pub struct ModelMeta {Show 13 fields
pub name: String,
pub table: String,
pub fields: Vec<Column>,
pub display: String,
pub icon: String,
pub database: Option<String>,
pub singleton: bool,
pub unique_together: Vec<Vec<String>>,
pub indexes: Vec<Vec<String>>,
pub ordering: Vec<(String, bool)>,
pub m2m_relations: Vec<M2MRelation>,
pub soft_delete: bool,
pub app_label: String,
}Expand description
Static metadata for one registered model, copied off the Model
trait’s consts when the user calls App::builder().model::<T>().
Owned (no lifetimes) so the registry can hold an arbitrary number
without the lifetime contortions a slice of trait references would
need. The cost is one Vec at App::build time; the win is
registered_models() having a plain &'static [ModelMeta] signature.
Fields§
§name: StringThe struct name (Model::NAME). Identifies the model across
snapshot diffs even if the table is renamed.
table: StringThe SQL table name (Model::TABLE).
fields: Vec<Column>One owned column descriptor per field, in declaration order.
Owned (Column, not the underlying static FieldSpec) so the
snapshot round-trips cleanly through serde.
display: StringHuman-readable display name from Model::DISPLAY. Defaults to
Model::NAME when no #[umbral(display = "...")] is present.
icon: StringLucide icon slug from Model::ICON. Defaults to "database".
database: Option<String>Database alias from Model::DATABASE, when set. None means
“fall back to the owning plugin’s Plugin::database(), then
the default pool.” Captured here so App::build’s alias
routing can read it without re-reaching into the trait at a
later phase.
singleton: boolMirrors Model::SINGLETON. Closes BUG-9 in
bugs/tests/testBugs.md. Default false; admin renderers
read it to auto-redirect list-view to the edit form.
unique_together: Vec<Vec<String>>Mirrors Model::UNIQUE_TOGETHER. Composite-UNIQUE constraints,
each inner Vec<String> listing the columns of one constraint.
Closes BUG-6.
indexes: Vec<Vec<String>>Mirrors Model::INDEXES. Each inner Vec<String> lists the
columns of one multi-column index. Closes BUG-7.
ordering: Vec<(String, bool)>Mirrors Model::ORDERING. Each tuple is (column, descending)
— descending == true lowers to ORDER BY col DESC. Closes
BUG-8.
m2m_relations: Vec<M2MRelation>Mirrors Model::M2M_RELATIONS. Many-to-many relations declared
on this model. The migration engine uses this to auto-generate
junction tables. Closes BUG-16.
soft_delete: boolMirrors Model::SOFT_DELETE (#[umbral(soft_delete)]). The
dynamic / annotate paths read this to auto-exclude
deleted_at IS NULL children from correlated counts and to
drive trash-aware admin views without re-reaching into the
typed trait. Shared enabler for gaps2 #35 + #39a.
app_label: StringThe app label (the owning plugin’s name), mirrors Model::APP_LABEL.
Sourced from #[umbral(plugin = "...")]; "app" when absent.
Authoritative for permission codenames (gaps2 #80g): replaces the
old table-name-split heuristic that collided distinct models. The
#[serde(default)] keeps pre-#80g snapshot JSON round-tripping.
Implementations§
Source§impl ModelMeta
impl ModelMeta
Trait Implementations§
Source§impl<'de> Deserialize<'de> for ModelMeta
impl<'de> Deserialize<'de> for ModelMeta
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>,
impl Eq for ModelMeta
impl StructuralPartialEq for ModelMeta
Auto Trait Implementations§
impl Freeze for ModelMeta
impl RefUnwindSafe for ModelMeta
impl Send for ModelMeta
impl Sync for ModelMeta
impl Unpin for ModelMeta
impl UnsafeUnpin for ModelMeta
impl UnwindSafe for ModelMeta
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
impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> DeserializeOwned for Twhere
T: for<'de> Deserialize<'de>,
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
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
impl<A, B, T> HttpServerConnExec<A, B> for Twhere
B: Body,
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> 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);