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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
|
// file : libbuild2/install/utility.hxx -*- C++ -*-
// license : MIT; see accompanying LICENSE file
#ifndef LIBBUILD2_INSTALL_UTILITY_HXX
#define LIBBUILD2_INSTALL_UTILITY_HXX
#include <libbuild2/types.hxx>
#include <libbuild2/utility.hxx>
#include <libbuild2/scope.hxx>
#include <libbuild2/target.hxx>
#include <libbuild2/export.hxx>
namespace build2
{
namespace install
{
// Set install path, mode for a target type.
//
// Note: should only be called if the install module is loaded.
//
inline void
install_path (scope& s, const target_type& tt, dir_path d)
{
auto r (
s.target_vars[tt]["*"].insert (
*s.var_pool ().find ("install")));
if (r.second) // Already set by the user?
r.first = path_cast<path> (move (d));
}
template <typename T>
inline void
install_path (scope& s, dir_path d)
{
return install_path (s, T::static_type, move (d));
}
inline void
install_mode (scope& s, const target_type& tt, string m)
{
auto r (
s.target_vars[tt]["*"].insert (
*s.ctx.var_pool.find ("install.mode")));
if (r.second) // Already set by the user?
r.first = move (m);
}
template <typename T>
inline void
install_mode (scope& s, string m)
{
return install_mode (s, T::static_type, move (m));
}
// Return the "installation scope". We do not install prerequisites (for
// example, shared libraries) of targets (for example, executables) that
// belong to projects outside of this scope. If it's NULL, install
// prerequisites from all projects. See also config.install.scope.
//
// Note that this should not apply to update-for-install. Failed that we
// may end up using incompatibly-built prerequisites (e.g., a library) in
// a target built for install (e.g., an executable).
//
LIBBUILD2_SYMEXPORT const scope*
install_scope (const target&);
// Resolve relative installation directory path (e.g., include/libfoo) to
// its absolute and normalized directory path (e.g., /usr/include/libfoo).
// If the resolution encountered an unknown directory, issue diagnostics
// and fail unless fail_unknown is false, in which case return empty
// directory.
//
// For rel_base semantics, see the $install.resolve() documentation. Note
// that fail_unknown does not apply to the rel_base resolution.
//
// Note: implemented in rule.cxx.
//
LIBBUILD2_SYMEXPORT dir_path
resolve_dir (const target&,
dir_path,
dir_path rel_base = {},
bool fail_unknown = true);
LIBBUILD2_SYMEXPORT dir_path
resolve_dir (const scope&,
dir_path,
dir_path rel_base = {},
bool fail_unknown = true);
// Resolve file installation path returning empty path if not installable.
//
LIBBUILD2_SYMEXPORT path
resolve_file (const file&); // rule.cxx
// Given an abolute path return its chroot'ed version, if any, accoring to
// install.chroot.
//
template <typename P>
inline P
chroot_path (const scope& rs, const P& p)
{
assert (p.absolute ());
const dir_path* d (cast_null<dir_path> (rs["install.chroot"]));
return d != nullptr ? *d / p.leaf (p.root_directory ()) : p;
}
}
}
#endif // LIBBUILD2_INSTALL_UTILITY_HXX
|