Skip to main content

doc string generator

Project description

fml_doc_gen

Documentation Status codecov

Authors

  • Farhan Bin Faisal
  • Michael Suriawan
  • Lukman Lateef

Summary

fml_doc_gen is a Python package designed to simplify the process of writing docstrings for user-defined functions. It offers an automated way to generate docstring templates or fully detailed docstrings through integration with the OpenAI API. By streamlining documentation, it helps developers save time, improve code readability, and maintain consistent documentation standards across projects.

Installation

$ pip install fml_doc_gen 

Usage

generate_docstring_template can be used to generate docstring template for your function shown below:

import fml_doc_gen
from fml_doc_gen.fml_doc_gen import generate_docstring_template

def square(base: int, pow: int) -> int:
    return base ** pow

print(generate_docstring_template(square, output_file=None))

Functions Included

  • generate_docstring_template(func: Callable, output_file: str, auto_generate: bool = False) -> str: The main end-user function that generates either a docstring template with placeholders or a fully detailed docstring if auto_generate is set to True.

  • read_user_function(func: Callable) -> str: Reads and extracts the signature and existing docstring (if any) of a given user-defined function.

  • generate_template(func_signature: str) -> str: Creates a docstring template with placeholders for parameters, return values, and a brief description based on the function signature.

  • write_docstring_to_file(docstring: str, output_file: str) -> None: Writes the generated docstring to a specified file.

Python Ecosystem

fml_doc_gen fits into the Python ecosystem as a specialized tool for automating function documentation. While other Python packages like sphinx and pydoc exist for generating documentation from docstrings, there are no widely known packages that automatically generate docstrings themselves using AI. This makes fml_doc_gen unique in its approach by leveraging OpenAI's capabilities to produce high-quality docstrings with minimal effort from the developer.

If you are aware of a similar tool, feel free to contribute to our documentation by suggesting it!

Contributing

Interested in contributing? Check out the contributing guidelines. Please note that this project is released with a Code of Conduct. By contributing to this project, you agree to abide by its terms.

License

fml_doc_gen was created by Farhan Faisal, Lukman Lateef, and Michael Suriawan. It is licensed under the terms of the MIT license.

Credits

fml_doc_gen was created with cookiecutter and the py-pkgs-cookiecutter template.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fml_doc_gen-3.0.0.tar.gz (5.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fml_doc_gen-3.0.0-py3-none-any.whl (7.1 kB view details)

Uploaded Python 3

File details

Details for the file fml_doc_gen-3.0.0.tar.gz.

File metadata

  • Download URL: fml_doc_gen-3.0.0.tar.gz
  • Upload date:
  • Size: 5.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for fml_doc_gen-3.0.0.tar.gz
Algorithm Hash digest
SHA256 e974783b2b9232d441c5cd0c8360667bf48e582c7b6e370a2d0d7572834d2197
MD5 d6becafa6d5c9acd7b236e7185814020
BLAKE2b-256 c5cd6c40263e5a2aa3b8bbded8ea55f1101acad94eb9b9ed30eff8212a5a77c9

See more details on using hashes here.

File details

Details for the file fml_doc_gen-3.0.0-py3-none-any.whl.

File metadata

  • Download URL: fml_doc_gen-3.0.0-py3-none-any.whl
  • Upload date:
  • Size: 7.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for fml_doc_gen-3.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d7bac5bc7bc8eaf436ffb6e159e4690d0f6beab77067da45dcbed4a477a53f60
MD5 87eb427cee82552573443a82ee062af0
BLAKE2b-256 40a70d5303828c34042bf9cb73e6277c5f997895fa5fd8c9cd8542c3edbe2f90

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page