blob: 051e40f16fe4eb9c110cc8e5f2acdd40189539c0 (
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
|
#ifndef INCLUDED_SRC_BUILDTOOL_FILE_SYSTEM_GIT_CAS_HPP
#define INCLUDED_SRC_BUILDTOOL_FILE_SYSTEM_GIT_CAS_HPP
#include <filesystem>
#include <memory>
#include <optional>
#include <unordered_map>
#include <vector>
#include "src/buildtool/file_system/object_type.hpp"
extern "C" {
using git_odb = struct git_odb;
}
class GitCAS;
using GitCASPtr = std::shared_ptr<GitCAS const>;
/// \brief Git CAS that maintains its own libgit2 global state.
class GitCAS {
public:
// Stores the data for defining a single Git tree entry, which consists of
// a name (flat basename) and an object type (file/executable/tree).
struct tree_entry_t {
tree_entry_t(std::string n, ObjectType t)
: name{std::move(n)}, type{t} {}
std::string name;
ObjectType type;
[[nodiscard]] auto operator==(tree_entry_t const& other) const noexcept
-> bool {
return name == other.name and type == other.type;
}
};
// Tree entries by raw id. The same id might refer to multiple entries.
// Note that sharding by id is used as this format enables a more efficient
// internal implementation for creating trees.
using tree_entries_t =
std::unordered_map<std::string, std::vector<tree_entry_t>>;
static auto Open(std::filesystem::path const& repo_path) noexcept
-> GitCASPtr;
GitCAS() noexcept;
~GitCAS() noexcept;
// prohibit moves and copies
GitCAS(GitCAS const&) = delete;
GitCAS(GitCAS&& other) = delete;
auto operator=(GitCAS const&) = delete;
auto operator=(GitCAS&& other) = delete;
/// \brief Read object from CAS.
/// \param id The object id.
/// \param is_hex_id Specify whether `id` is hex string or raw.
[[nodiscard]] auto ReadObject(std::string const& id,
bool is_hex_id = false) const noexcept
-> std::optional<std::string>;
/// \brief Read object header from CAS.
/// \param id The object id.
/// \param is_hex_id Specify whether `id` is hex string or raw.
// Use with care. Quote from git2/odb.h:138:
// Note that most backends do not support reading only the header of an
// object, so the whole object will be read and then the header will be
// returned.
[[nodiscard]] auto ReadHeader(std::string const& id,
bool is_hex_id = false) const noexcept
-> std::optional<std::pair<std::size_t, ObjectType>>;
/// \brief Read entries from tree in CAS.
/// Reading a tree must be backed by an object database. Therefore, a valid
/// instance of this class is required.
/// \param id The object id.
/// \param is_hex_id Specify whether `id` is hex string or raw.
[[nodiscard]] auto ReadTree(std::string const& id,
bool is_hex_id = false) const noexcept
-> std::optional<tree_entries_t>;
private:
git_odb* odb_{nullptr};
bool initialized_{false};
[[nodiscard]] auto OpenODB(std::filesystem::path const& repo_path) noexcept
-> bool;
};
#endif // INCLUDED_SRC_BUILDTOOL_FILE_SYSTEM_GIT_CAS_HPP
|