From 72c25bd262110fd1eb11af6e55de9d10f8bac7bb Mon Sep 17 00:00:00 2001 From: doki Date: Sat, 16 Mar 2024 08:16:35 +0800 Subject: [PATCH] update --- arrow-buffer/src/builder/offset.rs | 33 +++++++++++++++++++++++++----- 1 file changed, 28 insertions(+), 5 deletions(-) diff --git a/arrow-buffer/src/builder/offset.rs b/arrow-buffer/src/builder/offset.rs index 432334722a8d..d3d531345800 100644 --- a/arrow-buffer/src/builder/offset.rs +++ b/arrow-buffer/src/builder/offset.rs @@ -87,7 +87,7 @@ impl + Sub> OffsetBufferBuilder self.offsets.push(next_offset); } - /// Try to extend an IntoIterator of lengths + /// Try to extend builder with an IntoIterator of lengths pub fn try_extend>(&mut self, lengths: T) -> Result<(), String> { let lengths_iter = lengths.into_iter(); let size_hint = match lengths_iter.size_hint().1 { @@ -107,14 +107,20 @@ impl + Sub> OffsetBufferBuilder } /// Capacity of offsets + #[inline] pub fn capacity(&self) -> usize { self.offsets.capacity() - 1 } /// Length of the Offsets - #[allow(clippy::len_without_is_empty)] + #[inline] pub fn len(&self) -> usize { - self.offsets.len() + self.offsets.len() - 1 + } + + #[inline] + pub fn is_empty(&self) -> bool { + self.len() == 0 } /// Last offset @@ -150,19 +156,36 @@ mod tests { use crate::{OffsetBuffer, OffsetBufferBuilder}; #[test] - fn new_zeroed() -> Result<(), String> { + fn test_new_zeroed() -> Result<(), String> { let builder: OffsetBufferBuilder = OffsetBufferBuilder::new_zeroed(3); + assert_eq!(builder.is_empty(), false); + assert_eq!(builder.capacity(), 3); + assert_eq!(builder.len(), 3); assert_eq!(builder.finish().to_vec(), vec![0, 0, 0, 0]); Ok(()) } + #[test] + fn test_capacity_len() -> Result<(), String> { + let mut builder = OffsetBufferBuilder::::new(1); + assert_eq!(builder.is_empty(), true); + assert_eq!(builder.capacity(), 1); + builder.try_push_length(1)?; + assert_eq!(builder.is_empty(), false); + assert_eq!(builder.capacity(), 1); + assert_eq!(builder.len(), 1); + Ok(()) + } + #[test] fn test_from() -> Result<(), String> { let lengths = vec![1, 2, 3, 0, 3, 2, 1]; let builder = OffsetBufferBuilder::::try_from_lengths(lengths)?; assert_eq!(builder.last(), 12); - assert_eq!(builder.len(), 8); + assert_eq!(builder.capacity(), 7); + assert_eq!(builder.len(), 7); + assert_eq!(builder.is_empty(), false); let offsets = builder.finish(); assert_eq!(offsets.to_vec(), vec![0, 1, 3, 6, 6, 9, 11, 12]);