Skip to main content

Automatic C++ library API documentation generator using Doxygen, Sphinx, and

Project description

Documentation Status Latest Version Code Coverage Report License BSD-3 Clause

Automatic C++ library API documentation generator using Doxygen, Sphinx, and Breathe. Exhale revives Doxygen’s class, file, and page hierarchies in reStructuredText documents to make these hierarchies available in Sphinx documented projects.

Is it For Me?

Exhale might not be the tool you are looking for! It was designed to be as intuitive and flexible as possible, but it does require more machinery to get everything started.

Why use it?

You would use Exhale if you want to have beautiful Sphinx generated websites, but also see the value of the Class, File, and Page hierarchies provided by Doxygen. From running Doxygen for you, to organizing your full API every time, you won’t need to worry about your documentation getting out of sync with the code — it’s regenerated on the fly every time.

Why not use it?

It may be more involved than you need. Check out the breathe-apidoc tool that comes with your installation of breathe. It is quite similar to the Sphinx API doc tool, and that may be all you are looking for to get your documentation displayed.

If you are working with a small enough framework, you may also be satisfied with just using the .. autodoxygenindex:: directive from breathe. It works very well!

The Main Difference

The Class, File, and Page hierarchies are only available in Sphinx via Exhale 😊

Depending on the size and complexity of your project, breathe-apidoc or autodoxygenindex may be more appropriate.

Important Consideration

Exhale is known to work well on small to medium sized projects. Supporting larger projects in Sphinx is a much more involved process that may or may not be resolved over time – this has to do with a lot more than just Exhale, but the nature of Exhale (generation of a large number of .rst files) definitely does not help.

Please see the full documentation for more information on how to get started.

See it in Action

The ExhaleCompanion repository has three builds to demonstrate the different options with respect to creating a Tree View, as well as details of specific HTML Theme choices:

HTML Theme Choice

TreeView Created

ExhaleCompanion Docs

RTD Theme

Yes

rtd-docs

Bootstrap Theme

Yes

bootstrap-docs

Alabaster

No

alabaster-docs

Installation

Exhale is a Sphinx Extension that depends on Breathe for access to the Doxygen reStructuredText directives, and both BeautifulSoup and lxml for parsing the generated Doxygen XML documentation. Exhale is hosted on PyPI, meaning you can install it through the normal mechanisms, e.g.,

$ python -m pip install exhale

This will install Exhale, as well as all of its dependencies.

Exhale Version Compatibility with Python, Sphinx, and Breathe

Exhale Version

Python Version

Sphinx Version

Breathe Version

0.3.2 – 0.3.4

>=3.7

>=3.0,<5

>=4.32.0

0.3.0

>=3.6

>=3.0,<5

>=4.32.0

0.2.1 – 0.2.4

2.7, 3.3+

>=1.6.1

“Any”

<=0.2.0

2.7, 3.3+

>=1.0

“Any”

For your project’s documentation requirements, adopting exhale@0.3.0 means you just need to specify directly that your docs/requirements.txt or similar express:

exhale>=0.3.0

The exhale@0.3.0 release uses the same dependencies required by breathe@4.32.0. If you need python 3.5 support, pin your documentation requirements to:

sphinx>=2.0
breathe>=4.13.0
exhale<0.3.0

For Python 2.7, you should pin your documentation requirements to:

sphinx==1.8.5
breathe==4.12.0
exhale<0.3.0

Order matters, namely that sphinx and breathe appear / are installed before exhale. Exhale 0.2.* releases support Python 2.7, but users need to be aware of the dependencies between Python, Sphinx, and Breathe versions.

Credit

This project could not exist without the already excellent tools available: Doxygen, Sphinx, Breathe, and many others. In particular, though, for the Tree View hierarchies to be successful, I vendor copies of two excellent libraries that I make no claims to. They are vendored with your installation of Exhale, in accordance with each project’s license:

  1. For non-bootstrap, I used Kate Morley’s excellent and lightweight collapsibleLists including the sample CSS / images on that post. She includes a generous CC0 1.0 license for these files, as well as the rest of her website.

    For every HTML Theme I have tried, except for ones using bootstrap, this library works reliably and consistently. It matches the Sphinx RTD theme quite well, too!

  2. For bootstrap, I used Jon Miles’ comprehensive bootstrap-treeview library. Jon Miles hosts this library using the Apache v2 license.

    This library is exceptionally well thought out and enables an impressive amount of customization. At this time, Exhale does not expose any of the available customizations. If there is a specific one you’d like to see, please join the discussion here.

Both of these libraries and copies of their licenses can be found in the data folder of the source code.

License

This project uses a BSD 3-clause license, in hopes that it will be accessible to most projects. If you require a different license, please raise an issue and I will consider a dual license.

The full license is available here.

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

exhale-0.3.4.tar.gz (104.6 kB view details)

Uploaded Source

Built Distribution

exhale-0.3.4-py3-none-any.whl (108.0 kB view details)

Uploaded Python 3

File details

Details for the file exhale-0.3.4.tar.gz.

File metadata

  • Download URL: exhale-0.3.4.tar.gz
  • Upload date:
  • Size: 104.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.13

File hashes

Hashes for exhale-0.3.4.tar.gz
Algorithm Hash digest
SHA256 8fe83b2d96ef41e0f921b865c1bf46c40c6907cbeff0207ab9b445fd54539a16
MD5 a253746c6ac25b15535bdd76f79221ba
BLAKE2b-256 222636be64b9741d6c984009f1ae998f65c95c8acd9a4abfdd4b641f86701991

See more details on using hashes here.

File details

Details for the file exhale-0.3.4-py3-none-any.whl.

File metadata

  • Download URL: exhale-0.3.4-py3-none-any.whl
  • Upload date:
  • Size: 108.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.13

File hashes

Hashes for exhale-0.3.4-py3-none-any.whl
Algorithm Hash digest
SHA256 0871fa29ff9ac91c14e0dd69ad40db798068b4407e2e7ba5f650e07cedd6f365
MD5 189e06d0383bfc7ab1facce1f14e34df
BLAKE2b-256 ba153be4b6ab17ede80e5940bae11647cd7c5eb86aa21d92b762dedd30b41552

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