diff options
| author | jacqueline <me@jacqueline.id.au> | 2023-11-21 13:49:47 +1100 |
|---|---|---|
| committer | jacqueline <me@jacqueline.id.au> | 2023-11-21 13:49:47 +1100 |
| commit | d70ec9bf447f7a46e347c3bc5ad58fd88aff46a2 (patch) | |
| tree | ab75c1663934d7408fad36d134a0cfd4f4cb089b /src/database/database.cpp | |
| parent | f34b6405884c4073158c3f36158c6351fa135a0f (diff) | |
| download | tangara-fw-d70ec9bf447f7a46e347c3bc5ad58fd88aff46a2.tar.gz | |
Add lua functions to get database content
Diffstat (limited to 'src/database/database.cpp')
| -rw-r--r-- | src/database/database.cpp | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/src/database/database.cpp b/src/database/database.cpp index 142735d8..0967eb95 100644 --- a/src/database/database.cpp +++ b/src/database/database.cpp @@ -857,4 +857,48 @@ auto IndexRecord::Expand(std::size_t page_size) const }; } +Iterator::Iterator(std::weak_ptr<Database> db, const IndexInfo& idx) + : db_(db), prev_pos_(), current_pos_() { + std::string prefix = EncodeIndexPrefix( + IndexKey::Header{.id = idx.id, .depth = 0, .components_hash = 0}); + current_pos_ = Continuation{.prefix = {prefix.data(), prefix.size()}, + .start_key = {prefix.data(), prefix.size()}, + .forward = true, + .was_prev_forward = true, + .page_size = 1}; +} + +Iterator::Iterator(std::weak_ptr<Database> db, const Continuation& c) + : db_(db), prev_pos_(), current_pos_(c) {} + +auto Iterator::Prev() -> std::optional<IndexRecord> { + if (!prev_pos_) { + return {}; + } + auto db = db_.lock(); + if (!db) { + return {}; + } + std::unique_ptr<Result<IndexRecord>> res{ + db->GetPage<IndexRecord>(&*prev_pos_).get()}; + prev_pos_ = res->prev_page(); + current_pos_ = prev_pos_; + return *res->values()[0]; +} + +auto Iterator::Next() -> std::optional<IndexRecord> { + if (!current_pos_) { + return {}; + } + auto db = db_.lock(); + if (!db) { + return {}; + } + std::unique_ptr<Result<IndexRecord>> res{ + db->GetPage<IndexRecord>(&*current_pos_).get()}; + prev_pos_ = current_pos_; + current_pos_ = res->next_page(); + return *res->values()[0]; +} + } // namespace database |
