/* Macros that restrict available definitions and select implementations * to match an ABI stability promise: * * - internal API/ABI (may change at any time) -- Py_BUILD_CORE* * - general CPython API/ABI (may change in 3.x.0) -- default * - Stable ABI: abi3, abi3t (long-term stable) -- Py_LIMITED_API, * Py_TARGET_ABI3T, _Py_OPAQUE_PYOBJECT * - Free-threading (incompatible with non-free-threading builds) * -- Py_GIL_DISABLED */ #ifndef _Py_PYABI_H #define _Py_PYABI_H /* Defines to build Python and its standard library: * * - Py_BUILD_CORE: Build Python core. Gives access to Python internals; should * not be used by third-party modules. * - Py_BUILD_CORE_BUILTIN: Build a Python stdlib module as a built-in module. * - Py_BUILD_CORE_MODULE: Build a Python stdlib module as a dynamic library. * * Py_BUILD_CORE_BUILTIN and Py_BUILD_CORE_MODULE imply Py_BUILD_CORE. * * On Windows, Py_BUILD_CORE_MODULE exports "PyInit_xxx" symbol, whereas * Py_BUILD_CORE_BUILTIN does not. */ #if defined(Py_BUILD_CORE_BUILTIN) && !defined(Py_BUILD_CORE) # define Py_BUILD_CORE #endif #if defined(Py_BUILD_CORE_MODULE) && !defined(Py_BUILD_CORE) # define Py_BUILD_CORE #endif /* Check valid values for target ABI macros. */ #if defined(Py_LIMITED_API) && Py_LIMITED_API+0 < 3 // Empty Py_LIMITED_API used to work; redefine to // Python 3.2 to be explicit. # undef Py_LIMITED_API # define Py_LIMITED_API 0x03020000 #endif #if defined(Py_TARGET_ABI3T) && Py_TARGET_ABI3T+0 < 0x030f0000 # error "Py_TARGET_ABI3T must be 0x030f0000 (3.15) or above" #endif /* Stable ABI for free-threaded builds (abi3t, introduced in PEP 803) * is enabled by one of: * - Py_TARGET_ABI3T, or * - Py_LIMITED_API and Py_GIL_DISABLED. * * These affect set the following, which Python.h should use internally: * - Py_LIMITED_API (defines the subset of API we expose) * - _Py_OPAQUE_PYOBJECT (additionally hides what's ABI-incompatible between * free-threaded & GIL) * * (Don't use Py_TARGET_ABI3T directly. It's currently only used to set these * 2 macros, and defined for users' convenience.) */ #if defined(Py_LIMITED_API) && defined(Py_GIL_DISABLED) \ && !defined(Py_TARGET_ABI3T) # define Py_TARGET_ABI3T Py_LIMITED_API #endif #if defined(Py_TARGET_ABI3T) # define _Py_OPAQUE_PYOBJECT # if !defined(Py_LIMITED_API) # define Py_LIMITED_API Py_TARGET_ABI3T # elif Py_LIMITED_API > Py_TARGET_ABI3T // if both are defined, use the *lower* version, // i.e. maximum compatibility # undef Py_LIMITED_API # define Py_LIMITED_API Py_TARGET_ABI3T # endif #else # ifdef _Py_OPAQUE_PYOBJECT // _Py_OPAQUE_PYOBJECT is a private macro; do not define it directly. # error "Define Py_TARGET_ABI3T to target abi3t." # endif #endif #if defined(Py_TARGET_ABI3T) # if !defined(Py_GIL_DISABLED) // Define Py_GIL_DISABLED for users' needs. Users check this macro to see // whether they need extra synchronization. # define Py_GIL_DISABLED # endif # if defined(_Py_IS_TESTCEXT) // When compiling for abi3t, contents of Python.h should not depend // on Py_GIL_DISABLED. // We ask GCC to error if it sees the macro from this point on. // Since users are free to the macro, and there's no way to undo the // poisoning at the end of Python.h, we only do this in a test module // (test_cext). // // Clang's poisoning is stricter than GCC's: it looks in `#elif` // expressions after matching `#if`s. We disable it for now. // We also provide an undocumented, unsupported opt-out macro to help // porting to other compilers. Consider reaching out if you use it. # if defined(__GNUC__) && !defined(__clang__) && !defined(_Py_NO_GCC_POISON) # undef Py_GIL_DISABLED # pragma GCC poison Py_GIL_DISABLED # endif # endif #endif /* The internal C API must not be used with the limited C API: make sure * that Py_BUILD_CORE* macros are not defined in this case. * But, keep the "original" values, under different names, for "exports.h" */ #ifdef Py_BUILD_CORE # define _PyEXPORTS_CORE #endif #ifdef Py_BUILD_CORE_MODULE # define _PyEXPORTS_CORE_MODULE #endif #ifdef Py_LIMITED_API # undef Py_BUILD_CORE # undef Py_BUILD_CORE_BUILTIN # undef Py_BUILD_CORE_MODULE #endif #endif // _Py_PYABI_H