Skip to content

Automatic generation of documentation for mkdocs

License

Notifications You must be signed in to change notification settings

weijenloi/automacdoc

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Welcome to AutoMacDoc

What is AutoMacDoc?

AutoMacDoc is a tool to generate documentation for Python modules or groups of functions. It is based on MkDocs and written in Python.

Why this project?

To keep it simple:

  • The best tool to auto generate a doc is Sphinx but it is complicated and it uses reStructuredText.
  • reStructuredText sucks, MarkDown rocks!
  • MkDocs is an amazing tool to generate a website with MarkDown.
  • We lack a tool to transform a folder of code into a nice and clean MkDocs project

How to install ?

With pip pardi : pip install automacdoc

Recipe to make it works!

  • Ingredients:

    • a folder with some python codes inside (like the folder example here)
    • nice and well documented functions inside this code
  • Easy steps:

    • install automacdoc
    • open a terminal and type automacdoc example/src example

How is works ?

AutoMacDoc list all your python functions and class in the folder (in example/src here) and generate doc about it (in example here)! It creates:

  • a 'docs' folder that contains the documentation in markdown (see MkDocs for more details)
  • a 'site' folder that contains the static sitePP
  • a 'mkdocs.yml' file that in the config file for mkdocs (see MkDocs for more details)

Minimal project layout

  • before AutoMacDoc:
 src/
     ...         # Other python files or folders
  • after AutoMacDoc:
 mkdocs.yml      # The configuration file.

 src/
     ...         # Other python files or folders

 docs/
     index.md    # The documentation homepage.
     ...         # Other markdown pages, images and other files.

 site/           # The static site ready to be hosted
     index.html
     ...

Recommended Docstring

Code:

def fun(arg1: int, arg2: str = 'Hello World!'):
    """Description of your function

    **Parameters**

    > **arg1:** `int` -- Description of argument `arg1`.

    > **arg2:** `str` -- Description of argument `arg2`.

    **Returns**

    > `str` -- Description of returned object.
    """
    return arg2 + str(arg1)

Screenshot:

recommended docstring screenshot

You want more ?

Check the example folder, you will found tons of fancy elements you can now add to your documentation.

About

Automatic generation of documentation for mkdocs

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%