SeqMarked

Struct SeqMarked 

Source
pub struct SeqMarked<D = Vec<u8>> { /* private fields */ }
Expand description

Sequence-numbered marked value.

Ordered by sequence number first, then tombstone > normal.

use seq_marked::SeqMarked;

let v1 = SeqMarked::new_normal(1, "data");
let v2 = SeqMarked::<&str>::new_tombstone(2);
assert!(v1 < v2);

Implementations§

Source§

impl SeqMarked<()>

Source

pub const fn zero() -> Self

Creates the smallest order key (seq=0, normal).

Source

pub const fn max_value() -> Self

Source§

impl<D> SeqMarked<&D>

Source

pub fn cloned(self) -> SeqMarked<D>
where D: Clone,

Source§

impl<D> SeqMarked<D>

Source

pub fn new(seq: u64, marked: Marked<D>) -> Self

Creates a new SeqMarked with sequence number and marked data.

Source

pub fn new_normal(seq: u64, data: D) -> Self

Creates normal value with sequence number.

Source

pub fn new_tombstone(seq: u64) -> Self

Creates tombstone with sequence number.

Source

pub fn new_not_found() -> Self

Represents an absent record (not even marked as deleted).

Source

pub fn to_tombstone(self) -> Self

Source

pub fn is_normal(&self) -> bool

Returns true if this is normal data.

Source

pub fn is_tombstone(&self) -> bool

Returns true if this is a tombstone.

Source

pub fn is_not_found(&self) -> bool

Source

pub fn is_absent(&self) -> bool

Source

pub fn map<U>(self, f: impl FnOnce(D) -> U) -> SeqMarked<U>

Transforms data D to U while preserving sequence and tombstone state.

§Example
use seq_marked::SeqMarked;

let a = SeqMarked::new_normal(1, "data");
let b = a.map(|x| x.len());
assert_eq!(b.data_ref(), Some(&4));
Source

pub fn try_map<U, E>( self, f: impl FnOnce(D) -> Result<U, E>, ) -> Result<SeqMarked<U>, E>

Source

pub fn as_ref(&self) -> SeqMarked<&D>

Creates reference to the data.

Source

pub fn order_key(&self) -> SeqMarked<()>

Returns ordering key (sequence + tombstone state only).

Source

pub fn internal_seq(&self) -> InternalSeq

Returns the sequence number for internal use, tombstone also has a seq.

Source

pub fn user_seq(&self) -> u64

Returns the sequence number for application use, tombstone always has seq 0.

Source

pub fn max(a: Self, b: Self) -> Self

Returns the maximum of two values.

Source

pub fn max_ref<'l>(a: &'l Self, b: &'l Self) -> &'l Self

Returns the maximum of two values.

Source

pub fn data_ref(&self) -> Option<&D>

Returns reference to data if normal, None if tombstone.

Source

pub fn into_data(self) -> Option<D>

Consumes and returns data if normal, None if tombstone.

Source

pub fn into_parts(self) -> (u64, Marked<D>)

Source

pub fn display_with_debug(&self) -> impl Display + '_
where D: Debug,

Returns formatter for display using Debug trait.

Trait Implementations§

Source§

impl<D: Clone> Clone for SeqMarked<D>

Source§

fn clone(&self) -> SeqMarked<D>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<D: Debug> Debug for SeqMarked<D>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<D> Display for SeqMarked<D>
where D: Display,

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<D> From<SeqData<D>> for SeqMarked<D>

Source§

fn from(value: SeqData<D>) -> Self

Converts to this type from the input type.
Source§

impl<M> From<SeqMarked<(Option<M>, String)>> for SeqMarked<(Option<M>, Vec<u8>)>

Source§

fn from(value: SeqMarked<(Option<M>, String)>) -> Self

Converts to this type from the input type.
Source§

impl<M, T> From<SeqMarked<(Option<M>, T)>> for Option<SeqV<M, T>>

Source§

fn from(value: SeqMarked<(Option<M>, T)>) -> Self

Converts to this type from the input type.
Source§

impl<D> From<SeqMarked<D>> for Option<SeqData<D>>

Source§

fn from(value: SeqMarked<D>) -> Self

Converts to this type from the input type.
Source§

impl<M, T> From<SeqV<M, T>> for SeqMarked<(Option<M>, T)>

Source§

fn from(value: SeqV<M, T>) -> Self

Converts to this type from the input type.
Source§

impl<D: Ord> Ord for SeqMarked<D>

Source§

fn cmp(&self, other: &SeqMarked<D>) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl<D: PartialEq> PartialEq for SeqMarked<D>

Source§

fn eq(&self, other: &SeqMarked<D>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<D: PartialOrd> PartialOrd for SeqMarked<D>

Source§

fn partial_cmp(&self, other: &SeqMarked<D>) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl<M, T> SeqValue<M, T> for SeqMarked<(Option<M>, T)>

SeqMarked is a superset of SeqValue.

Source§

fn seq(&self) -> u64

Return the sequence number of the value.
Source§

fn value(&self) -> Option<&T>

Return the reference of the value.
Source§

fn into_value(self) -> Option<T>

Consume the value and return the value.
Source§

fn meta(&self) -> Option<&M>

Return the reference of metadata of the value.
Source§

fn unpack(self) -> (u64, Option<V>)
where Self: Sized,

Consume self and return the sequence number and the value.
Source§

fn expires_at_ms_opt(&self) -> Option<u64>
where M: Expirable,

Return the absolute expire time in millisecond since 1970-01-01 00:00:00.
Source§

fn expires_at_ms(&self) -> u64
where M: Expirable,

Returns the absolute expiration time in milliseconds since the Unix epoch (1970-01-01 00:00:00 UTC). Read more
Source§

fn is_expired(&self, now_ms: u64) -> bool
where M: Expirable,

Return true if the record is expired at the given time in milliseconds since the Unix epoch (1970-01-01 00:00:00 UTC).
Source§

impl<M> TryFrom<SeqMarked<(Option<M>, Vec<u8>)>> for SeqMarked<(Option<M>, String)>

Source§

type Error = Error

The type returned in the event of a conversion error.
Source§

fn try_from(value: SeqMarked<(Option<M>, Vec<u8>)>) -> Result<Self, Self::Error>

Performs the conversion.
Source§

impl<D: Copy> Copy for SeqMarked<D>

Source§

impl<D: Eq> Eq for SeqMarked<D>

Source§

impl<D> StructuralPartialEq for SeqMarked<D>

Auto Trait Implementations§

§

impl<D> Freeze for SeqMarked<D>
where D: Freeze,

§

impl<D> RefUnwindSafe for SeqMarked<D>
where D: RefUnwindSafe,

§

impl<D> Send for SeqMarked<D>
where D: Send,

§

impl<D> Sync for SeqMarked<D>
where D: Sync,

§

impl<D> Unpin for SeqMarked<D>
where D: Unpin,

§

impl<D> UnwindSafe for SeqMarked<D>
where D: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.