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.
-
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 ifauto_generate
is set toTrue
. -
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.
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!
- Farhan Bin Faisal
- Michael Suriawan
- Lukman Lateef
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.
fml_doc_gen
was created by Farhan Faisal, Lukman Lateef, and Michael Suriawan. It is licensed under the terms of the MIT license.
fml_doc_gen
was created with cookiecutter
and the py-pkgs-cookiecutter
template.