• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2 Copyright Rene Rivera 2005-2016
3 Distributed under the Boost Software License, Version 1.0.
4 (See accompanying file LICENSE_1_0.txt or copy at
5 http://www.boost.org/LICENSE_1_0.txt)
6 */
7 
8 #ifndef BOOST_PREDEF_VERSION_NUMBER_H
9 #define BOOST_PREDEF_VERSION_NUMBER_H
10 
11 /* tag::reference[]
12 = `BOOST_VERSION_NUMBER`
13 
14 [source]
15 ----
16 BOOST_VERSION_NUMBER(major,minor,patch)
17 ----
18 
19 Defines standard version numbers, with these properties:
20 
21 * Decimal base whole numbers in the range [0,1000000000).
22   The number range is designed to allow for a (2,2,5) triplet.
23   Which fits within a 32 bit value.
24 * The `major` number can be in the [0,99] range.
25 * The `minor` number can be in the [0,99] range.
26 * The `patch` number can be in the [0,99999] range.
27 * Values can be specified in any base. As the defined value
28   is an constant expression.
29 * Value can be directly used in both preprocessor and compiler
30   expressions for comparison to other similarly defined values.
31 * The implementation enforces the individual ranges for the
32   major, minor, and patch numbers. And values over the ranges
33   are truncated (modulo).
34 
35 */ // end::reference[]
36 #define BOOST_VERSION_NUMBER(major,minor,patch) \
37     ( (((major)%100)*10000000) + (((minor)%100)*100000) + ((patch)%100000) )
38 
39 #define BOOST_VERSION_NUMBER_MAX \
40     BOOST_VERSION_NUMBER(99,99,99999)
41 
42 #define BOOST_VERSION_NUMBER_ZERO \
43     BOOST_VERSION_NUMBER(0,0,0)
44 
45 #define BOOST_VERSION_NUMBER_MIN \
46     BOOST_VERSION_NUMBER(0,0,1)
47 
48 #define BOOST_VERSION_NUMBER_AVAILABLE \
49     BOOST_VERSION_NUMBER_MIN
50 
51 #define BOOST_VERSION_NUMBER_NOT_AVAILABLE \
52     BOOST_VERSION_NUMBER_ZERO
53 
54 /* tag::reference[]
55 [source]
56 ----
57 BOOST_VERSION_NUMBER_MAJOR(N), BOOST_VERSION_NUMBER_MINOR(N), BOOST_VERSION_NUMBER_PATCH(N)
58 ----
59 
60 The macros extract the major, minor, and patch portion from a well formed
61 version number resulting in a preprocessor expression in the range of
62 [0,99] or [0,99999] for the major and minor, or patch numbers
63 respectively.
64 */ // end::reference[]
65 #define BOOST_VERSION_NUMBER_MAJOR(N) \
66     ( ((N)/10000000)%100 )
67 
68 #define BOOST_VERSION_NUMBER_MINOR(N) \
69     ( ((N)/100000)%100 )
70 
71 #define BOOST_VERSION_NUMBER_PATCH(N) \
72     ( (N)%100000 )
73 
74 #endif
75