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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
|
// file : bdep/init.cli
// copyright : Copyright (c) 2014-2017 Code Synthesis Ltd
// license : MIT; see accompanying LICENSE file
include <bdep/project.cli>;
"\section=1"
"\name=bdep-init"
"\summary=initialize project in build configurations"
namespace bdep
{
{
"<options>
<prj-spec> <prj-dir>
<pkg-spec> <pkg-dir>
<cfg-spec> <cfg-name> <cfg-dir>
<cfg-args> <option> <module> <cfg-var>
<pkg-args> <pkg>",
"\h|SYNOPSIS|
\c{\b{bdep init} [<options>] [<pkg-spec>] [<cfg-spec>] [<pkg-args>]\n
\b{bdep init} [<options>] [<prj-spec>] \b{--empty|-E}\n
\b{bdep init} [<options>] [<pkg-spec>] \b{--config-add|-A} <cfg-dir> [\b{@}<cfg-name>]\n
\b{bdep init} [<options>] [<pkg-spec>] \b{--config-create|-C} <cfg-dir> [\b{@}<cfg-name>]\n
\ \ \ \ \ \ \ \ \ \ [<cfg-args>]}
\c{<cfg-spec> = (\b{@}<cfg-name> | \b{--config}|\b{-c} <cfg-dir>)... | \b{--all}|\b{-a}\n
<pkg-spec> = (\b{--directory}|\b{-d} <pkg-dir>)... | <prj-spec>\n
<prj-spec> = \b{--directory}|\b{-d} <prj-dir>\n
<pkg-args> = (<pkg> | <cfg-var>)...\n
<cfg-args> = (<option> | <module> | <cfg-var>)...}
\h|DESCRIPTION|
The \cb{init} command initializes a project in one or more build
configurations. The first form initializes the specified project packages
(<pkg-spec>), or, if the project itself is specified (<prj-spec>), all
its available packages, in one or more build configurations (<cfg-spec>)
that have already been associated with the project (\l{bdep-config(1)}).
If no project directory is specified, then the current working directory
is assumed. If no configuration is specified, then the default
configuration is assumed. See \l{bdep-projects-configs(1)} for details on
specifying projects and configurations. Optional <pkg-args> are the
additional arguments to the underlying \l{bpkg-pkg-build(1)} command.
The second form (\cb{--empty} is specified) initializes an empty project
database that can later be used to first add build configurations
(\l{bdep-config(1)}) and then initialize project packages using the first
form.
The third (\cb{--config-add}) and fourth (\cb{--config-create}) forms are
shortcuts to first adding an existing or newly created build
configuration and then initializing project packages in that
configuration. Semantically they are equivalent to first performing the
\cb{config add} or \cb{config create} commands (\l{bdep-config(1)}),
respectively, followed by the first form. Optional <cfg-args> in the
fourth form are the additional arguments to the underlying
\l{bpkg-cfg-create(1)} command.
\h|EXAMPLES|
As an example, consider project \cb{prj} with two packages, \cb{foo}
and \cb{libfoo}:
\
prj/
├── foo/
└── libfoo/
\
The following invocations illustrate the common \cb{init} use cases (the
current working directory is shown before the shell prompt).
Create new build configuration in \cb{../prj-gcc}, call it \cb{gcc}, and
initialize project packages \cb{foo} and \cb{libfoo} in this
configuration:
\
prj/$ bdep init -C ../prj-gcc @gcc cc config.cxx=g++
\
Create new build configuration in \cb{../prj-clang} using
\l{bpkg-cfg-create(1)}. Then add it calling it \cb{clang} and initialize
project package \cb{foo} in this configuration:
\
prj/$ bpkg create -d ../prj-clang cc config.cxx=clang++
prj/$ cd foo
foo/$ bdep init -A ../../prj-clang @clang
\
Initialize project package \cb{libfoo} in the build configuration
\cb{clang}:
\
foo/$ cd ..
prj/$ bdep init -d libfoo @clang
\
The following set of invocations achieves the same end result but using
the \l{bdep-config(1)} command to manage configuration.
Initialize an empty project database:
\
prj/$ bdep init --empty
\
Create new build configuration in \cb{../prj-gcc}, call it \cb{gcc}:
\
prj/$ bdep config create ../prj-gcc @gcc cc config.cxx=g++
\
Add existing build configuration in \cb{../prj-clang}, call it
\cb{clang}.
\
prj/$ bdep config add ../prj-clang @clang
\
Initialize project packages \cb{foo} and \cb{libfoo} in build
configurations \cb{gcc} and \cb{clang}.
\
prj/$ bdep init @gcc @clang
\
Or, alternatively, in all the build configurations:
\
prj/$ bdep init -a
\
"
}
class cmd_init_options: configuration_add_options, project_options
{
"\h|INIT OPTIONS|"
bool --empty|-E
{
"Initialize an empty build configuration set."
}
dir_path --config-add|-A
{
"<dir>",
"Add an existing build configuration <dir>."
}
dir_path --config-create|-C
{
"<dir>",
"Create a new build configuration in <dir>."
}
};
}
|