blob: ae19d56d6f34d453c4e99cb6590f390544c2c966 (
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
57
58
59
60
61
62
63
64
|
// file : build2/cc/utility -*- C++ -*-
// copyright : Copyright (c) 2014-2016 Code Synthesis Ltd
// license : MIT; see accompanying LICENSE file
#ifndef BUILD2_CC_UTILITY
#define BUILD2_CC_UTILITY
#include <build2/types>
#include <build2/utility>
#include <build2/target>
#include <build2/bin/target>
#include <build2/cc/types>
namespace build2
{
struct variable;
namespace cc
{
// Compile/link output type.
//
otype
compile_type (target&);
otype
link_type (target&);
// Library link order.
//
// The reason we pass scope and not the target is because this function is
// called not only for exe/lib but also for obj as part of the library
// meta-information protocol implementation. Normally the bin.*.lib values
// will be project-wide. With this scheme they can be customized on the
// per-directory basis but not per-target which means all exe/lib in the
// same directory have to have the same link order.
//
lorder
link_order (scope& base, otype);
// Given the link order return the library member (liba or libs) to link.
//
target&
link_member (bin::lib&, lorder);
// Append or hash library options from a pair of *.export.* variables
// (first one is cc.export.*) recursively, prerequisite libraries first.
//
void
append_lib_options (cstrings&, target&, lorder,
const variable&,
const variable&);
void
hash_lib_options (sha256&, target&, lorder,
const variable&,
const variable&);
}
}
#include <build2/cc/utility.ixx>
#endif // BUILD2_CC_UTILITY
|