pub struct SpannedValue<T> {
value: T,
span: Span,
}
Expand description
A value and an associated position in source code. The main use case for this is
to preserve position information to emit warnings from proc macros. You can use
a SpannedValue<T>
as a field in any struct that implements or derives any of
darling
’s core traits.
To access the underlying value, use the struct’s Deref
implementation.
§Defaulting
This type is meant to be used in conjunction with attribute-extracted options,
but the user may not always explicitly set those options in their source code.
In this case, using Default::default()
will create an instance which points
to Span::call_site()
.
Fields§
§value: T
§span: Span
Implementations§
source§impl<T> SpannedValue<T>
impl<T> SpannedValue<T>
Trait Implementations§
source§impl<T> AsRef<T> for SpannedValue<T>
impl<T> AsRef<T> for SpannedValue<T>
source§impl<T> Clone for SpannedValue<T>where
T: Clone,
impl<T> Clone for SpannedValue<T>where
T: Clone,
source§fn clone(&self) -> SpannedValue<T>
fn clone(&self) -> SpannedValue<T>
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl<T> Debug for SpannedValue<T>where
T: Debug,
impl<T> Debug for SpannedValue<T>where
T: Debug,
source§impl<T> Default for SpannedValue<T>where
T: Default,
impl<T> Default for SpannedValue<T>where
T: Default,
source§fn default() -> SpannedValue<T>
fn default() -> SpannedValue<T>
Returns the “default value” for a type. Read more
source§impl<T> Deref for SpannedValue<T>
impl<T> Deref for SpannedValue<T>
source§impl<T> DerefMut for SpannedValue<T>
impl<T> DerefMut for SpannedValue<T>
source§impl<T> From<T> for SpannedValue<T>where
T: Spanned,
impl<T> From<T> for SpannedValue<T>where
T: Spanned,
source§fn from(value: T) -> SpannedValue<T>
fn from(value: T) -> SpannedValue<T>
Converts to this type from the input type.
source§impl<T> FromDeriveInput for SpannedValue<T>where
T: FromDeriveInput,
impl<T> FromDeriveInput for SpannedValue<T>where
T: FromDeriveInput,
source§fn from_derive_input(value: &DeriveInput) -> Result<SpannedValue<T>, Error>
fn from_derive_input(value: &DeriveInput) -> Result<SpannedValue<T>, Error>
Create an instance from
syn::DeriveInput
, or return an error.source§impl<T> FromField for SpannedValue<T>where
T: FromField,
impl<T> FromField for SpannedValue<T>where
T: FromField,
fn from_field(value: &Field) -> Result<SpannedValue<T>, Error>
source§impl<T> FromGenericParam for SpannedValue<T>where
T: FromGenericParam,
impl<T> FromGenericParam for SpannedValue<T>where
T: FromGenericParam,
fn from_generic_param(value: &GenericParam) -> Result<SpannedValue<T>, Error>
source§impl<T> FromGenerics for SpannedValue<T>where
T: FromGenerics,
impl<T> FromGenerics for SpannedValue<T>where
T: FromGenerics,
fn from_generics(value: &Generics) -> Result<SpannedValue<T>, Error>
source§impl<T> FromMeta for SpannedValue<T>where
T: FromMeta,
impl<T> FromMeta for SpannedValue<T>where
T: FromMeta,
source§fn from_meta(item: &Meta) -> Result<SpannedValue<T>, Error>
fn from_meta(item: &Meta) -> Result<SpannedValue<T>, Error>
Create an instance from a
syn::Meta
by dispatching to the format-appropriate
trait function. This generally should not be overridden by implementers. Read morefn from_nested_meta(item: &NestedMeta) -> Result<Self, Error>
source§fn from_none() -> Option<Self>
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. Read moresource§fn from_word() -> Result<Self, Error>
fn from_word() -> Result<Self, Error>
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, Error>
fn from_list(items: &[NestedMeta]) -> Result<Self, Error>
Create an instance from a list of nested meta items.
source§fn from_value(value: &Lit) -> Result<Self, Error>
fn from_value(value: &Lit) -> Result<Self, Error>
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. Read morefn from_expr(expr: &Expr) -> Result<Self, Error>
source§fn from_char(value: char) -> Result<Self, Error>
fn from_char(value: char) -> Result<Self, Error>
Create an instance from a char literal in a value position.
source§impl<T> FromTypeParam for SpannedValue<T>where
T: FromTypeParam,
impl<T> FromTypeParam for SpannedValue<T>where
T: FromTypeParam,
fn from_type_param(value: &TypeParam) -> Result<SpannedValue<T>, Error>
source§impl<T> FromVariant for SpannedValue<T>where
T: FromVariant,
impl<T> FromVariant for SpannedValue<T>where
T: FromVariant,
source§fn from_variant(value: &Variant) -> Result<SpannedValue<T>, Error>
fn from_variant(value: &Variant) -> Result<SpannedValue<T>, Error>
Create an instance from
syn::Variant
, or return an error.impl<T> Copy for SpannedValue<T>where
T: Copy,
Auto Trait Implementations§
impl<T> Freeze for SpannedValue<T>where
T: Freeze,
impl<T> RefUnwindSafe for SpannedValue<T>where
T: RefUnwindSafe,
impl<T> !Send for SpannedValue<T>
impl<T> !Sync for SpannedValue<T>
impl<T> Unpin for SpannedValue<T>where
T: Unpin,
impl<T> UnwindSafe for SpannedValue<T>where
T: UnwindSafe,
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
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)