[−][src]Struct syn::Attribute
An attribute like #[repr(transparent)]
.
This type is available if Syn is built with the "derive"
or "full"
feature.
Syntax
Rust has six types of attributes.
- Outer attributes like
#[repr(transparent)]
. These appear outside or in front of the item they describe. - Inner attributes like
#![feature(proc_macro)]
. These appear inside of the item they describe, usually a module. - Outer doc comments like
/// # Example
. - Inner doc comments like
//! Please file an issue
. - Outer block comments
/** # Example */
. - Inner block comments
/*! Please file an issue */
.
The style
field of type AttrStyle
distinguishes whether an attribute
is outer or inner. Doc comments and block comments are promoted to
attributes, as this is how they are processed by the compiler and by
macro_rules!
macros.
The path
field gives the possibly colon-delimited path against which
the attribute is resolved. It is equal to "doc"
for desugared doc
comments. The tts
field contains the rest of the attribute body as
tokens.
#[derive(Copy)] #[crate::precondition x < 5]
^^^^^^~~~~~~ ^^^^^^^^^^^^^^^^^^^ ~~~~~
path tts path tts
Use the parse_meta
method to try parsing the tokens of an attribute
into the structured representation that is used by convention across
most Rust libraries.
Parsing
This type does not implement the Parse
trait and thus cannot be
parsed directly by ParseStream::parse
. Instead use
ParseStream::call
with one of the two parser functions
Attribute::parse_outer
or Attribute::parse_inner
depending on
which you intend to parse.
#[macro_use] extern crate syn; use syn::{Attribute, Ident}; use syn::parse::{Parse, ParseStream, Result}; // Parses a unit struct with attributes. // // #[path = "s.tmpl"] // struct S; struct UnitStruct { attrs: Vec<Attribute>, struct_token: Token![struct], name: Ident, semi_token: Token![;], } impl Parse for UnitStruct { fn parse(input: ParseStream) -> Result<Self> { Ok(UnitStruct { attrs: input.call(Attribute::parse_outer)?, struct_token: input.parse()?, name: input.parse()?, semi_token: input.parse()?, }) } }
Fields
pound_token: Pound
style: AttrStyle
bracket_token: Bracket
path: Path
tts: TokenStream
Methods
impl Attribute
[src]
[−]
impl Attribute
pub fn parse_meta(&self) -> Result<Meta>
[src]
[−]
pub fn parse_meta(&self) -> Result<Meta>
Parses the tokens after the path as a Meta
if
possible.
pub fn parse_outer(input: ParseStream) -> Result<Vec<Self>>
[src]
[−]
pub fn parse_outer(input: ParseStream) -> Result<Vec<Self>>
Parses zero or more outer attributes from the stream.
This function is available if Syn is built with the "parsing"
feature.
pub fn parse_inner(input: ParseStream) -> Result<Vec<Self>>
[src]
[−]
pub fn parse_inner(input: ParseStream) -> Result<Vec<Self>>
Parses zero or more inner attributes from the stream.
This function is available if Syn is built with the "parsing"
feature.
Trait Implementations
impl PartialEq<Attribute> for Attribute
[src]
[+]
impl PartialEq<Attribute> for Attribute
impl Clone for Attribute
[src]
[+]
impl Clone for Attribute
impl Eq for Attribute
[src]
impl Eq for Attribute
impl Hash for Attribute
[src]
[+]
impl Hash for Attribute
impl Debug for Attribute
[src]
[+]
impl Debug for Attribute
impl ToTokens for Attribute
[src]
[+]
impl ToTokens for Attribute
Auto Trait Implementations
Blanket Implementations
impl<T> Spanned for T where
T: ToTokens,
[src]
[−]
impl<T> Spanned for T where
T: ToTokens,
impl<T> From for T
[src]
[−]
impl<T> From for T
impl<T, U> Into for T where
U: From<T>,
[src]
[−]
impl<T, U> Into for T where
U: From<T>,
impl<T> ToOwned for T where
T: Clone,
[src]
[−]
impl<T> ToOwned for T where
T: Clone,
impl<T, U> TryFrom for T where
T: From<U>,
[src]
[−]
impl<T, U> TryFrom for T where
T: From<U>,
type Error = !
try_from
)The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
[−]
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
impl<T> Borrow for T where
T: ?Sized,
[src]
[−]
impl<T> Borrow for T where
T: ?Sized,
impl<T> Any for T where
T: 'static + ?Sized,
[src]
[−]
impl<T> Any for T where
T: 'static + ?Sized,
fn get_type_id(&self) -> TypeId
[src]
[−]
fn get_type_id(&self) -> TypeId
impl<T> BorrowMut for T where
T: ?Sized,
[src]
[−]
impl<T> BorrowMut for T where
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
[−]
fn borrow_mut(&mut self) -> &mut T
impl<T, U> TryInto for T where
U: TryFrom<T>,
[src]
[−]
impl<T, U> TryInto for T where
U: TryFrom<T>,