Skip to main content

Hawkmoth - Sphinx Autodoc for C

Project description

Hawkmoth is a minimalistic Sphinx C Domain autodoc directive extension to incorporate formatted C source code comments written in reStructuredText into Sphinx based documentation. It uses Clang Python Bindings for parsing, and generates C Domain directives for C API documentation, and more. In short, Hawkmoth is Sphinx Autodoc for C.

Hawkmoth aims to be a compelling alternative for documenting C projects using Sphinx, mainly through its simplicity of design, implementation and use.

Example

Given C source code with rather familiar looking documentation comments:

/**
 * Get foo out of bar.
 */
void foobar();

and a directive in the Sphinx project:

.. c:autodoc:: filename.c

you can incorporate code documentation into Sphinx. It’s as simple as that.

You can document functions, their parameters and return values, structs, unions, their members, macros, function-like macros, enums, enumeration constants, typedefs, variables, as well as have generic documentation comments not attached to any symbols.

Documentation

Documentation on how to install and configure Hawkmoth, and write documentation comments, with examples, is available in the doc directory in the source tree, obviously in Sphinx format and using the directive extension. Pre-built documentation showcasing what Hawkmoth can do is available at Read the Docs.

Installation

You can install Hawkmoth from PyPI with:

pip install hawkmoth

You’ll additionally need to install Clang and Python 3 bindings for it through your distro’s package manager; they are not available via PyPI. For further details, see the documentation.

Alternatively, installation packages are available for:

In Sphinx conf.py, add hawkmoth to extensions, and point cautodoc_root at the source tree. See the extension documentation for details.

Development and Contributing

Hawkmoth source code is available on GitHub. The development version can be checked out via git using this command:

git clone https://github.com/jnikula/hawkmoth.git

Please file bugs and feature requests as GitHub issues. Contributions are welcome both as emailed patches to the mailing list and as pull requests.

Dependencies

  • Python 3.6

  • Sphinx 3

  • Clang 6.0

  • Python 3 Bindings for Clang 6.0

  • pytest (for development)

  • sphinx-testing 1.0.0 (for development)

These are the versions Hawkmoth is currently being developed and tested against. Other versions might work, but no guarantees.

License

Hawkmoth is free software, released under the 2-Clause BSD License.

Contact

IRC channel #hawkmoth on freenode.

Mailing list hawkmoth@freelists.org. Subscription information at the list home page.

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

hawkmoth-0.8.0.tar.gz (16.2 kB view details)

Uploaded Source

Built Distribution

hawkmoth-0.8.0-py3-none-any.whl (15.7 kB view details)

Uploaded Python 3

File details

Details for the file hawkmoth-0.8.0.tar.gz.

File metadata

  • Download URL: hawkmoth-0.8.0.tar.gz
  • Upload date:
  • Size: 16.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.2

File hashes

Hashes for hawkmoth-0.8.0.tar.gz
Algorithm Hash digest
SHA256 38bda607b589108beb99ad915602b5786214c8decedf91ca9eb24d4ea5707a1c
MD5 f3227790e03a86669cc2ac573859803b
BLAKE2b-256 dc9b1c24acf4bb674d8f2693f1b5e2c5c48696cde92a1d58f3849c38b164bd9a

See more details on using hashes here.

File details

Details for the file hawkmoth-0.8.0-py3-none-any.whl.

File metadata

  • Download URL: hawkmoth-0.8.0-py3-none-any.whl
  • Upload date:
  • Size: 15.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.2

File hashes

Hashes for hawkmoth-0.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d287f898962e7fabc0a5c8ec6333507e157821ebb9196a5e6a4516688b6b941d
MD5 c722b358657da0d079f373ad39a07ef7
BLAKE2b-256 8ea6312cfcbbba6a15d8e5827c9261594b98d0ff3cb16e32ebba016d60b75bb5

See more details on using hashes here.

Supported by

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