summaryrefslogtreecommitdiff
path: root/src/buildtool/file_system/git_repo.cpp
diff options
context:
space:
mode:
authorMaksim Denisov <denisov.maksim@huawei.com>2024-11-27 17:36:43 +0100
committerKlaus Aehlig <klaus.aehlig@huawei.com>2024-12-03 11:28:48 +0100
commit2e94df845a434f19f634d6605061428512c2302f (patch)
treec7917787bc64182cfa5d4e8d5b009c6faec36901 /src/buildtool/file_system/git_repo.cpp
parent617bde473a2d2cb394a20f3899f21ddfaafdae8b (diff)
downloadjustbuild-2e94df845a434f19f634d6605061428512c2302f.tar.gz
Ensure gitstrarray gets created with alive pointers.
(cherry-picked from 9dc61e9faca5e8b05a1a2a2eed83a5468aeb6202)
Diffstat (limited to 'src/buildtool/file_system/git_repo.cpp')
-rw-r--r--src/buildtool/file_system/git_repo.cpp15
1 files changed, 15 insertions, 0 deletions
diff --git a/src/buildtool/file_system/git_repo.cpp b/src/buildtool/file_system/git_repo.cpp
index 176535b3..20144439 100644
--- a/src/buildtool/file_system/git_repo.cpp
+++ b/src/buildtool/file_system/git_repo.cpp
@@ -2097,6 +2097,21 @@ auto GitRepo::CreateTreeFromDirectory(std::filesystem::path const& dir,
#endif // BOOTSTRAP_BUILD_TOOL
}
+void GitRepo::GitStrArray::AddEntry(std::string entry) {
+ std::size_t const prev_capacity = entries_.capacity();
+ entries_.emplace_back(std::move(entry));
+ if (prev_capacity == entries_.capacity()) {
+ entry_pointers_.push_back(entries_.back().data());
+ }
+ else {
+ // update pointers if reallocation happened
+ entry_pointers_.resize(entries_.size());
+ for (std::size_t i = 0; i < entries_.size(); ++i) {
+ entry_pointers_[i] = entries_[i].data();
+ }
+ }
+}
+
auto GitRepo::GitStrArray::Get() & noexcept -> git_strarray {
return git_strarray{.strings = entry_pointers_.data(),
.count = entry_pointers_.size()};