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
|
// file : bdep/git.hxx -*- C++ -*-
// copyright : Copyright (c) 2014-2018 Code Synthesis Ltd
// license : MIT; see accompanying LICENSE file
#ifndef BDEP_GIT_HXX
#define BDEP_GIT_HXX
#include <libbutl/git.mxx>
#include <bdep/types.hxx>
#include <bdep/utility.hxx>
namespace bdep
{
using butl::git_repository;
// All functions that start git process take the minimum supported git
// version as an argument.
//
// Start git process.
//
template <typename I, typename O, typename E, typename... A>
process
start_git (const semantic_version&, I&& in, O&& out, E&& err, A&&... args);
template <typename I, typename O, typename E, typename... A>
process
start_git (const semantic_version&,
const dir_path& repo,
I&& in, O&& out, E&& err,
A&&... args);
// Wait for git process to terminate.
//
void
finish_git (process& pr, bool io_read = false);
// Run git process.
//
template <typename... A>
void
run_git (const semantic_version&, const dir_path& repo, A&&... args);
// Return the first line of the git output. If ignore_error is true, then
// suppress stderr, ignore (normal) error exit status, and return nullopt.
//
template <typename... A>
optional<string>
git_line (const semantic_version&, bool ignore_error, A&&... args);
template <typename... A>
optional<string>
git_line (const semantic_version&,
const dir_path& repo,
bool ignore_error,
A&&... args);
// Similar to the above but takes the already started git process with a
// redirected output pipe.
//
optional<string>
git_line (process&& pr, fdpipe&& pipe, bool ignore_error);
// Try to derive a remote HTTPS repository URL from the optionally specified
// custom git config value falling back to remote.origin.build2Url and then
// remote.origin.url. Issue diagnostics (including a suggestion to use
// option opt, if specified) and fail if unable to.
//
url
git_remote_url (const dir_path& repo,
const char* opt = nullptr,
const char* what = "remote repository URL",
const char* cfg = nullptr);
}
#include <bdep/git.ixx>
#include <bdep/git.txx>
#endif // BDEP_GIT_HXX
|