pub struct SchemaDoc { /* private fields */ }Expand description
Loro-backed CRDT document tracking a single array’s schema.
The schema is stored as a MessagePack blob at root map key "content".
schema_hlc is the HLC of the most-recent schema write on this replica;
it is compared against the schema_hlc embedded in each [ArrayOp]
header to gate op application.
LoroDoc is not Clone, so SchemaDoc is not Clone either.
Implementations§
Source§impl SchemaDoc
impl SchemaDoc
Sourcepub fn new(replica_id: ReplicaId) -> Self
pub fn new(replica_id: ReplicaId) -> Self
Create an empty schema doc for replica_id.
schema_hlc starts at Hlc::ZERO. Call SchemaDoc::from_schema
or SchemaDoc::import_snapshot to populate it.
Sourcepub fn from_schema(
replica_id: ReplicaId,
schema: &ArraySchema,
generator: &HlcGenerator,
) -> ArrayResult<Self>
pub fn from_schema( replica_id: ReplicaId, schema: &ArraySchema, generator: &HlcGenerator, ) -> ArrayResult<Self>
Construct a schema doc pre-populated with schema.
The schema is encoded as MessagePack and stored under
root["content"]. generator.next() is called to assign the initial
schema_hlc.
Sourcepub fn schema_hlc(&self) -> Hlc
pub fn schema_hlc(&self) -> Hlc
Return the current schema HLC.
Sourcepub fn replica_id(&self) -> ReplicaId
pub fn replica_id(&self) -> ReplicaId
Return the replica ID of this doc.
Sourcepub fn to_schema(&self) -> ArrayResult<ArraySchema>
pub fn to_schema(&self) -> ArrayResult<ArraySchema>
Decode the stored schema from the Loro doc.
Reads the MessagePack blob at root["content"] and decodes it via
zerompk. Errors map to ArrayError::SegmentCorruption.
Sourcepub fn export_snapshot(&self) -> ArrayResult<Vec<u8>>
pub fn export_snapshot(&self) -> ArrayResult<Vec<u8>>
Export the full Loro snapshot as an enveloped byte buffer.
The returned bytes have the format:
[LORO_FORMAT_VERSION: u8][loro snapshot bytes…]
Pass the result to SchemaDoc::import_snapshot (or
SchemaDoc::import_snapshot_replicated) on another replica to
converge schema state.
Sourcepub fn import_snapshot(
&mut self,
bytes: &[u8],
remote_hlc: Hlc,
generator: &HlcGenerator,
) -> ArrayResult<()>
pub fn import_snapshot( &mut self, bytes: &[u8], remote_hlc: Hlc, generator: &HlcGenerator, ) -> ArrayResult<()>
Import a Loro snapshot from a remote replica.
After merging the snapshot, generator.observe(remote_hlc) is called
so the local generator incorporates the remote clock. A fresh
schema_hlc is then generated via generator.next() so that any
subsequent local writes have an HLC strictly greater than
remote_hlc.
Sourcepub fn import_snapshot_replicated(
&mut self,
bytes: &[u8],
committed_hlc: Hlc,
) -> ArrayResult<()>
pub fn import_snapshot_replicated( &mut self, bytes: &[u8], committed_hlc: Hlc, ) -> ArrayResult<()>
Import a Loro snapshot from a Raft-committed entry.
Unlike [import_snapshot], this method sets schema_hlc to exactly
remote_hlc rather than bumping past it. This is the correct
behaviour for Raft replication: every replica must converge to the
same schema_hlc after applying the same log entry so that
schema-gating checks on ops are consistent across the cluster.
Call this only from the distributed applier (Raft commit path), not from the CRDT sync path where bumping is required.
Sourcepub fn replace_schema(
&mut self,
schema: &ArraySchema,
generator: &HlcGenerator,
) -> ArrayResult<()>
pub fn replace_schema( &mut self, schema: &ArraySchema, generator: &HlcGenerator, ) -> ArrayResult<()>
Replace the stored schema with schema.
Re-encodes the schema as MessagePack and overwrites root["content"].
Bumps schema_hlc via generator.next().
This is the stub entry point for Phase F ALTER ARRAY support. Incremental dim/attr add will build on this path.
Auto Trait Implementations§
impl Freeze for SchemaDoc
impl RefUnwindSafe for SchemaDoc
impl Send for SchemaDoc
impl Sync for SchemaDoc
impl Unpin for SchemaDoc
impl UnsafeUnpin for SchemaDoc
impl UnwindSafe for SchemaDoc
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
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> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§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 moreSource§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
out indicating that a T is niched.Source§impl<T> Paint for Twhere
T: ?Sized,
impl<T> Paint for Twhere
T: ?Sized,
Source§fn fg(&self, value: Color) -> Painted<&T>
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the foreground set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red() and
green(), which have the same functionality but are
pithier.
§Example
Set foreground color to white using fg():
use yansi::{Paint, Color};
painted.fg(Color::White);Set foreground color to white using white().
use yansi::Paint;
painted.white();Source§fn bright_black(&self) -> Painted<&T>
fn bright_black(&self) -> Painted<&T>
Source§fn bright_red(&self) -> Painted<&T>
fn bright_red(&self) -> Painted<&T>
Source§fn bright_green(&self) -> Painted<&T>
fn bright_green(&self) -> Painted<&T>
Source§fn bright_yellow(&self) -> Painted<&T>
fn bright_yellow(&self) -> Painted<&T>
Source§fn bright_blue(&self) -> Painted<&T>
fn bright_blue(&self) -> Painted<&T>
Source§fn bright_magenta(&self) -> Painted<&T>
fn bright_magenta(&self) -> Painted<&T>
Source§fn bright_cyan(&self) -> Painted<&T>
fn bright_cyan(&self) -> Painted<&T>
Source§fn bright_white(&self) -> Painted<&T>
fn bright_white(&self) -> Painted<&T>
Source§fn bg(&self, value: Color) -> Painted<&T>
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the background set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red() and
on_green(), which have the same functionality but
are pithier.
§Example
Set background color to red using fg():
use yansi::{Paint, Color};
painted.bg(Color::Red);Set background color to red using on_red().
use yansi::Paint;
painted.on_red();Source§fn on_primary(&self) -> Painted<&T>
fn on_primary(&self) -> Painted<&T>
Source§fn on_magenta(&self) -> Painted<&T>
fn on_magenta(&self) -> Painted<&T>
Source§fn on_bright_black(&self) -> Painted<&T>
fn on_bright_black(&self) -> Painted<&T>
Source§fn on_bright_red(&self) -> Painted<&T>
fn on_bright_red(&self) -> Painted<&T>
Source§fn on_bright_green(&self) -> Painted<&T>
fn on_bright_green(&self) -> Painted<&T>
Source§fn on_bright_yellow(&self) -> Painted<&T>
fn on_bright_yellow(&self) -> Painted<&T>
Source§fn on_bright_blue(&self) -> Painted<&T>
fn on_bright_blue(&self) -> Painted<&T>
Source§fn on_bright_magenta(&self) -> Painted<&T>
fn on_bright_magenta(&self) -> Painted<&T>
Source§fn on_bright_cyan(&self) -> Painted<&T>
fn on_bright_cyan(&self) -> Painted<&T>
Source§fn on_bright_white(&self) -> Painted<&T>
fn on_bright_white(&self) -> Painted<&T>
Source§fn attr(&self, value: Attribute) -> Painted<&T>
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling Attribute value.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold() and
underline(), which have the same functionality
but are pithier.
§Example
Make text bold using attr():
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);Make text bold using using bold().
use yansi::Paint;
painted.bold();Source§fn rapid_blink(&self) -> Painted<&T>
fn rapid_blink(&self) -> Painted<&T>
Source§fn quirk(&self, value: Quirk) -> Painted<&T>
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi Quirk value.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask() and
wrap(), which have the same functionality but are
pithier.
§Example
Enable wrapping using .quirk():
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);Enable wrapping using wrap().
use yansi::Paint;
painted.wrap();Source§fn clear(&self) -> Painted<&T>
👎Deprecated since 1.0.1: renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
fn clear(&self) -> Painted<&T>
renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
Source§fn whenever(&self, value: Condition) -> Painted<&T>
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the Condition value
applies. Replaces any previous condition.
See the crate level docs for more details.
§Example
Enable styling painted only when both stdout and stderr are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);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>
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
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
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.