forked from QuantStack/git2cpp
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathrevparse_subcommand.cpp
More file actions
65 lines (57 loc) · 2.16 KB
/
revparse_subcommand.cpp
File metadata and controls
65 lines (57 loc) · 2.16 KB
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
#include "revparse_subcommand.hpp"
#include "../utils/git_exception.hpp"
#include "../wrapper/repository_wrapper.hpp"
revparse_subcommand::revparse_subcommand(const libgit2_object&, CLI::App& app)
{
auto* sub = app.add_subcommand("rev-parse", "Pick out and message parameters");
auto* bare_opt = sub->add_flag("--is-bare-repository", m_is_bare_repository_flag, "When the repository is bare print \"true\", otherwise \"false\".");
auto* shallow_opt = sub->add_flag("--is-shallow-repository", m_is_shallow_repository_flag, "When the repository is shallow print \"true\", otherwise \"false\".");
auto* rev_opt = sub->add_option("<rev>", m_revisions, "Revision(s) to parse (e.g. HEAD, main, HEAD~1, dae86e, ...)");
sub->parse_complete_callback([this, sub, bare_opt, shallow_opt, rev_opt]() {
for (CLI::Option* opt : sub->parse_order())
{
if (opt == bare_opt)
{
m_queries_in_order.push_back("is_bare");
}
else if (opt == shallow_opt)
{
m_queries_in_order.push_back("is_shallow");
}
else if (opt == rev_opt)
{
m_queries_in_order.push_back("is_rev");
}
}
});
sub->callback([this]() { this->run(); });
}
void revparse_subcommand::run()
{
auto directory = get_current_git_path();
auto repo = repository_wrapper::open(directory);
size_t i = 0;
for (const auto& q : m_queries_in_order)
{
if (q == "is_bare")
{
std::cout << std::boolalpha << repo.is_bare() << std::endl;
}
else if (q == "is_shallow")
{
std::cout << std::boolalpha << repo.is_shallow() << std::endl;
}
else if (q == "is_rev")
{
const auto& rev = m_revisions[i];
auto obj = repo.revparse_single(rev.c_str());
if (!obj.has_value())
{
throw git_exception("bad revision '" + rev + "'", git2cpp_error_code::BAD_ARGUMENT);
}
auto oid = obj.value().oid();
std::cout << git_oid_tostr_s(&oid) << std::endl;
i += 1;
}
}
}