API e Versionamento de ABI¶
Constantes de versão de tempo de construção¶
O CPython expõe seu número de versão nas seguintes macros. Note que estes correspondem ao código da versão com a qual está construída. Veja Py_Version
para a versão usada em tempo de execução.
Veja Estabilidade da API C para uma discussão da estabilidade da API e ABI através das versões.
-
PY_MAJOR_VERSION¶
O
3
em3.4.1a2
.
-
PY_MINOR_VERSION¶
O
4
em3.4.1a2
.
-
PY_MICRO_VERSION¶
O
1
em3.4.1a2
.
-
PY_RELEASE_LEVEL¶
O
a
em3.4.1a2
. Isto pode ser0xA
para alfa,0xB
para beta,0xC
para o candidato a lançamento ou0xF
para final.
-
PY_RELEASE_SERIAL¶
O
2
em3.4.1a2
. Zero para os lançamentos finais.
-
PY_VERSION_HEX¶
O número da versão do Python codificado em um único inteiro. Consulte
Py_PACK_FULL_VERSION()
para obter detalhes sobre a codificação.Use isso para comparações numéricas como, por exemplo,
#if PY_VERSION_HEX >= ...
.
Versão de tempo de execução¶
-
const unsigned long Py_Version¶
- Parte da ABI Estável desde a versão 3.11.
O número da versão do tempo de execução do Python codificado em um único inteiro constante. Consulte
Py_PACK_FULL_VERSION()
para obter detalhes sobre a codificação. Contém a versão do Python usada em tempo de execução.Use isso para comparações numéricas como, por exemplo,
if (Py_Version >= ...)
.Adicionado na versão 3.11.
Macros de empacotamento de bits¶
-
uint32_t Py_PACK_FULL_VERSION(int major, int minor, int micro, int release_level, int release_serial)¶
- Parte da ABI Estável desde a versão 3.14.
Retorna a versão fornecida, codificada como um único inteiro de 32 bits com a seguinte estrutura:
Argumento
Nº de bits
Máscara de bits
Deslocamento de bits
Exemplo de valores
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
Por exemplo:
Versão
Argumentos de
Py_PACK_FULL_VERSION
Versão codificada
3.4.1a2
(3, 4, 1, 0xA, 2)
0x030401a2
3.10.0
(3, 10, 0, 0xF, 0)
0x030a00f0
Bits fora do intervalo nos argumentos são ignorados. Ou seja, a macro pode ser definida como:
#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
é principalmente uma macro, destinada ao uso em diretivas#if
, mas também está disponível como uma função exportada.Adicionado na versão 3.14.
-
uint32_t Py_PACK_VERSION(int major, int minor)¶
- Parte da ABI Estável desde a versão 3.14.
Equivalente a
Py_PACK_FULL_VERSION(major, minor, 0, 0, 0)
. O resultado não corresponde a nenhuma versão do Python, mas é útil em comparações numéricas.Adicionado na versão 3.14.