2.4 KiB
Development
This document outlines how to set up a development environment for Quicktex. Documentation on writing Python extension modules is sparse, so I hope this document is useful for other projects as well. The Coding Patterns for Python Extensions site has some useful information and will be linked to often in this document.
Setting up Debug Python
Many development tools require debug symbols to function, and since the front-end for accessing an extension module is Python, that usually means adding debug symbols to Python. This Page has some instructions on building python with debug symbols.
If you plan to use DTrace, enable the --with-dtrace
flag when running configure
.
It's useful for this debug python to have SSL enabled so that packages can be installed using pip. Enable SSL with the --with-openssl
flag when running configure
. If you are on macOS and installed OpenSSL through Homebrew, you may need to use --with-openssl=$(brew --prefix openssl)
to help the compiler find it.
Installing Debug Python
You can keep the resulting binary in your local copy of the cpython repo and symlink to it, but I like to install it somewhere like /opt/python-debug/
. The install location is set in the configure
tool using the --prefix
flag, and installation is done by running make install
Mixing Debug and Release Python
The debug build of python is slow (It may be possible to build with debug symbols but full optimization, I have not looked into it). If you already have a venv setup for your project, you can just symlink the debug python binary into env/bin
with a full name like python3.9d
. Make sure that the debug build has the same minor version (e.g '3.9') as the version you made the virtual environment with to maintain ABI compatibility.
Profiling with Dtrace
DTrace is the default program profiler on macOS and other Unix systems, but it's also available for use on Windows and Linux. Using DTrace requires building Python with DTrace hooks as seen above.
Your extension module does not need a full debug build to profile, but it does need frame pointers to see the stack trace at each sample, as well as debug symbols to give functions names. The cmake build type RelWithDebInfo
handles this automatically.