From 7e77dbcc1751efbec19b537dcc1f0c8388c97605 Mon Sep 17 00:00:00 2001 From: bsbds <69835502+bsbds@users.noreply.github.com> Date: Fri, 19 Apr 2024 18:45:56 +0800 Subject: [PATCH] squash!: update segment size during recovery Signed-off-by: bsbds <69835502+bsbds@users.noreply.github.com> --- crates/curp/src/server/storage/wal/segment.rs | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/crates/curp/src/server/storage/wal/segment.rs b/crates/curp/src/server/storage/wal/segment.rs index 97def61cd..93a71ae7d 100644 --- a/crates/curp/src/server/storage/wal/segment.rs +++ b/crates/curp/src/server/storage/wal/segment.rs @@ -140,7 +140,7 @@ impl WALSegment { { let encoded_bytes = encoder.encode(item)?; self.file.write_all(&encoded_bytes)?; - self.size = self.size.overflow_add(encoded_bytes.len().numeric_cast()); + self.update_size(encoded_bytes.len().numeric_cast()); self.file.flush()?; self.file.sync_data()?; @@ -173,10 +173,16 @@ impl WALSegment { }; entries.push(item); pos += n; + self.update_size(n.numeric_cast()); } Ok(entries) } + /// Updates the size of this segment + pub(super) fn update_size(&mut self, increment: u64) { + self.size = self.size.overflow_add(increment); + } + /// Updates the seal index pub(super) fn update_seal_index(&mut self, index: LogIndex) { self.seal_index = self.seal_index.max(index);