pub struct WriteMode {
pub insert: InsertMode,
pub overwrite: OverwriteMode,
pub allow_extend_support: bool,
pub append_strategy: AppendStrategy,
}Expand description
Defines how/where data may be inserted, which day may and may not be overwritten, and whether data may extend the domain
§Example
Default WriteMode only allows appending supported values to new rows or
columns
use lace::{WriteMode, InsertMode, OverwriteMode, AppendStrategy};
let mode_new = WriteMode::new();
let mode_def = WriteMode::default();
assert_eq!(
mode_new,
WriteMode {
insert: InsertMode::Unrestricted,
overwrite: OverwriteMode::Deny,
allow_extend_support: false,
append_strategy: AppendStrategy::None,
}
);
assert_eq!(mode_def, mode_new);Fields§
§insert: InsertModeDetermines whether new rows or columns can be appended or if data may be entered into existing cells.
overwrite: OverwriteModeDetermines if existing cells may or may not be overwritten or whether only missing cells may be overwritten.
allow_extend_support: boolIf true, allow column support to be extended to accommodate new data
that fall outside the range. For example, a binary column extends to
ternary after the user inserts Datum::Categorical(2).
append_strategy: AppendStrategyThe behavior of the table when new rows are appended
Implementations§
Trait Implementations§
Source§impl<'de> Deserialize<'de> for WriteMode
impl<'de> Deserialize<'de> for WriteMode
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
impl Copy for WriteMode
impl Eq for WriteMode
impl StructuralPartialEq for WriteMode
Auto Trait Implementations§
impl Freeze for WriteMode
impl RefUnwindSafe for WriteMode
impl Send for WriteMode
impl Sync for WriteMode
impl Unpin for WriteMode
impl UnwindSafe for WriteMode
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.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 moreSource§impl<T> Key for Twhere
T: Clone,
impl<T> Key for Twhere
T: Clone,
Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.