• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1[/
2    Boost.Config
3
4    Copyright (c) 2001 Beman Dawes
5    Copyright (c) 2001 Vesa Karvonen
6    Copyright (c) 2001 John Maddock
7
8    Distributed under the Boost Software License, Version 1.0.
9    (See accompanying file LICENSE_1_0.txt or copy at
10    http://www.boost.org/LICENSE_1_0.txt)
11]
12
13[section:build_config Build Time Configuration]
14
15There are times when you want to control whether a build target gets built or not, based
16on what features the compiler supports.  For example, suppose you have a test file
17"test_constexpr_128.cpp" which requires three key features in order to build:
18
19* The `constexpr` keyword as detected by BOOST_NO_CXX11_CONSTEXPR.
20* User defined literals, as detected by BOOST_NO_CXX11_USER_DEFINED_LITERALS.
21* The `__int128` data type, as detected by BOOST_HAS_INT128.
22
23Clearly we know that if these features are not supported by the compiler, then
24there's simply no point in even trying to build the test program.  The main advantages being:
25
26* Faster compile times - build configuration uses lightweight tests the results of which are also cached.
27* Less noise in build output - there's no reason to be faced with pages of template
28instantiation backtrace if we know the file can never compile anyway.
29* Less noise in the online test results - the test will show up as blank, rather than as a fail
30in the online test matrix.
31* A better experience for end users building all of Boost, if those libraries which can not be built
32for the current target compiler are simply skipped, rather than generating pages of error output.
33
34Returning to our example, the test case is probably executed in it's Jamfile via the "run" rule:
35
36   run test_constexpr_128.cpp ;
37
38We now need to make this target conditional on the necessary features.
39We can do that by first importing the necessary rule at the start of the Jamfile:
40
41   import path-to-config-lib/checks/config : requires ;
42
43Assuming that the test case is in the usual directory:
44
45   libs/yourlib/test
46
47then the import rule will actually be:
48
49   import ../../config/checks/config : requires ;
50
51Then add a "requires" rule invocation to the requirements section of the target:
52
53   run test_constexpr_128.cpp
54      : : : #requirements:
55      [ requires cxx11_constexpr cxx11_user_defined_literals int128 ] ;
56
57Notice that multiple arguments can be added to the requires rule, and that these are
58always the same as the Boost.Config macro name, but in lower case and with the ['boost_no_]
59or ['boost_has_] prefix removed.  You can also use any C++ standard feature-macro name
60with the leading underscores removed (see more below).
61
62When building the above example, you will see at the start of the build process the results
63of the configuration, for example GCC in C++11 mode gives:
64
65    - Boost.Config Feature Check: int128 : yes
66    - Boost.Config Feature Check: cxx11_constexpr : yes
67    - Boost.Config Feature Check: cxx11_user_defined_literals : yes
68
69If you wish to make a build conditional on a C++ standard feature macro then you can specify
70these too, just remove the leading underscores from the name.  For example:
71
72   [ requires cpp_constexpr ]
73
74To require C++11 style const-expressions.  If you want to specify a macro from a particular
75standard, then you append an underscore followed by the (2 digit) year of the standard, for example:
76
77   [ requires cpp_constexpr_17 ]
78
79For C++17 constepxr.  If you don't specify a standard then you get the first version that
80introduced the macro.  In addition there are only standard-specific rules for each version
81bump of the macro, so:
82
83   [ requires cpp_if_constexpr_17 ]
84
85Is fine since the macro was introduced in C++17 and is the same as the un-versioned name, but:
86
87   [ requires cpp_if_constexpr_20 ]
88
89Will result in a build error since there is no C++20 version bump for `__cpp_if_constexpr`.
90
91That's all there is to this handy feature, should at any time you be unsure of the feature-test
92names you can pass to the "requires" rule, then search for the Boost.Config macro of interest in
93libs/config/checks/Jamfiles.v2, and the name of the feature check will follow it.
94
95And finally, this feature is built around the Boost.Build built in rule ['check-target-builds]
96which can be used to perform more generalized build-time feature testing.  The checks in this
97library are provided as a convenient shorthand without the need for you to write the test cases yourself.
98
99[endsect]
100