diff options
author | Klaus Aehlig <klaus.aehlig@huawei.com> | 2024-07-16 11:19:51 +0200 |
---|---|---|
committer | Klaus Aehlig <klaus.aehlig@huawei.com> | 2024-07-19 15:50:15 +0200 |
commit | 7e6330e7c2ecdee4cc7edf137b9e4616c55a57b1 (patch) | |
tree | d0c019513a10abbb792323f3d1724f23476e1a8f /src | |
parent | ff8ecea73904cf6348fee13e83814809f55e26f5 (diff) | |
download | justbuild-7e6330e7c2ecdee4cc7edf137b9e4616c55a57b1.tar.gz |
Storage config: change layout to support several storage generations
Diffstat (limited to 'src')
-rw-r--r-- | src/buildtool/storage/config.hpp | 22 | ||||
-rw-r--r-- | src/buildtool/storage/fs_utils.cpp | 32 | ||||
-rw-r--r-- | src/buildtool/storage/fs_utils.hpp | 21 |
3 files changed, 55 insertions, 20 deletions
diff --git a/src/buildtool/storage/config.hpp b/src/buildtool/storage/config.hpp index 39bb74ac..4bc8911c 100644 --- a/src/buildtool/storage/config.hpp +++ b/src/buildtool/storage/config.hpp @@ -72,9 +72,29 @@ struct StorageConfig final { return build_root / "protocol-dependent"; } + /// \brief Root directory of all repository generations. + [[nodiscard]] auto RepositoryRoot() const noexcept + -> std::filesystem::path { + return build_root / "repositories"; + } + + /// \brief Directory for the given generation of stored repositories + [[nodiscard]] auto RepositoryGenerationRoot( + std::size_t index) const noexcept -> std::filesystem::path { + ExpectsAudit(index < num_generations); + auto generation = std::string{"generation-"} + std::to_string(index); + return RepositoryRoot() / generation; + } + + /// \brief Directory for the git repository of the given generation + [[nodiscard]] auto GitGenerationRoot(std::size_t index) const noexcept + -> std::filesystem::path { + return RepositoryGenerationRoot(index) / "git"; + } + /// \brief Directory for the git repository storing various roots [[nodiscard]] auto GitRoot() const noexcept -> std::filesystem::path { - return build_root / "git"; + return GitGenerationRoot(0); } /// \brief Root directory of specific storage generation diff --git a/src/buildtool/storage/fs_utils.cpp b/src/buildtool/storage/fs_utils.cpp index 3286c4ec..03ef75c6 100644 --- a/src/buildtool/storage/fs_utils.cpp +++ b/src/buildtool/storage/fs_utils.cpp @@ -52,22 +52,27 @@ auto GetGitRoot(StorageConfig const& storage_config, } auto GetCommitTreeIDFile(StorageConfig const& storage_config, - std::string const& commit) noexcept + std::string const& commit, + std::size_t generation) noexcept -> std::filesystem::path { - return storage_config.build_root / "commit-tree-map" / commit; + return storage_config.RepositoryGenerationRoot(generation) / + "commit-tree-map" / commit; } auto GetArchiveTreeIDFile(StorageConfig const& storage_config, std::string const& repo_type, - std::string const& content) noexcept + std::string const& content, + std::size_t generation) noexcept -> std::filesystem::path { - return storage_config.build_root / "tree-map" / repo_type / content; + return storage_config.RepositoryGenerationRoot(generation) / "tree-map" / + repo_type / content; } auto GetForeignFileTreeIDFile(StorageConfig const& storage_config, std::string const& content, std::string const& name, - bool executable) noexcept + bool executable, + std::size_t generation) noexcept -> std::filesystem::path { return GetDistdirTreeIDFile( storage_config, @@ -76,21 +81,26 @@ auto GetForeignFileTreeIDFile(StorageConfig const& storage_config, std::unordered_map<std::string, std::pair<std::string, bool>>{ {name, {content, executable}}}) .dump()) - .HexString()); + .HexString(), + generation); } auto GetDistdirTreeIDFile(StorageConfig const& storage_config, - std::string const& content) noexcept + std::string const& content, + std::size_t generation) noexcept -> std::filesystem::path { - return storage_config.build_root / "distfiles-tree-map" / content; + return storage_config.RepositoryGenerationRoot(generation) / + "distfiles-tree-map" / content; } auto GetResolvedTreeIDFile(StorageConfig const& storage_config, std::string const& tree_hash, - PragmaSpecial const& pragma_special) noexcept + PragmaSpecial const& pragma_special, + std::size_t generation) noexcept -> std::filesystem::path { - return storage_config.build_root / "special-tree-map" / - kPragmaSpecialInverseMap.at(pragma_special) / tree_hash; + return storage_config.RepositoryGenerationRoot(generation) / + "special-tree-map" / kPragmaSpecialInverseMap.at(pragma_special) / + tree_hash; } auto WriteTreeIDFile(std::filesystem::path const& tree_id_file, diff --git a/src/buildtool/storage/fs_utils.hpp b/src/buildtool/storage/fs_utils.hpp index bd4852a9..7482457b 100644 --- a/src/buildtool/storage/fs_utils.hpp +++ b/src/buildtool/storage/fs_utils.hpp @@ -38,14 +38,16 @@ namespace StorageUtils { /// \brief Get the path to the file storing the tree id associated with /// a given commit. [[nodiscard]] auto GetCommitTreeIDFile(StorageConfig const& storage_config, - std::string const& commit) noexcept + std::string const& commit, + std::size_t generation = 0) noexcept -> std::filesystem::path; /// \brief Get the path to the file storing the tree id of an archive /// content. [[nodiscard]] auto GetArchiveTreeIDFile(StorageConfig const& storage_config, std::string const& repo_type, - std::string const& content) noexcept + std::string const& content, + std::size_t generation = 0) noexcept -> std::filesystem::path; /// \brief Get the path to the file storing the tree id of an archive @@ -53,20 +55,23 @@ namespace StorageUtils { [[nodiscard]] auto GetForeignFileTreeIDFile(StorageConfig const& storage_config, std::string const& content, std::string const& name, - bool executable) noexcept + bool executable, + std::size_t generation = 0) noexcept -> std::filesystem::path; /// \brief Get the path to the file storing the tree id of a distdir list /// content. [[nodiscard]] auto GetDistdirTreeIDFile(StorageConfig const& storage_config, - std::string const& content) noexcept + std::string const& content, + std::size_t generation = 0) noexcept -> std::filesystem::path; /// \brief Get the path to the file storing a resolved tree hash. -[[nodiscard]] auto GetResolvedTreeIDFile( - StorageConfig const& storage_config, - std::string const& tree_hash, - PragmaSpecial const& pragma_special) noexcept -> std::filesystem::path; +[[nodiscard]] auto GetResolvedTreeIDFile(StorageConfig const& storage_config, + std::string const& tree_hash, + PragmaSpecial const& pragma_special, + std::size_t generation = 0) noexcept + -> std::filesystem::path; /// \brief Write a tree id to file. The parent folder of the file must exist! [[nodiscard]] auto WriteTreeIDFile(std::filesystem::path const& tree_id_file, |