pub struct DictionaryTracker {
pub dictionaries: Dictionaries,
pub cannot_replace: bool,
}
Available on crate feature
io_ipc
only.Expand description
Keeps track of dictionaries that have been written, to avoid emitting the same dictionary
multiple times. Can optionally error if an update to an existing dictionary is attempted, which
isn’t allowed in the FileWriter
.
Fields§
§dictionaries: Dictionaries
§cannot_replace: bool
Implementations§
Source§impl DictionaryTracker
impl DictionaryTracker
Sourcepub fn insert(&mut self, dict_id: i64, array: &dyn Array) -> PolarsResult<bool>
pub fn insert(&mut self, dict_id: i64, array: &dyn Array) -> PolarsResult<bool>
Keep track of the dictionary with the given ID and values. Behavior:
- If this ID has been written already and has the same data, return
Ok(false)
to indicate that the dictionary was not actually inserted (because it’s already been seen). - If this ID has been written already but with different data, and this tracker is configured to return an error, return an error.
- If the tracker has not been configured to error on replacement or this dictionary
has never been seen before, return
Ok(true)
to indicate that the dictionary was just inserted.
Auto Trait Implementations§
impl Freeze for DictionaryTracker
impl !RefUnwindSafe for DictionaryTracker
impl Send for DictionaryTracker
impl Sync for DictionaryTracker
impl Unpin for DictionaryTracker
impl !UnwindSafe for DictionaryTracker
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
Mutably borrows from an owned value. Read more
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> ⓘ
Converts
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> ⓘ
Converts
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 more