FacetInner

Enum FacetInner 

Source
pub enum FacetInner {
Show 17 variants Sensitive(KSensitive), Invariants(InvariantInner), Opaque(KOpaque), DenyUnknownFields(KDenyUnknownFields), DefaultEquals(DefaultEqualsInner), Default(KDefault), Transparent(KTransparent), RenameAll(RenameAllInner), Rename(RenameInner), Flatten(FlattenInner), Child(ChildInner), SkipSerializing(SkipSerializingInner), SkipSerializingIf(SkipSerializingIfInner), TypeTag(TypeTagInner), DeserializeWith(DeserializeWithInner), SerializeWith(SerializeWithInner), Arbitrary(VerbatimUntil<Comma>),
}
Expand description

Represents the inner content of a facet attribute.

Variants§

§

Sensitive(KSensitive)

A sensitive attribute that specifies sensitivity information.

§

Invariants(InvariantInner)

An invariants attribute that specifies invariants for the type.

§

Opaque(KOpaque)

An opaque attribute that specifies opaque information.

§

DenyUnknownFields(KDenyUnknownFields)

A deny_unknown_fields attribute that specifies whether unknown fields are allowed.

§

DefaultEquals(DefaultEqualsInner)

A default attribute with an explicit value (#[facet(default = “myfunc”)])

§

Default(KDefault)

A default attribute with no explicit value (#[facet(default)])

§

Transparent(KTransparent)

A transparent attribute for containers

§

RenameAll(RenameAllInner)

A rename_all attribute that specifies a case conversion for all fields/variants (#[facet(rename_all = “camelCase”)])

§

Rename(RenameInner)

A rename attribute that specifies a custom name for a field/variant (#[facet(rename = “custom_name”)])

§

Flatten(FlattenInner)

A flatten attribute that marks a field to be flattened into the parent structure

§

Child(ChildInner)

A child attribute that marks a field as a child node

§

SkipSerializing(SkipSerializingInner)

A skip_serializing attribute that specifies whether a field should be skipped during serialization.

§

SkipSerializingIf(SkipSerializingIfInner)

A skip_serializing_if attribute that specifies a condition for skipping serialization.

§

TypeTag(TypeTagInner)

A type_tag attribute that specifies the identifying tag for self describing formats

§

DeserializeWith(DeserializeWithInner)

A function to define how to deserializize the target

§

SerializeWith(SerializeWithInner)

A function to define how to serializize the target

§

Arbitrary(VerbatimUntil<Comma>)

Any other attribute represented as a sequence of token trees.

Trait Implementations§

Source§

impl Debug for FacetInner

Source§

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

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

impl Parser for FacetInner

Source§

fn parser(tokens: &mut TokenIter) -> Result<Self>

The actual parsing function that must be implemented. This mutates the tokens iterator directly. It should not be called from user code except for implementing parsers itself and then only when the rules below are followed. Read more
Source§

impl ToTokens for FacetInner

Source§

fn to_tokens(&self, tokens: &mut TokenStream)

Write &self to the given TokenStream. Read more
Source§

fn to_token_iter(&self) -> TokenIter

Convert &self into a TokenIter object.
Source§

fn into_token_iter(self) -> TokenIter
where Self: Sized,

Convert self into a TokenIter object.
Source§

fn to_token_stream(&self) -> TokenStream

Convert &self into a TokenStream object.
Source§

fn into_token_stream(self) -> TokenStream
where Self: Sized,

Convert self into a TokenStream object.
Source§

fn tokens_to_string(&self) -> String

Convert &self into a String object. This is mostly used in the test suite to compare the outputs. When the input is a &str then this parses it and returns a normalized String.

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> DynamicTokens for T
where T: Any + ToTokens + Debug,

Source§

fn as_any(&self) -> &(dyn Any + 'static)

Upcasts &DynamicTokens to &dyn Any. This allows us to stay backward compatible with older rust. Rust 1.86 implements upcast coercion.
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> Parse for T
where T: Parser,

Source§

fn parse(tokens: &mut TokenIter) -> Result<Self, Error>

This is the user facing API to parse grammatical entities. Calls a parser() within a transaction. Commits changes on success and returns the parsed value. Read more
Source§

fn parse_all(tokens: &mut TokenIter) -> Result<Self, Error>

Exhaustive parsing within a transaction. This is a convenience method that implies a EndOfStream at the end. Thus it will error if parsing is not exhaustive. Read more
Source§

fn parse_with<T>( tokens: &mut TokenIter, f: impl FnOnce(Self, &mut TokenIter) -> Result<T, Error>, ) -> Result<T, Error>

Parse a value in a transaction, pass it to a FnOnce(Self, &mut TokenIter) -> Result<T> closure which creates a new result or returns an Error. 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.