aboutsummaryrefslogtreecommitdiff
path: root/bpkg/pkg-fetch.cli
blob: 19866272bc633c3d2bec6764d33b3f15a2ba7506 (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
58
59
60
61
// file      : bpkg/pkg-fetch.cli
// copyright : Copyright (c) 2014-2019 Code Synthesis Ltd
// license   : MIT; see accompanying LICENSE file

include <bpkg/configuration.cli>;

"\section=1"
"\name=bpkg-pkg-fetch"
"\summary=fetch package archive"

namespace bpkg
{
  {
    "<options> <pkg> <ver> <file>",

    "\h|SYNOPSIS|

     \c{\b{bpkg pkg-fetch} [<options>] (<pkg>\b{/}<ver> | \b{--existing|-e} <file>)}

     \h|DESCRIPTION|

     The \cb{pkg-fetch} command fetches the archive for the specified package
     name and version from one of the archive-based repositories
     (\l{bpkg-rep-add(1)}). The resulting package state is \cb{fetched}
     (\l{bpkg-pkg-status(1)}).

     If the \cb{--replace|-r} option is specified, then \cb{pkg-fetch} will
     replace the archive of a package that is already in the \cb{fetched} or
     \cb{unpacked} state. Otherwise, \cb{pkg-fetch} expects the package to not
     exist in the configuration.

     If the \cb{--existing|-e} option is used, then instead of the name and
     version arguments, \cb{pkg-fetch} expects a local path to an existing
     package archive. In this case, \cb{bpkg} will use the archive in place,
     without copying it into the configuration directory. Also, unless the
     \cb{--purge|-p} option is specified, \cb{bpkg} will not attempt to remove
     this archive when the package is later purged with the
     \l{bpkg-pkg-purge(1)} command."
  }

  class pkg_fetch_options: configuration_options
  {
    "\h|PKG-FETCH OPTIONS|"

    bool --replace|-r
    {
      "Replace the archive if the package is already fetched or unpacked."
    }

    bool --existing|-e
    {
      "Treat the argument as an existing package archive path rather than
       the package name/version to fetch."
    }

    bool --purge|-p
    {
      "Remove the existing package archive when the package is purged."
    }
  };
}