API and ABI Versioning (original) (raw)
Build-time version constants¶
CPython exposes its version number in the following macros. Note that these correspond to the version code is built with. See Py_Version for the version used at run time.
See C API Stability for a discussion of API and ABI stability across versions.
PY_MAJOR_VERSION¶
The 3
in 3.4.1a2
.
PY_MINOR_VERSION¶
The 4
in 3.4.1a2
.
PY_MICRO_VERSION¶
The 1
in 3.4.1a2
.
PY_RELEASE_LEVEL¶
The a
in 3.4.1a2
. This can be 0xA
for alpha, 0xB
for beta, 0xC
for release candidate or 0xF
for final.
PY_RELEASE_SERIAL¶
The 2
in 3.4.1a2
. Zero for final releases.
PY_VERSION_HEX¶
The Python version number encoded in a single integer. See Py_PACK_FULL_VERSION() for the encoding details.
Use this for numeric comparisons, for example,#if PY_VERSION_HEX >= ...
.
Run-time version¶
const unsigned long Py_Version¶
Part of the Stable ABI since version 3.11.
The Python runtime version number encoded in a single constant integer. See Py_PACK_FULL_VERSION() for the encoding details. This contains the Python version used at run time.
Use this for numeric comparisons, for example, if (Py_Version >= ...)
.
Added in version 3.11.
Bit-packing macros¶
uint32_t Py_PACK_FULL_VERSION(int major, int minor, int micro, int release_level, int release_serial)¶
Part of the Stable ABI since version 3.14.
Return the given version, encoded as a single 32-bit integer with the following structure:
Argument | No. of bits | Bit mask | Bit shift | Example values | |
---|---|---|---|---|---|
3.4.1a2 | 3.10.0 | ||||
major | 8 | 0xFF000000 | 24 | 0x03 | 0x03 |
minor | 8 | 0x00FF0000 | 16 | 0x04 | 0x0A |
micro | 8 | 0x0000FF00 | 8 | 0x01 | 0x00 |
release_level | 4 | 0x000000F0 | 4 | 0xA | 0xF |
release_serial | 4 | 0x0000000F | 0 | 0x2 | 0x0 |
For example:
Version | Py_PACK_FULL_VERSION arguments | Encoded version |
---|---|---|
3.4.1a2 | (3, 4, 1, 0xA, 2) | 0x030401a2 |
3.10.0 | (3, 10, 0, 0xF, 0) | 0x030a00f0 |
Out-of range bits in the arguments are ignored. That is, the macro can be defined as:
#ifndef Py_PACK_FULL_VERSION
#define Py_PACK_FULL_VERSION(X, Y, Z, LEVEL, SERIAL) (
(((X) & 0xff) << 24) |
(((Y) & 0xff) << 16) |
(((Z) & 0xff) << 8) |
(((LEVEL) & 0xf) << 4) |
(((SERIAL) & 0xf) << 0))
#endif
Py_PACK_FULL_VERSION
is primarily a macro, intended for use in#if
directives, but it is also available as an exported function.
Added in version 3.14.
uint32_t Py_PACK_VERSION(int major, int minor)¶
Part of the Stable ABI since version 3.14.
Equivalent to Py_PACK_FULL_VERSION(major, minor, 0, 0, 0)
. The result does not correspond to any Python release, but is useful in numeric comparisons.
Added in version 3.14.