| 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 | |