aboutsummaryrefslogtreecommitdiff
path: root/bpkg/cfg-create.cli
blob: 510f4771a08781fc8405ffb134fe9805aeac60bd (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
// file      : bpkg/cfg-create.cli
// copyright : Copyright (c) 2014-2016 Code Synthesis Ltd
// license   : MIT; see accompanying LICENSE file

include <bpkg/common.cli>;

"\section=1"
"\name=bpkg-cfg-create"
"\summary=create configuration"

namespace bpkg
{
  {
    "<options> <module> <conf-var>",

    "\h|SYNOPSIS|

     \c{\b{bpkg cfg-create}|\b{create} [<options>] [(<module> | <conf-var>)...]}

     \h|DESCRIPTION|

     The \cb{cfg-create} command creates a new \cb{bpkg} configuration with
     the specified \cb{build2} modules and configuration variables. Unless
     the \cb{--wipe} option is specified, \cb{cfg-create} expects the
     configuration directory to be empty or to not exist (in which case it
     will be created).

     By default, the resulting configuration loads the \cb{config}, \cb{test},
     and \cb{install} modules. However, additional modules and, if required,
     their configuration variables can be specified as the \cb{cfg-create}
     arguments. For example:

     \
     bpkg create cxx config.cxx=clang++ config.install.root=/usr/local
     \
     "
  }

  class cfg_create_options: common_options
  {
    "\h|CFG-CREATE OPTIONS|"

    dir_path --directory|-d (".")
    {
      "<dir>",
      "Create the configuration in <dir> rather than in the current working
       directory."
    }

    bool --wipe
    {
      "Wipe the configuration directory clean before creating the new
       configuration. For safety, this option requires that you specify the
       configuration directory explicitly with \cb{--directory|-d}."
    }
  };
}