Struct DictionaryTracker
pub struct DictionaryTracker {
written: HashMap<i64, ArrayData>,
dict_ids: Vec<i64>,
error_on_replacement: bool,
}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§
§written: HashMap<i64, ArrayData>§dict_ids: Vec<i64>§error_on_replacement: boolImplementations§
§impl DictionaryTracker
impl DictionaryTracker
pub fn new(error_on_replacement: bool) -> DictionaryTracker
pub fn new(error_on_replacement: bool) -> DictionaryTracker
Create a new DictionaryTracker.
If error_on_replacement
is true, an error will be generated if an update to an
existing dictionary is attempted.
pub fn next_dict_id(&mut self) -> i64
pub fn next_dict_id(&mut self) -> i64
Record and return the next dictionary ID.
pub fn dict_id(&mut self) -> &[i64]
pub fn dict_id(&mut self) -> &[i64]
Return the sequence of dictionary IDs in the order they should be observed while traversing the schema
pub fn insert(
&mut self,
dict_id: i64,
column: &Arc<dyn Array>,
) -> Result<bool, ArrowError>
👎Deprecated since 56.1.0: Use insert_column instead
pub fn insert( &mut self, dict_id: i64, column: &Arc<dyn Array>, ) -> Result<bool, ArrowError>
insert_column insteadKeep 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.
pub fn insert_column(
&mut self,
dict_id: i64,
column: &Arc<dyn Array>,
dict_handling: DictionaryHandling,
) -> Result<DictionaryUpdate, ArrowError>
pub fn insert_column( &mut self, dict_id: i64, column: &Arc<dyn Array>, dict_handling: DictionaryHandling, ) -> Result<DictionaryUpdate, ArrowError>
Keep track of the dictionary with the given ID and values. The return
value indicates what, if any, update to the internal map took place
and how it should be interpreted based on the dict_handling parameter.
§Returns
Ok(Dictionary::New)- If the dictionary was not previously writtenOk(Dictionary::Replaced)- If the dictionary was previously written with completely different data, or if the data is a delta of the existing, but withdict_handlingset toDictionaryHandling::ResendOk(Dictionary::Delta)- If the dictionary was previously written, but the new data is a delta of the old and thedict_handlingis set toDictionaryHandling::DeltaErr(e)- If the dictionary was previously written with different data, anderror_on_replacementis set totrue.
Trait Implementations§
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
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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 more