-
-
Notifications
You must be signed in to change notification settings - Fork 32.5k
bpo-43795: PEP 652 user documentation #25668
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from 11 commits
28e34ab
61cf858
b9dc6d2
15cc273
f37ec96
d3c3107
179c132
377dd60
920965d
6b4c8db
e958d56
d0792e5
3fbc13a
5637b1f
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -6,34 +6,58 @@ | |
API and ABI Versioning | ||
*********************** | ||
|
||
``PY_VERSION_HEX`` is the Python version number encoded in a single integer. | ||
|
||
For example if the ``PY_VERSION_HEX`` is set to ``0x030401a2``, the underlying | ||
version information can be found by treating it as a 32 bit number in | ||
the following manner: | ||
|
||
+-------+-------------------------+------------------------------------------------+ | ||
| Bytes | Bits (big endian order) | Meaning | | ||
+=======+=========================+================================================+ | ||
| ``1`` | ``1-8`` | ``PY_MAJOR_VERSION`` (the ``3`` in | | ||
| | | ``3.4.1a2``) | | ||
+-------+-------------------------+------------------------------------------------+ | ||
| ``2`` | ``9-16`` | ``PY_MINOR_VERSION`` (the ``4`` in | | ||
| | | ``3.4.1a2``) | | ||
+-------+-------------------------+------------------------------------------------+ | ||
| ``3`` | ``17-24`` | ``PY_MICRO_VERSION`` (the ``1`` in | | ||
| | | ``3.4.1a2``) | | ||
+-------+-------------------------+------------------------------------------------+ | ||
| ``4`` | ``25-28`` | ``PY_RELEASE_LEVEL`` (``0xA`` for alpha, | | ||
| | | ``0xB`` for beta, ``0xC`` for release | | ||
| | | candidate and ``0xF`` for final), in this | | ||
| | | case it is alpha. | | ||
+-------+-------------------------+------------------------------------------------+ | ||
| | ``29-32`` | ``PY_RELEASE_SERIAL`` (the ``2`` in | | ||
| | | ``3.4.1a2``, zero for final releases) | | ||
+-------+-------------------------+------------------------------------------------+ | ||
|
||
Thus ``3.4.1a2`` is hexversion ``0x030401a2``. | ||
CPython exposes its version number in the following macros. | ||
Note that these correspond to the version code is built with, | ||
not necessarily the version used at run time. | ||
|
||
All the given macros are defined in :source:`Include/patchlevel.h`. | ||
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 | ||
encukou marked this conversation as resolved.
Show resolved
Hide resolved
|
||
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. | ||
|
||
For example if the ``PY_VERSION_HEX`` is set to ``0x030401a2``, the underlying | ||
encukou marked this conversation as resolved.
Show resolved
Hide resolved
|
||
version information can be found by treating it as a 32 bit number in | ||
the following manner: | ||
|
||
+-------+-------------------------+-------------------------+ | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Nice table as an example 😄 |
||
| Bytes | Bits (big endian order) | Meaning | | ||
+=======+=========================+=========================+ | ||
| 1 | 1-8 | ``PY_MAJOR_VERSION`` | | ||
+-------+-------------------------+-------------------------+ | ||
| 2 | 9-16 | ``PY_MINOR_VERSION`` | | ||
+-------+-------------------------+-------------------------+ | ||
| 3 | 17-24 | ``PY_MICRO_VERSION`` | | ||
+-------+-------------------------+-------------------------+ | ||
| 4 | 25-28 | ``PY_RELEASE_LEVEL`` | | ||
+ +-------------------------+-------------------------+ | ||
| | 29-32 | ``PY_RELEASE_SERIAL`` | | ||
+-------+-------------------------+-------------------------+ | ||
|
||
Thus ``3.4.1a2`` is hexversion ``0x030401a2`` and ``3.10.0`` is | ||
hexversion ``0x030a00f0``. | ||
|
||
|
||
All the given macros are defined in :source:`Include/patchlevel.h`. |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,37 +2,155 @@ | |
|
||
.. _stable: | ||
|
||
*********************************** | ||
*************** | ||
C API Stability | ||
*************** | ||
|
||
Python's C API is covered by the Backwards Compatibility Policy, :pep:`387`. | ||
While the C API will change with every minor release (e.g. from 3.9 to 3.10), | ||
most changes will be source-compatible, typically by only adding new API. | ||
Changing existing API or removing API is only done after a deprecation period | ||
or to fix serious issues. | ||
|
||
CPython's Application Binary Interface (ABI) is forward- and | ||
backwards-compatible across a minor release (if these are compiled the same | ||
way; see :ref:`stable-abi-platform` below). | ||
So, code compiled for Python 3.10.0 will work on 3.10.8 and vice versa, | ||
but will need to be compiled separately for 3.9.x and 3.10.x. | ||
|
||
Names prefixed by an underscore, such as ``_Py_InternalState``, | ||
are private API that can change without notice even in patch releases. | ||
|
||
|
||
Stable Application Binary Interface | ||
*********************************** | ||
|
||
Traditionally, the C API of Python will change with every release. Most changes | ||
will be source-compatible, typically by only adding API, rather than changing | ||
existing API or removing API (although some interfaces do get removed after | ||
being deprecated first). | ||
|
||
Unfortunately, the API compatibility does not extend to binary compatibility | ||
(the ABI). The reason is primarily the evolution of struct definitions, where | ||
addition of a new field, or changing the type of a field, might not break the | ||
API, but can break the ABI. As a consequence, extension modules need to be | ||
recompiled for every Python release (although an exception is possible on Unix | ||
when none of the affected interfaces are used). In addition, on Windows, | ||
extension modules link with a specific pythonXY.dll and need to be recompiled to | ||
link with a newer one. | ||
|
||
Since Python 3.2, a subset of the API has been declared to guarantee a stable | ||
ABI. Extension modules wishing to use this API (called "limited API") need to | ||
define ``Py_LIMITED_API``. A number of interpreter details then become hidden | ||
from the extension module; in return, a module is built that works on any 3.x | ||
version (x>=2) without recompilation. | ||
|
||
In some cases, the stable ABI needs to be extended with new functions. | ||
Extension modules wishing to use these new APIs need to set ``Py_LIMITED_API`` | ||
to the ``PY_VERSION_HEX`` value (see :ref:`apiabiversion`) of the minimum Python | ||
version they want to support (e.g. ``0x03030000`` for Python 3.3). Such modules | ||
will work on all subsequent Python releases, but fail to load (because of | ||
missing symbols) on the older releases. | ||
|
||
As of Python 3.2, the set of functions available to the limited API is | ||
documented in :pep:`384`. In the C API documentation, API elements that are not | ||
part of the limited API are marked as "Not part of the limited API." | ||
=================================== | ||
|
||
Python 3.2 introduced the *Limited API*, a subset of Python's C API. | ||
Extensions that only use the Limited API can be | ||
compiled once and work with multiple versions of Python. | ||
Contents of the Limited API are :ref:`listed below <stable-abi-list>`. | ||
|
||
To enable this, Python provides a *Stable ABI*: a set of symbols that will | ||
remain compatible across Python 3.x versions. The Stable ABI contains symbols | ||
exposed in the Limited API, but also other ones – for example, functions | ||
necessary to support older versions of the Limited API. | ||
|
||
(For simplicity, this document talks about *extensions*, but the Limited API | ||
and Stable ABI work the same way for all uses of the API – for example, | ||
embedding Python.) | ||
|
||
.. c:macro:: Py_LIMITED_API | ||
|
||
Define this macro ``Py_LIMITED_API`` before including ``Python.h`` to | ||
opt in to only use the Limited API. | ||
|
||
Defining ``Py_LIMITED_API`` to ``3`` will limit the available API so that | ||
the extension will work without recompilation with all Python 3.x releases | ||
(x>=2) on the particular :ref:`platform <stable-abi-platform>`. | ||
|
||
Defining ``Py_LIMITED_API`` to a value of :c:data:`PY_VERSION_HEX` will | ||
do the same, but allow additional API added up to specified version, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Great improvements to this section. The wording in this item is slightly confusing. Does this mean: It will use the Limited API for this version and later versions. Earlier versions lose compatibility since additional API may exist prior to this version. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Thanks for the note! It really helps to have a second set of eyes here. |
||
and lose compatibility with earlier versions. | ||
Rather than using the macro directly, hardcode a minimum minor version | ||
(e.g. ``0x030A0000`` for Python 3.10) for stability when compiling with | ||
future Python versions. | ||
|
||
On Windows, extensions that use the Stable ABI should be linked against | ||
``python3.dll`` rather than a version-specific library such as | ||
``python39.dll``. | ||
|
||
On some platforms, Python will look for and load shared library files named | ||
with the ``abi3`` tag (e.g. ``mymodule.abi3.so``). | ||
It does not check if such extensions conform to a Stable ABI. | ||
The user (or their packaging tools) need to ensure that, for example, | ||
extensions built with the 3.10+ Limited API are not installed for lower | ||
versions of Python. | ||
|
||
All functions in the Stable ABI are present as functions in Python's shared | ||
library, not solely as macros. This makes them usable from languages that don't | ||
use the C preprocessor. | ||
|
||
|
||
Limited API Scope and Performance | ||
--------------------------------- | ||
|
||
The goal for the Limited API is to allow everything that is possible with the | ||
full C API, but possibly with a performance penalty. | ||
|
||
For example, while :c:func:`PyList_GetItem` is available, its “unsafe” macro | ||
variant :c:func:`PyList_GET_ITEM` is not. | ||
The macro can be faster because it can rely on version-specific implementation | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Good example. |
||
details of the list object. | ||
|
||
Without ``Py_LIMITED_API`` defined, some C API functions are inlined or | ||
replaced by macros. | ||
Defining ``Py_LIMITED_API`` disables this inlining, allowing stability as | ||
Python's data structures are improved, but possibly reducing performance. | ||
|
||
By leaving out the ``Py_LIMITED_API`` definition, it is possible to compile | ||
a Limited API extension with a version-specific ABI. This can improve | ||
performance for that Python version, but will limit compatibility. | ||
Compiling with ``Py_LIMITED_API`` will then yield an extension that can be | ||
distributed where a version-specific one is not available – for example, | ||
for prereleases of an upcoming Python version. | ||
|
||
|
||
Limited API Caveats | ||
------------------- | ||
|
||
Note that compiling with ``Py_LIMITED_API`` is *not* a complete guarantee that | ||
code conforms to the Limited API or the Stable ABI. ``Py_LIMITED_API`` only | ||
covers definitions, but an API also includes other issues, such as expected | ||
semantics. | ||
|
||
One issue that ``Py_LIMITED_API`` does not guard against is calling a function | ||
with arguments that are invalid in a lower Python version. | ||
For example, consider a function that starts accepting ``NULL`` for an | ||
argument. In Python 3.9, ``NULL`` now selects a default behavior, but in | ||
Python 3.8, the argument will be used directly, causing a ``NULL`` dereference | ||
and crash. A similar argument works for fields of structs. | ||
|
||
Another issue is that some struct fields are currently not hidden when | ||
``Py_LIMITED_API`` is defined, even though they're part of the Limited API. | ||
|
||
For these reasons, we recommend testing an extension with *all* minor Python | ||
versions it supports, and preferably to build with the *lowest* such version. | ||
|
||
We also recommend reviewing documentation of all used API to check | ||
if it is explicitly part of the Limited API. Even with ``Py_LIMITED_API`` | ||
defined, a few private declarations are exposed for technical reasons (or | ||
even unintentionally, as bugs). | ||
|
||
Also note that the Limited API is not necessarily stable: compiling with | ||
``Py_LIMITED_API`` with Python 3.8 means that the extension will | ||
run with Python 3.12, but it will not necessarily *compile* with Python 3.12. | ||
In particular, parts of the Limited API may be deprecated and removed, | ||
provided that the Stable ABI stays stable. | ||
|
||
|
||
.. _stable-abi-platform: | ||
|
||
Platform Considerations | ||
======================= | ||
|
||
ABI stability depends not only on Python, but also on the compiler used, | ||
lower-level libraries and compiler options. For the purposes of the Stable ABI, | ||
these details define a “platform”. They usually depend on the OS | ||
type and processor architecture | ||
|
||
It is the responsibility of each particular distributor of Python | ||
to ensure that all Python versions on a particular platform are built | ||
in a way that does not break the Stable ABI. | ||
This is the case with Windows and macOS releases from ``python.org`` and many | ||
third-party distributors. | ||
|
||
|
||
.. _stable-abi-list: | ||
|
||
Contents of Limited API | ||
======================= | ||
|
||
|
||
Currently, the Limited API includes the following items: | ||
|
||
.. limited-api-list:: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Perhaps bold part of this sentence re: build version vs run-time version.