patchlevel.h 1.19 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16

/* 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
17
#define PY_RELEASE_LEVEL_GAMMA	0xC
18
#define PY_RELEASE_LEVEL_FINAL	0xF	/* Serial should be 0 here */
19
					/* Higher for patch releases */
20 21

/* Version parsed out into numeric values */
22
#define PY_MAJOR_VERSION	2
23
#define PY_MINOR_VERSION	3
24
#define PY_MICRO_VERSION	0
25
#define PY_RELEASE_LEVEL	PY_RELEASE_LEVEL_ALPHA
26
#define PY_RELEASE_SERIAL	1
27 28

/* Version as a string */
29
#define PY_VERSION		"2.3a0"
30 31 32 33 34 35 36 37

/* 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))