pub(super) struct AttrWrapper {
attrs: AttrVec,
start_pos: Option<u32>,
}
Expand description
A wrapper type to ensure that the parser handles outer attributes correctly. When we parse outer attributes, we need to ensure that we capture tokens for the attribute target. This allows us to perform cfg-expansion on a token stream before we invoke a derive proc-macro.
This wrapper prevents direct access to the underlying ast::AttrVec
.
Parsing code can only get access to the underlying attributes
by passing an AttrWrapper
to collect_tokens
.
This makes it difficult to accidentally construct an AST node
(which stores an ast::AttrVec
) without first collecting tokens.
This struct has its own module, to ensure that the parser code
cannot directly access the attrs
field.
Fields§
§attrs: AttrVec
§start_pos: Option<u32>
Implementations§
Source§impl AttrWrapper
impl AttrWrapper
pub(super) fn new(attrs: AttrVec, start_pos: u32) -> AttrWrapper
pub(super) fn empty() -> AttrWrapper
pub(super) fn take_for_recovery(self, psess: &ParseSess) -> AttrVec
Sourcepub(super) fn prepend_to_nt_inner(self, attrs: &mut AttrVec)
pub(super) fn prepend_to_nt_inner(self, attrs: &mut AttrVec)
Prepend self.attrs
to attrs
.
pub(super) fn is_empty(&self) -> bool
Trait Implementations§
Source§impl Clone for AttrWrapper
impl Clone for AttrWrapper
Source§fn clone(&self) -> AttrWrapper
fn clone(&self) -> AttrWrapper
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreAuto Trait Implementations§
impl DynSend for AttrWrapper
impl DynSync for AttrWrapper
impl Freeze for AttrWrapper
impl !RefUnwindSafe for AttrWrapper
impl !Send for AttrWrapper
impl !Sync for AttrWrapper
impl Unpin for AttrWrapper
impl !UnwindSafe for AttrWrapper
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T, R> CollectAndApply<T, R> for T
impl<T, R> CollectAndApply<T, R> for T
Source§impl<T> Filterable for T
impl<T> Filterable for T
Source§fn filterable(
self,
filter_name: &'static str,
) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>
fn filterable( self, filter_name: &'static str, ) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>
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> Pointable for T
impl<T> Pointable for T
Source§impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
Source§impl<I, T> UpcastFrom<I, T> for T
impl<I, T> UpcastFrom<I, T> for T
fn upcast_from(from: T, _tcx: I) -> T
Source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
Source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
Source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
impl<'a, T> Captures<'a> for Twhere
T: ?Sized,
impl<T> ErasedDestructor for Twhere
T: 'static,
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 16 bytes