This tool processes a sequence of C/C++ headers and extracts comments that can be referenced to generate docstrings in pybind11 binding code.
To install the latest development version:
python -m pip install git+git://github.com/pybind/pybind11_mkdoc.git@master
To use this tool, simply invoke it with a list of header files. All output will
be written to stdout
, or to a filename provided via the -o
parameter.
python -m pybind11_mkdoc -o docstrings.h header_file_1.h header_file_2.h
Optionally, the path to the libclang.so
and LLVM directory can be specified by setting the LIBCLANG_PATH and LLVM_DIR_PATH environment variables respectively.
Suppose we provide an input file with the following contents:
/// Docstring 1
class MyClass {
/// Docstring 2
MyClass() {
}
/// Docstring 3
void foo() {
}
/// Docstring 4 for overload
void foo(int bar) {
}
/// Docstring 5 for yet another overload
void foo(int bar, int baz) {
}
};
Once processed via pybind11_mkdoc
, the docstrings can be accessed as follows
from pybind11 binding code:
#include "docstrings.h"
const char *docstring_1 = DOC(MyClass);
const char *docstring_2 = DOC(MyClass, MyClass);
const char *docstring_3 = DOC(MyClass, foo);
const char *docstring_4 = DOC(MyClass, foo, 2);
const char *docstring_5 = DOC(MyClass, foo, 3);
Note the counter suffix for repeated definitions and docstrings. Namespaces and
nested classes are also supported, in which case the number of arguments to the
DOC
macro simply increases.
In practice, the docstrings are likely referenced in a matching set of binding declarations:
py::class_<MyClass>(m, "MyClass", DOC(MyClass))
.def(py::init<>(), DOC(MyClass, MyClass))
...
This tool supports Linux and macOS for Python versions 3.8 to 3.11. Also, it requires Clang/LLVM to be installed.
Install the packages pytest
, pytest-xdist
, and flit
:
python3 -m pip install pytest==7.1.3 pytest-xdist==2.4.0
Next, install this project:
python3 -m pip install .
And execute the tests (forked)
python3 -m pytest --forked