blob: aea8d03078d4e7b155dd913c5c39e8584350c22a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
# file : build/root.build
# license : GNU GPL v3; see accompanying LICENSE file
cxx.std = latest
using cxx
hxx{*}: extension = hxx
ixx{*}: extension = ixx
txx{*}: extension = txx
cxx{*}: extension = cxx
if ($cxx.target.system == 'win32-msvc')
cxx.poptions += -D_CRT_SECURE_NO_WARNINGS -D_SCL_SECURE_NO_WARNINGS
if ($cxx.class == 'msvc')
cxx.coptions += /wd4251 /wd4275 /wd4800
cxx.poptions =+ "-I$out_root" "-I$src_root"
# Specify the test target for cross-testing.
#
test.target = $cxx.target
# Omit the rest during the skeleton load.
#
if ($build.mode != 'skeleton')
{
if ($cxx.id != 'gcc')
fail 'ODB compiler can only be built with GCC'
# Determine the GCC plugin directory.
#
# If plugin support is disabled, then -print-file-name will print the name
# we have passed (the real plugin directory will always be absolute).
#
# It can also include '..' components (e.g., on Windows) so normalize it for
# good measure.
#
plugin_dir = [dir_path] $process.run($cxx.path -print-file-name=plugin)
if ("$plugin_dir" == plugin)
fail "$recall($cxx.path) does not support plugins"
plugin_dir = $normalize($plugin_dir)
config [config.report] plugin_dir
# Load the cli module but only if it's available. This way a distribution
# that includes pre-generated files can be built without installing cli.
# This is also the reason why we need to explicitly spell out individual
# source file prerequisites instead of using the cli.cxx{} group (it won't
# be there unless the module is configured).
#
using? cli
}
|