cpython/Include/patchlevel.h

38 lines
1.2 KiB
C
Raw Normal View History

/* Newfangled version identification scheme.
This scheme was added in Python 1.5.2b2; before that time, only PATCHLEVEL
was available. To test for presence of the scheme, test for
defined(PY_MAJOR_VERSION).
When the major or minor version changes, the VERSION variable in
configure.in must also be changed.
There is also (independent) API version information in modsupport.h.
*/
/* Values for PY_RELEASE_LEVEL */
#define PY_RELEASE_LEVEL_ALPHA 0xA
#define PY_RELEASE_LEVEL_BETA 0xB
#define PY_RELEASE_LEVEL_GAMMA 0xC
#define PY_RELEASE_LEVEL_FINAL 0xF /* Serial should be 0 here */
1999-04-13 14:47:26 +00:00
/* Higher for patch releases */
/* Version parsed out into numeric values */
2000-06-29 22:29:24 +00:00
#define PY_MAJOR_VERSION 2
2003-07-30 05:37:39 +00:00
#define PY_MINOR_VERSION 4
#define PY_MICRO_VERSION 0
2003-07-30 05:37:39 +00:00
#define PY_RELEASE_LEVEL PY_RELEASE_LEVEL_ALPHA
2004-07-08 03:59:33 +00:00
#define PY_RELEASE_SERIAL 1
/* Version as a string */
2004-07-09 07:19:21 +00:00
#define PY_VERSION "2.4a1+"
/* Version as a single 4-byte hex number, e.g. 0x010502B2 == 1.5.2b2.
Use this for numeric comparisons, e.g. #if PY_VERSION_HEX >= ... */
#define PY_VERSION_HEX ((PY_MAJOR_VERSION << 24) | \
(PY_MINOR_VERSION << 16) | \
(PY_MICRO_VERSION << 8) | \
(PY_RELEASE_LEVEL << 4) | \
(PY_RELEASE_SERIAL << 0))