This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

classification
Title: Make PYLONG_BITS_IN_DIGIT always available to non-core extensions
Type: enhancement Stage:
Components: Build Versions: Python 3.5
process
Status: open Resolution:
Dependencies: Superseder:
Assigned To: Nosy List: mark.dickinson, scoder
Priority: normal Keywords:

Created on 2014-08-31 10:22 by scoder, last changed 2022-04-11 14:58 by admin.

Messages (1)
msg226167 - (view) Author: Stefan Behnel (scoder) * (Python committer) Date: 2014-08-31 10:22
"longintrepr.h" is a non-public header file (not included by Python.h) that defines the inner struct layout of PyLong objects. Including it allows for very fast access to "small" integers through ob_digit[0] when -1 <= Py_SIZE(n) <= 1, which is a great feature.

However, the header file depends on PYLONG_BITS_IN_DIGIT being defined and matching exactly the value that was used when building CPython. In the case that --enable-big-digits=X was passed to configure, this value is available from pyconfig.h. Otherwise, it will be determined by pyport.h, where it depends on the current configuration of the C compiler and may in some cases come up with a different definition than it did when building CPython (which then leads to crashes).

I'd like to have the correct build-time value always available in one way or another, e.g. by always storing it in pyconfig.h even when it was not user configured, so that including and using longintrepr.h becomes a safe and simple thing.
History
Date User Action Args
2022-04-11 14:58:07adminsetgithub: 66509
2014-08-31 10:22:00scodercreate