Skip to main content

SchemaRegistry

Struct SchemaRegistry 

Source
pub struct SchemaRegistry { /* private fields */ }
Expand description

The schema registry takes care of storing and retrieving table schemas from memory.

Implementations§

Source§

impl SchemaRegistry

Source

pub fn load(mm: &mut impl MemoryAccess) -> MemoryResult<Self>

Load the schema registry from memory.

Source

pub const fn schema_hash(&self) -> u64

Returns the cached hash of every persisted schema snapshot.

Source

pub fn register_table<TS>( &mut self, mm: &mut impl MemoryAccess, ) -> MemoryResult<TableRegistryPage>
where TS: TableSchema,

Registers a table and allocates it registry page.

The TableSchema type parameter is used to get the TableSchema::fingerprint of the table schema. The fingerprint is derived from the table name, so two distinct names that hash to the same value are detected eagerly: when the slot is already occupied by a table with a different name, MemoryError::NameCollision is returned and no allocation is performed.

§Errors
  • MemoryError::NameCollision when the fingerprint slot is occupied by a table whose persisted snapshot carries a different name.
  • Any MemoryError propagated from page allocation, snapshot init, or the registry write-back.
Source

pub fn save(&self, mm: &mut impl MemoryAccess) -> MemoryResult<()>

Save the schema registry to memory.

Source

pub fn table_registry_page<TS>(&self) -> Option<TableRegistryPage>
where TS: TableSchema,

Returns the table registry page for a given table schema.

Source

pub fn table_registry_page_by_name( &self, name: &str, ) -> Option<TableRegistryPage>

Returns the table registry page for the table with the given name.

Used by the migration engine, which knows tables only by name when applying ops decoded from snapshots.

Source

pub fn register_table_from_snapshot( &mut self, snapshot: &TableSchemaSnapshot, mm: &mut impl MemoryAccess, ) -> MemoryResult<TableRegistryPage>

Registers a table from a snapshot, allocating its registry pages.

The migration engine uses this entry point when applying a MigrationOp::CreateTable: the source of truth is a TableSchemaSnapshot, not a TableSchema type.

§Errors
  • MemoryError::NameCollision when the fingerprint slot is occupied by a table with a different name.
  • Any MemoryError propagated from page allocation, snapshot init, index init, or registry persistence.
Source

pub fn unregister_table( &mut self, name: &str, mm: &mut impl MemoryAccess, ) -> MemoryResult<Option<TableRegistryPage>>

Removes the table identified by name from the registry, releases every page it owned back to the unclaimed-pages ledger, and persists the updated registry.

Used by the migration engine when applying a MigrationOp::DropTable.

Returns the TableRegistryPage previously associated with the table, or None if no such table was registered.

§Errors

Returns a MemoryError if loading the table registry, releasing its pages, or persisting the updated schema registry fails.

Source

pub fn stored_snapshots( &self, mm: &mut impl MemoryAccess, ) -> MemoryResult<Vec<TableSchemaSnapshot>>

Returns the persisted TableSchemaSnapshot for every registered table.

The order is unspecified. Callers that need a stable order (e.g. for drift hashing) must sort by TableSchemaSnapshot::name.

§Errors

Returns the first MemoryError encountered while loading any snapshot page.

Source

pub fn refresh_schema_hash( &mut self, mm: &mut impl MemoryAccess, ) -> MemoryResult<()>

Recomputes the cached schema hash from the currently registered tables.

Trait Implementations§

Source§

impl Clone for SchemaRegistry

Source§

fn clone(&self) -> SchemaRegistry

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 Debug for SchemaRegistry

Source§

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

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

impl Default for SchemaRegistry

Source§

fn default() -> SchemaRegistry

Returns the “default value” for a type. Read more
Source§

impl Encode for SchemaRegistry

Source§

const SIZE: DataSize = DataSize::Dynamic

The size characteristic of the data type. Read more
Source§

const ALIGNMENT: PageOffset = DEFAULT_ALIGNMENT

The alignment requirement in bytes for the data type. Read more
Source§

fn encode(&self) -> Cow<'_, [u8]>

Encodes the data type into a vector of bytes.
Source§

fn decode(data: Cow<'_, [u8]>) -> MemoryResult<Self>
where Self: Sized,

Decodes the data type from a slice of bytes.
Source§

fn size(&self) -> MSize

Returns the size in bytes of the encoded data type.
Source§

impl PartialEq for SchemaRegistry

Source§

fn eq(&self, other: &SchemaRegistry) -> 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 Eq for SchemaRegistry

Source§

impl StructuralPartialEq for SchemaRegistry

Auto Trait Implementations§

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, 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.