From 249449ff1a34df7d53d160874cc48d4f8e7f50af Mon Sep 17 00:00:00 2001 From: Yuya Nishihara Date: Thu, 21 Dec 2023 18:09:52 +0900 Subject: [PATCH] index: store local position in lookup table --- lib/src/default_index/mutable.rs | 2 +- lib/src/default_index/readonly.rs | 17 ++++------------- 2 files changed, 5 insertions(+), 14 deletions(-) diff --git a/lib/src/default_index/mutable.rs b/lib/src/default_index/mutable.rs index da0d52100..f09c193bd 100644 --- a/lib/src/default_index/mutable.rs +++ b/lib/src/default_index/mutable.rs @@ -224,7 +224,7 @@ impl MutableIndexSegment { for (commit_id, LocalPosition(pos)) in &self.commit_lookup { buf.extend_from_slice(commit_id.as_bytes()); - buf.extend((pos + self.num_parent_commits).to_le_bytes()); + buf.extend(pos.to_le_bytes()); } buf[parent_overflow_offset..][..4] diff --git a/lib/src/default_index/readonly.rs b/lib/src/default_index/readonly.rs index 393268c28..8df91e225 100644 --- a/lib/src/default_index/readonly.rs +++ b/lib/src/default_index/readonly.rs @@ -73,7 +73,7 @@ impl ReadonlyIndexLoadError { } /// Current format version of the index segment file. -pub(crate) const INDEX_SEGMENT_FILE_FORMAT_VERSION: u32 = 2; +pub(crate) const INDEX_SEGMENT_FILE_FORMAT_VERSION: u32 = 3; struct CommitGraphEntry<'a> { data: &'a [u8], @@ -122,7 +122,6 @@ impl CommitGraphEntry<'_> { struct CommitLookupEntry<'a> { data: &'a [u8], commit_id_length: usize, - num_parent_commits: u32, } impl CommitLookupEntry<'_> { @@ -139,16 +138,9 @@ impl CommitLookupEntry<'_> { &self.data[0..self.commit_id_length] } - fn pos(&self) -> IndexPosition { - let pos = u32::from_le_bytes(self.data[self.commit_id_length..][..4].try_into().unwrap()); - IndexPosition(pos) - } - - // TODO: better to store local pos in lookup table since there should be no - // inter-segment entry. fn local_pos(&self) -> LocalPosition { - let IndexPosition(pos) = self.pos(); - LocalPosition(pos - self.num_parent_commits) + let pos = u32::from_le_bytes(self.data[self.commit_id_length..][..4].try_into().unwrap()); + LocalPosition(pos) } } @@ -171,7 +163,7 @@ impl CommitLookupEntry<'_> { /// : commit id /// for each entry, sorted by commit id: /// : commit id -/// u32: global index position +/// u32: local position in the graph entries table /// for each overflow parent: /// u32: global index position /// ``` @@ -344,7 +336,6 @@ impl ReadonlyIndexSegment { CommitLookupEntry { data: &self.data[offset..][..self.commit_lookup_entry_size], commit_id_length: self.commit_id_length, - num_parent_commits: self.num_parent_commits, } }