Exhale

Warning

There is a reason why Exhale is development status 2 as far as pip is concerned. It is functional enough that it should work for your project, but there are a number of features I still intend to implement when there is more time.

In particular, Exhale underwent a significant rewrite. There is a decent amount of redundant, dead, and unused code. There is also a large portion of documentation that is either outdated or just flat out inaccurate. The graph module used to be the entire project (it was a single file library).

Automatic C++ library API documentation generator using Doxygen, Sphinx, and Breathe. Exhale revives Doxygen’s class / file hierarchies using reStructuredText for superior markup syntax / websites.

Exhale is a Sphinx extension that depends on the excellent Breathe extension which enables parsing Doxygen documentation into the Sphinx domain. Exhale provides a layer of automation, enabling launching Doxygen and generating the full website all from your conf.py. Exhale will execute these actions by way of sphinx-build being invoked, allowing you to use it for hosting on Read the Docs. Exhale was designed for generating html output, and may not be appropriate for other builders provided by Sphinx.

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 docs
Bootstrap Theme Yes bootstrap
Alabaster No alabaster

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 also uses six help account for the Python 2 unicode dilemma. The easiest way to install Exhale is:

# For python3.
# https://wiki.python.org/moin/Python2orPython3#What_are_the_differences.3F
$ pip3 install exhale

# For python2.
$ pip install exhale

This will install Exhale, as well as all of its dependencies. You are of course capable of installing Exhale through other means, as it contains a setup.py, but since I strongly discourage this, I will not provide you with instructions on how to do so.

Note

If you fail pip3 install exhale and it is failing on lxml, you will likely need to install the proper development libraries. See the lxml installation instructions for possible fixes.

lxml is readily available for Read The Docs and generally installs seamlessly for Unix systems, but my understanding is Windows users may need to put a little more effort in to get it to install.

Getting Started

A Quickstart Guide gives the bare minimum needed to get things working, please read the Overview section if you are new to documenting code with either Doxygen, Sphinx, or Breathe.

Tip

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 and File 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 and File 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.

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 Stephen Morley’s excellent and lightweight collapsibleLists including the sample CSS / images on that post. He includes a generous CC0 license for these files, as well as the rest of his 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.

Legacy

Legacy documentation is available here for if you chanced upon this library when it was a single file.