f4pga/doxygen
Robert Winkler 4bd488cdcd Add support for documenting C++ with Sphinx
Signed-off-by: Robert Winkler <rwinkler@antmicro.com>
2019-10-18 09:44:31 +02:00
..
c.doxyfile.in Add support for documenting C++ with Sphinx 2019-10-18 09:44:31 +02:00
CMakeLists.txt Add support for documenting C++ with Sphinx 2019-10-18 09:44:31 +02:00
doxygen.cmake Add support for documenting C++ with Sphinx 2019-10-18 09:44:31 +02:00
README.md Add support for documenting C++ with Sphinx 2019-10-18 09:44:31 +02:00

Adding C++ support for a new project

  1. Add the project to the symbiflow-docs/doxygen/CMakeLists.txt, i.e:
add_doxygen_project(
    PRJNAME "prjxray"
    INPUT_DIR "${SYMBIFLOW_DOCS_DIR}/source/prjxray/lib"
              "${SYMBIFLOW_DOCS_DIR}/source/prjxray/tools"
    LANGUAGE "c++"
    FILE_EXTENSIONS ".cpp" ".cc" ".h" ".hh")
  • PRJNAME - the project's name
  • INPUT_DIR - input directories which will be recursively scanned for documented files
  • LANGUAGE - the programming language of the project (currently only "c" and "c++" are supported") This variable is used to determine proper doxygen configuration template (<lang>.doxyfile.in file)
  • FILE_EXTENSIONS - extensions of the files that contain documentation

The generated doxygen documentation will be placed in symbiflow-docs/build/doxygen/<PRJNAME>/xml directory

  1. Add the project to the breathe_projects variable in symbiflow-docs/source/conf.py:
breathe_projects = {
    ...
    "prjxray" : "../build/doxygen/prjxray/xml",
    ...
}

The first field in the dictionary refers to the project's name. This value is placed after :project: property in the Breathe's directives.

The second field in dictionary refers to the Doxygen documentation output directory. It should be a relative path to generated Doxygen documentation, mentioned above.

  1. Now you can document the project using the breathe plugin. Note that every class should be documented using its full namespace, i.e:
.. doxygenclass:: prjxray::xilinx::xc7series::ConfigurationBus
   :project: prjxray