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 : build/algorithm.ixx -*- C++ -*-
// copyright : Copyright (c) 2014-2015 Code Synthesis Ltd
// license : MIT; see accompanying LICENSE file
#include <build/prerequisite>
#include <build/context>
namespace build
{
inline target&
search (prerequisite& p)
{
if (p.target == nullptr)
p.target = &search (p.key ());
return *p.target;
}
inline target&
search (const target_type& type,
const dir_path& dir,
const std::string& name,
const std::string* ext,
scope* scope)
{
return search (prerequisite_key {{&type, &dir, &name, &ext}, scope});
}
template <typename T>
inline T&
search (const dir_path& dir,
const std::string& name,
const std::string* ext,
scope* scope)
{
return static_cast<T&> (search (T::static_type, dir, name, ext, scope));
}
void
match_impl (action, target&);
inline void
match (action a, target& t)
{
if (!t.recipe (a))
match_impl (a, t);
t.dependents++;
}
target_state
execute_impl (action, target&);
inline target_state
execute (action a, target& t)
{
t.dependents--;
switch (t.state)
{
case target_state::unchanged:
case target_state::changed: return t.state;
default:
{
// Handle the "last" execution mode.
//
if (current_mode == execution_mode::last && t.dependents != 0)
return (t.state = target_state::postponed);
return execute_impl (a, t);
}
}
}
}
|