RawModuleDefV9

Struct RawModuleDefV9 

Source
pub struct RawModuleDefV9 {
    pub typespace: Typespace,
    pub tables: Vec<RawTableDefV9>,
    pub reducers: Vec<RawReducerDefV9>,
    pub types: Vec<RawTypeDefV9>,
    pub misc_exports: Vec<RawMiscModuleExportV9>,
    pub row_level_security: Vec<RawRowLevelSecurityDefV9>,
}
Expand description

A possibly-invalid raw module definition.

ABI Version 9.

These “raw definitions” may contain invalid data, and are validated by the validate module into a proper spacetimedb_schema::ModuleDef, or a collection of errors.

The module definition has a single logical global namespace, which maps Identifiers to:

  • database-level objects:
    • logical schema objects:
      • tables
      • constraints
      • sequence definitions
    • physical schema objects:
      • indexes
  • module-level objects:
    • reducers
    • schedule definitions
  • binding-level objects:
    • type aliases

All of these types of objects must have unique names within the module. The exception is columns, which need unique names only within a table.

Fields§

§typespace: Typespace

The Typespace used by the module.

AlgebraicTypeRefs in the table, reducer, and type alias declarations refer to this typespace.

The typespace must satisfy Typespace::is_valid_for_client_code_generation. That is, all types stored in the typespace must either:

  1. satisfy AlgebraicType::is_valid_for_client_type_definition
  2. and/or AlgebraicType::is_valid_for_client_type_use.

Types satisfying condition 1 correspond to generated classes in client code. (Types satisfying condition 2 are an artifact of the module bindings, and do not affect the semantics of the module definition.)

Types satisfying condition 1 are required to have corresponding RawTypeDefV9 declarations in the module.

§tables: Vec<RawTableDefV9>

The tables of the database definition used in the module.

Each table must have a unique name.

§reducers: Vec<RawReducerDefV9>

The reducers exported by the module.

§types: Vec<RawTypeDefV9>

The types exported by the module.

§misc_exports: Vec<RawMiscModuleExportV9>

Miscellaneous additional module exports.

§row_level_security: Vec<RawRowLevelSecurityDefV9>

Low level security definitions.

Each definition must have a unique name.

Trait Implementations§

Source§

impl Clone for RawModuleDefV9

Source§

fn clone(&self) -> RawModuleDefV9

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 RawModuleDefV9

Source§

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

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

impl Default for RawModuleDefV9

Source§

fn default() -> RawModuleDefV9

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

impl<'de> Deserialize<'de> for RawModuleDefV9

Source§

fn deserialize<D: Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error>

Deserialize this value from the given deserializer.
Source§

impl Serialize for RawModuleDefV9

Source§

fn serialize<S: Serializer>(&self, __serializer: S) -> Result<S::Ok, S::Error>

Serialize self in the data format of S using the provided serializer.
Source§

impl SpacetimeType for RawModuleDefV9

Source§

fn make_type<S: TypespaceBuilder>(__typespace: &mut S) -> AlgebraicType

Returns an AlgebraicType representing the type for Self in SATS and in the typing context in typespace. This is used by the automatic type registration system in Rust modules. Read more

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> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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 more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> Satn for T
where T: Serialize + ?Sized,

Source§

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

Formats the value using the SATN data format into the formatter f.
Source§

fn fmt_psql( &self, f: &mut Formatter<'_>, ty: &PsqlType<'_>, ) -> Result<(), Error>

Formats the value using the postgres SATN(PsqlFormatter { f }, /* PsqlType */) formatter f.
Source§

fn to_satn(&self) -> String

Formats the value using the SATN data format into the returned String.
Source§

fn to_satn_pretty(&self) -> String

Pretty prints the value using the SATN data format into the returned String.
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.
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,