blob: 030b192e49041343e449f7e31183a3f072ba1dc7 (
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
62
63
64
|
// file : bpkg/rep-fetch.hxx -*- C++ -*-
// copyright : Copyright (c) 2014-2017 Code Synthesis Ltd
// license : MIT; see accompanying LICENSE file
#ifndef BPKG_REP_FETCH_HXX
#define BPKG_REP_FETCH_HXX
#include <libbpkg/manifest.hxx>
#include <bpkg/types.hxx>
#include <bpkg/forward.hxx> // database
#include <bpkg/utility.hxx>
#include <bpkg/rep-fetch-options.hxx>
namespace bpkg
{
int
rep_fetch (const rep_fetch_options&, cli::scanner& args);
// Fetch and authenticate repositories and packages manifests.
//
// If conf is NULL, then assume not running in a bpkg configuration. If it
// is empty, then check if the bpkg configuration exists in the current
// working directory.
//
class certificate;
struct rep_fetch_data
{
using repository = repository_manifest;
struct package
{
package_manifest manifest;
string repository_fragment; // See package_location::fragment.
};
std::vector<repository> repositories;
std::vector<package> packages;
// For base repo (can be NULL).
//
shared_ptr<const bpkg::certificate> certificate;
};
rep_fetch_data
rep_fetch (const common_options&,
const dir_path* conf,
const repository_location&,
bool ignore_unknown);
// Add (or update) repository locations to the configuration and fetch
// them. On failure clean up the configuration (see rep_remove_clean() for
// details). Note that it should be called in session.
//
void
rep_fetch (const common_options&,
const dir_path& conf,
database&,
const vector<repository_location>&);
}
#endif // BPKG_REP_FETCH_HXX
|