Docstrings in C extensions to Python?
Asked Answered
G

1

22

When creating a C extension to Python, is it possible to be able to somehow write comments that are exposed as docstrings to users of the extension?

Guile answered 6/6, 2011 at 23:20 Comment(1)
You may already be aware of it, but if not: You might want to investigate Cython. You write Python-style code, add some type declarations, and it gets translated to C and compiled.Sherrer
D
21

Docstrings for types can be included as the tp_doc member in the PyTypeObject structure, see an example in the docs.

Docstrings for functions can be included in the ml_doc field of the module's method table. If you want your docstrings to be "physically close" to the actual functions, you could include string constants above your function definitions which you reference in the method table.

Docstrings for methods can be assigned to the doc field in the type's member table.

Docstrings for modules can be passed as a parameter to the Py_InitModule3() or Py_InitModule4() functions.


UPDATE: Python3 does not support Py_InitModule3(), and the method has been replaced with PyModule_Create().

Defloration answered 6/6, 2011 at 23:33 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.