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
65
66
67
68
69
70
71
72
73
74
|
// file : libbuild2/bin/rule.hxx -*- C++ -*-
// license : MIT; see accompanying LICENSE file
#ifndef LIBBUILD2_BIN_RULE_HXX
#define LIBBUILD2_BIN_RULE_HXX
#include <libbuild2/types.hxx>
#include <libbuild2/utility.hxx>
#include <libbuild2/rule.hxx>
#include <libbuild2/bin/export.hxx>
namespace build2
{
namespace bin
{
// "Fail rule" for obj{} and [h]bmi{} that issues diagnostics if someone
// tries to build these groups directly.
//
class obj_rule: public simple_rule
{
public:
obj_rule () {}
virtual bool
match (action, target&) const override;
virtual recipe
apply (action, target&) const override;
};
// This rule picks, matches, and unmatches (if possible) a member for the
// purpose of making its metadata (for example, library's poptions, if
// it's one of the cc libraries) available.
//
// The underlying idea here is that someone else (e.g., cc::link_rule)
// makes a more informed choice and we piggy back on that decision,
// falling back to making our own based on bin.lib and bin.exe.lib. Note
// that for update this rule always returns target_state::unchanged.
//
class libul_rule: public simple_rule
{
public:
explicit
libul_rule () {}
virtual bool
match (action, target&) const override;
virtual recipe
apply (action, target&) const override;
};
// Pass-through to group members rule, similar to alias.
//
class LIBBUILD2_BIN_SYMEXPORT lib_rule: public simple_rule
{
public:
lib_rule () {}
virtual bool
match (action, target&) const override;
virtual recipe
apply (action, target&) const override;
static target_state
perform (action, const target&);
};
}
}
#endif // LIBBUILD2_BIN_RULE_HXX
|