mirror of
https://github.com/python/cpython.git
synced 2025-07-07 19:35:27 +00:00
123 lines
4.4 KiB
ReStructuredText
123 lines
4.4 KiB
ReStructuredText
.. highlight:: c
|
|
|
|
.. _apiabiversion:
|
|
|
|
***********************
|
|
API and ABI Versioning
|
|
***********************
|
|
|
|
|
|
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 :c:var:`Py_Version` for the version used at **run time**.
|
|
|
|
See :ref:`stable` for a discussion of API and ABI stability across versions.
|
|
|
|
.. c:macro:: PY_MAJOR_VERSION
|
|
|
|
The ``3`` in ``3.4.1a2``.
|
|
|
|
.. c:macro:: PY_MINOR_VERSION
|
|
|
|
The ``4`` in ``3.4.1a2``.
|
|
|
|
.. c:macro:: PY_MICRO_VERSION
|
|
|
|
The ``1`` in ``3.4.1a2``.
|
|
|
|
.. c:macro:: 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.
|
|
|
|
.. c:macro:: PY_RELEASE_SERIAL
|
|
|
|
The ``2`` in ``3.4.1a2``. Zero for final releases.
|
|
|
|
.. c:macro:: PY_VERSION_HEX
|
|
|
|
The Python version number encoded in a single integer.
|
|
See :c:func:`Py_PACK_FULL_VERSION` for the encoding details.
|
|
|
|
Use this for numeric comparisons, for example,
|
|
``#if PY_VERSION_HEX >= ...``.
|
|
|
|
|
|
Run-time version
|
|
----------------
|
|
|
|
.. c:var:: const unsigned long Py_Version
|
|
|
|
The Python runtime version number encoded in a single constant integer.
|
|
See :c:func:`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 >= ...)``.
|
|
|
|
.. versionadded:: 3.11
|
|
|
|
|
|
Bit-packing macros
|
|
------------------
|
|
|
|
.. c:function:: uint32_t Py_PACK_FULL_VERSION(int major, int minor, int micro, int release_level, int release_serial)
|
|
|
|
Return the given version, encoded as a single 32-bit integer with
|
|
the following structure:
|
|
|
|
+------------------+-------+----------------+-----------+--------------------------+
|
|
| | No. | | | Example values |
|
|
| | of | | +-------------+------------+
|
|
| Argument | bits | Bit mask | Bit shift | ``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:
|
|
|
|
.. code-block:: c
|
|
|
|
#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.
|
|
|
|
.. versionadded:: 3.14
|
|
|
|
.. c:function:: uint32_t Py_PACK_VERSION(int major, int minor)
|
|
|
|
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.
|
|
|
|
.. versionadded:: 3.14
|