pub struct BinaryViewVectorMut<T: BinaryViewType> { /* private fields */ }Expand description
A mutable vector of binary view data.
The immutable equivalent of this type is BinaryViewVector.
Implementations§
Source§impl<T: BinaryViewType> BinaryViewVectorMut<T>
impl<T: BinaryViewType> BinaryViewVectorMut<T>
Sourcepub fn new(
views: BufferMut<BinaryView>,
buffers: Vec<ByteBuffer>,
validity: MaskMut,
) -> Self
pub fn new( views: BufferMut<BinaryView>, buffers: Vec<ByteBuffer>, validity: MaskMut, ) -> Self
Create a new BinaryViewVectorMut from its components, panicking if validation fails.
§Errors
This function will panic if any of the validation checks performed by try_new
fails.
Sourcepub fn with_capacity(capacity: usize) -> Self
pub fn with_capacity(capacity: usize) -> Self
Create a new empty BinaryViewVectorMut, pre-allocated to hold the specified number
of items. This does not reserve any memory for string data itself, only for the binary views
and the validity bits.
Sourcepub fn try_new(
views: BufferMut<BinaryView>,
buffers: Vec<ByteBuffer>,
validity: MaskMut,
) -> VortexResult<Self>
pub fn try_new( views: BufferMut<BinaryView>, buffers: Vec<ByteBuffer>, validity: MaskMut, ) -> VortexResult<Self>
Tries to create a new BinaryViewVectorMut from its components.
§Errors
Returns an error if the length of the validity mask does not match the length of the views.
Returns an error if the views reference any data that is not a valid buffer
Sourcepub unsafe fn new_unchecked(
views: BufferMut<BinaryView>,
validity: MaskMut,
buffers: Vec<ByteBuffer>,
) -> Self
pub unsafe fn new_unchecked( views: BufferMut<BinaryView>, validity: MaskMut, buffers: Vec<ByteBuffer>, ) -> Self
Creates a new BinaryViewVectorMut from the given bits and validity mask without validation.
§Safety
The caller must ensure that the validity mask has the same length as the views.
Sourcepub unsafe fn views_mut(&mut self) -> &mut BufferMut<BinaryView>
pub unsafe fn views_mut(&mut self) -> &mut BufferMut<BinaryView>
Sourcepub unsafe fn validity_mut(&mut self) -> &mut MaskMut
pub unsafe fn validity_mut(&mut self) -> &mut MaskMut
Get a mutable handle to the validity mask of the vector.
§Safety
Caller must make sure that the length of the validity mask always matches the length of the views
Sourcepub fn buffers(&mut self) -> &mut Vec<ByteBuffer> ⓘ
pub fn buffers(&mut self) -> &mut Vec<ByteBuffer> ⓘ
Get a mutable handle to the vector of buffers backing the string data of the vector.
Sourcepub fn append_values(&mut self, value: &T::Slice, n: usize)
pub fn append_values(&mut self, value: &T::Slice, n: usize)
Append a repeated sequence of binary data to a vector.
let mut strings = StringVectorMut::with_capacity(4);
strings.append_values("inlined", 2);
strings.append_nulls(1);
strings.append_values("large not inlined", 1);
let strings = strings.freeze();
assert_eq!(
[strings.get_ref(0), strings.get_ref(1), strings.get_ref(2), strings.get_ref(3)],
[Some("inlined"), Some("inlined"), None, Some("large not inlined")],
);Sourcepub fn append_owned_values(&mut self, value: T::Scalar, n: usize)
pub fn append_owned_values(&mut self, value: T::Scalar, n: usize)
Append a repeated sequence of binary data to a vector, from an owned buffer.
The buffer will be used directly if possible, avoiding a copy.
Trait Implementations§
Source§impl<T: Clone + BinaryViewType> Clone for BinaryViewVectorMut<T>
impl<T: Clone + BinaryViewType> Clone for BinaryViewVectorMut<T>
Source§fn clone(&self) -> BinaryViewVectorMut<T>
fn clone(&self) -> BinaryViewVectorMut<T>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<T: Debug + BinaryViewType> Debug for BinaryViewVectorMut<T>
impl<T: Debug + BinaryViewType> Debug for BinaryViewVectorMut<T>
Source§impl<T: BinaryViewType> From<BinaryViewVectorMut<T>> for VectorMut
impl<T: BinaryViewType> From<BinaryViewVectorMut<T>> for VectorMut
Source§fn from(value: BinaryViewVectorMut<T>) -> Self
fn from(value: BinaryViewVectorMut<T>) -> Self
Source§impl<T: BinaryViewType> VectorMutOps for BinaryViewVectorMut<T>
impl<T: BinaryViewType> VectorMutOps for BinaryViewVectorMut<T>
Source§type Immutable = BinaryViewVector<T>
type Immutable = BinaryViewVector<T>
Source§fn len(&self) -> usize
fn len(&self) -> usize
Source§fn validity(&self) -> &MaskMut
fn validity(&self) -> &MaskMut
true represents a valid element and
false represents a null element. Read moreSource§fn capacity(&self) -> usize
fn capacity(&self) -> usize
Source§fn reserve(&mut self, additional: usize)
fn reserve(&mut self, additional: usize)
additional more elements to be inserted in the given
vector. Read moreSource§fn truncate(&mut self, len: usize)
fn truncate(&mut self, len: usize)
Source§fn extend_from_vector(&mut self, other: &BinaryViewVector<T>)
fn extend_from_vector(&mut self, other: &BinaryViewVector<T>)
Source§fn append_nulls(&mut self, n: usize)
fn append_nulls(&mut self, n: usize)
n null elements to the vector. Read moreSource§fn freeze(self) -> BinaryViewVector<T>
fn freeze(self) -> BinaryViewVector<T>
self into an immutable vector.Source§fn split_off(&mut self, _at: usize) -> Self
fn split_off(&mut self, _at: usize) -> Self
Auto Trait Implementations§
impl<T> Freeze for BinaryViewVectorMut<T>
impl<T> RefUnwindSafe for BinaryViewVectorMut<T>where
T: RefUnwindSafe,
impl<T> Send for BinaryViewVectorMut<T>
impl<T> Sync for BinaryViewVectorMut<T>
impl<T> Unpin for BinaryViewVectorMut<T>where
T: Unpin,
impl<T> UnwindSafe for BinaryViewVectorMut<T>where
T: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self to use its Binary implementation when Debug-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self to use its Display implementation when
Debug-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self to use its Octal implementation when Debug-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.