darling_core

Trait FromMeta

Source
pub trait FromMeta: Sized {
    // Provided methods
    fn from_nested_meta(item: &NestedMeta) -> Result<Self> { ... }
    fn from_meta(item: &Meta) -> Result<Self> { ... }
    fn from_none() -> Option<Self> { ... }
    fn from_word() -> Result<Self> { ... }
    fn from_list(items: &[NestedMeta]) -> Result<Self> { ... }
    fn from_value(value: &Lit) -> Result<Self> { ... }
    fn from_expr(expr: &Expr) -> Result<Self> { ... }
    fn from_char(value: char) -> Result<Self> { ... }
    fn from_string(value: &str) -> Result<Self> { ... }
    fn from_bool(value: bool) -> Result<Self> { ... }
}
Expand description

Create an instance from an item in an attribute declaration.

§Implementing FromMeta

  • Do not take a dependency on the ident of the passed-in meta item. The ident will be set by the field name of the containing struct.
  • Implement only the from_* methods that you intend to support. The default implementations will return useful errors.

§Provided Implementations

§bool

  • Word with no value specified - becomes true.
  • As a boolean literal, e.g. foo = true.
  • As a string literal, e.g. foo = "true".

§char

  • As a char literal, e.g. foo = '#'.
  • As a string literal consisting of a single character, e.g. foo = "#".

§String

  • As a string literal, e.g. foo = "hello".
  • As a raw string literal, e.g. foo = r#"hello "world""#.

§Number

  • As a string literal, e.g. foo = "-25".
  • As an unquoted positive value, e.g. foo = 404. Negative numbers must be in quotation marks.

§()

  • Word with no value specified, e.g. foo. This is best used with Option. See darling::util::Flag for a more strongly-typed alternative.

§Option

  • Any format produces Some.

§Result<T, darling::Error>

  • Allows for fallible parsing; will populate the target field with the result of the parse attempt.

Provided Methods§

Source

fn from_nested_meta(item: &NestedMeta) -> Result<Self>

Source

fn from_meta(item: &Meta) -> Result<Self>

Create an instance from a syn::Meta by dispatching to the format-appropriate trait function. This generally should not be overridden by implementers.

§Error Spans

If this method is overridden and can introduce errors that weren’t passed up from other from_meta calls, the override must call with_span on the error using the item to make sure that the emitted diagnostic points to the correct location in source code.

Source

fn from_none() -> Option<Self>

When a field is omitted from a parent meta-item, from_none is used to attempt recovery before a missing field error is generated.

Most types should not override this method. darling already allows field-level missing-field recovery using #[darling(default)] and #[darling(default = "...")], and users who add a String field to their FromMeta-deriving struct would be surprised if they get back "" instead of a missing field error when that field is omitted.

The primary use-case for this is Option<T> fields gracefully handlling absence without needing #[darling(default)].

Source

fn from_word() -> Result<Self>

Create an instance from the presence of the word in the attribute with no additional options specified.

Source

fn from_list(items: &[NestedMeta]) -> Result<Self>

Create an instance from a list of nested meta items.

Source

fn from_value(value: &Lit) -> Result<Self>

Create an instance from a literal value of either foo = "bar" or foo("bar"). This dispatches to the appropriate method based on the type of literal encountered, and generally should not be overridden by implementers.

§Error Spans

If this method is overridden, the override must make sure to add value’s span information to the returned error by calling with_span(value) on the Error instance.

Source

fn from_expr(expr: &Expr) -> Result<Self>

Source

fn from_char(value: char) -> Result<Self>

Create an instance from a char literal in a value position.

Source

fn from_string(value: &str) -> Result<Self>

Create an instance from a string literal in a value position.

Source

fn from_bool(value: bool) -> Result<Self>

Create an instance from a bool literal in a value position.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementations on Foreign Types§

Source§

impl FromMeta for RenameRule

Source§

fn from_string(value: &str) -> Result<Self>

Source§

impl FromMeta for Meta

Source§

fn from_meta(value: &Meta) -> Result<Self>

Source§

impl FromMeta for Expr

Support for arbitrary expressions as values in a meta item.

For backwards-compatibility to versions of darling based on syn 1, string literals will be “unwrapped” and their contents will be parsed as an expression.

See util::parse_expr for functions to provide alternate parsing modes for this type.

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for Lit

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for Visibility

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for Type

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for bool

Source§

fn from_word() -> Result<Self>

Source§

fn from_bool(value: bool) -> Result<Self>

Source§

fn from_string(value: &str) -> Result<Self>

Source§

impl FromMeta for char

Source§

fn from_char(value: char) -> Result<Self>

Source§

fn from_string(s: &str) -> Result<Self>

Source§

impl FromMeta for f32

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for f64

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for i8

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for i16

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for i32

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for i64

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for i128

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for isize

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for u8

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for u16

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for u32

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for u64

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for u128

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for ()

Source§

impl FromMeta for usize

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for String

Source§

fn from_string(s: &str) -> Result<Self>

Source§

impl FromMeta for Vec<WherePredicate>

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for Vec<u8>

Parsing an unsigned integer array, i.e. example = "[1, 2, 3, 4]".

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for Vec<u16>

Parsing an unsigned integer array, i.e. example = "[1, 2, 3, 4]".

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for Vec<u32>

Parsing an unsigned integer array, i.e. example = "[1, 2, 3, 4]".

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for Vec<u64>

Parsing an unsigned integer array, i.e. example = "[1, 2, 3, 4]".

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for Vec<usize>

Parsing an unsigned integer array, i.e. example = "[1, 2, 3, 4]".

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for Vec<Literal>

Source§

fn from_list(items: &[NestedMeta]) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

impl FromMeta for Vec<LitBool>

Source§

fn from_list(items: &[NestedMeta]) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

impl FromMeta for Vec<LitByte>

Source§

fn from_list(items: &[NestedMeta]) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

impl FromMeta for Vec<LitByteStr>

Source§

fn from_list(items: &[NestedMeta]) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

impl FromMeta for Vec<LitChar>

Source§

fn from_list(items: &[NestedMeta]) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

impl FromMeta for Vec<LitFloat>

Source§

fn from_list(items: &[NestedMeta]) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

impl FromMeta for Vec<LitInt>

Source§

fn from_list(items: &[NestedMeta]) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

impl FromMeta for Vec<LitStr>

Source§

fn from_list(items: &[NestedMeta]) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

impl FromMeta for AtomicBool

Source§

fn from_meta(mi: &Meta) -> Result<Self>

Source§

impl FromMeta for PathBuf

Source§

fn from_string(s: &str) -> Result<Self>

Source§

impl FromMeta for Ident

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

impl FromMeta for Literal

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for ExprArray

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for ExprPath

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for TypeParam

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for WhereClause

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for LitBool

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for LitByte

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for LitByteStr

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for LitChar

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for LitFloat

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for LitInt

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for LitStr

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for Path

Parser for paths that supports both quote-wrapped and bare values.

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

fn from_expr(expr: &Expr) -> Result<Self>

Source§

impl FromMeta for TypeArray

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for TypeBareFn

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for TypeGroup

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for TypeImplTrait

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for TypeInfer

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for TypeMacro

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for TypeNever

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for TypeParen

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for TypePath

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for TypePtr

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for TypeReference

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for TypeSlice

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for TypeTraitObject

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for TypeTuple

Source§

fn from_string(value: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for NonZeroI8

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for NonZeroI16

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for NonZeroI32

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for NonZeroI64

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for NonZeroI128

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for NonZeroIsize

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for NonZeroU8

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for NonZeroU16

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for NonZeroU32

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for NonZeroU64

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for NonZeroU128

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl FromMeta for NonZeroUsize

Source§

fn from_string(s: &str) -> Result<Self>

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl<T: Parse, P: Parse> FromMeta for Punctuated<T, P>

Parsing support for punctuated. This attempts to preserve span information when available, but also supports parsing strings with the call site as the emitted span.

Source§

fn from_value(value: &Lit) -> Result<Self>

Source§

impl<T: FromMeta> FromMeta for Option<T>

Source§

fn from_none() -> Option<Self>

Source§

fn from_meta(item: &Meta) -> Result<Self>

Source§

impl<T: FromMeta> FromMeta for Result<T, Meta>

Parses the meta-item, and in case of error preserves a copy of the input for later analysis.

Source§

fn from_meta(item: &Meta) -> Result<Self>

Source§

impl<T: FromMeta> FromMeta for Box<T>

Source§

fn from_none() -> Option<Self>

Source§

fn from_list(items: &[NestedMeta]) -> Result<Self>

Source§

fn from_meta(item: &Meta) -> Result<Self>

Source§

impl<T: FromMeta> FromMeta for Rc<T>

Source§

fn from_none() -> Option<Self>

Source§

fn from_list(items: &[NestedMeta]) -> Result<Self>

Source§

fn from_meta(item: &Meta) -> Result<Self>

Source§

impl<T: FromMeta> FromMeta for Arc<T>

Source§

fn from_none() -> Option<Self>

Source§

fn from_list(items: &[NestedMeta]) -> Result<Self>

Source§

fn from_meta(item: &Meta) -> Result<Self>

Source§

impl<T: FromMeta> FromMeta for RefCell<T>

Source§

fn from_none() -> Option<Self>

Source§

fn from_list(items: &[NestedMeta]) -> Result<Self>

Source§

fn from_meta(item: &Meta) -> Result<Self>

Source§

impl<V: FromMeta, S: BuildHasher + Default> FromMeta for HashMap<String, V, S>

Source§

fn from_list(nested: &[NestedMeta]) -> Result<Self>

Source§

impl<V: FromMeta, S: BuildHasher + Default> FromMeta for HashMap<Ident, V, S>

Source§

fn from_list(nested: &[NestedMeta]) -> Result<Self>

Source§

impl<V: FromMeta, S: BuildHasher + Default> FromMeta for HashMap<Path, V, S>

Source§

fn from_list(nested: &[NestedMeta]) -> Result<Self>

Implementors§

Source§

impl FromMeta for Flag

Source§

impl FromMeta for IdentString

Source§

impl FromMeta for Ignored

Source§

impl FromMeta for PathList

Source§

impl<T: FromMeta> FromMeta for Override<T>

Parses a Meta. A bare word will produce Override::Inherit, while any value will be forwarded to T::from_meta.

Source§

impl<T: FromMeta> FromMeta for SpannedValue<T>

Source§

impl<T: FromMeta> FromMeta for WithOriginal<T, Meta>

Source§

impl<T: FromMeta> FromMeta for darling_core::error::Result<T>