Enum hir_expand::MacroCallKind

source ·
pub enum MacroCallKind {
    FnLike {
        ast_id: AstId<MacroCall>,
        expand_to: ExpandTo,
        eager: Option<Arc<EagerCallInfo>>,
    },
    Derive {
        ast_id: AstId<Adt>,
        derive_attr_index: AttrId,
        derive_index: u32,
        derive_macro_id: MacroCallId,
    },
    Attr {
        ast_id: AstId<Item>,
        attr_args: Option<Arc<Subtree>>,
        invoc_attr_index: AttrId,
    },
}

Variants§

§

FnLike

Fields

§ast_id: AstId<MacroCall>
§expand_to: ExpandTo
§eager: Option<Arc<EagerCallInfo>>

Some if this is a macro call for an eager macro. Note that this is None for the eager input macro file.

§

Derive

Fields

§ast_id: AstId<Adt>
§derive_attr_index: AttrId

Syntactical index of the invoking #[derive] attribute.

Outer attributes are counted first, then inner attributes. This does not support out-of-line modules, which may have attributes spread across 2 files!

§derive_index: u32

Index of the derive macro in the derive attribute

§derive_macro_id: MacroCallId

The “parent” macro call. We will resolve the same token tree for all derive macros in the same derive attribute.

§

Attr

Fields

§ast_id: AstId<Item>
§attr_args: Option<Arc<Subtree>>
§invoc_attr_index: AttrId

Syntactical index of the invoking #[attribute].

Outer attributes are counted first, then inner attributes. This does not support out-of-line modules, which may have attributes spread across 2 files!

Implementations§

source§

impl MacroCallKind

source

pub fn file_id(&self) -> HirFileId

Returns the file containing the macro invocation.

source

pub fn erased_ast_id(&self) -> ErasedFileAstId

source

pub fn original_call_range_with_body(self, db: &dyn ExpandDatabase) -> FileRange

Returns the original file range that best describes the location of this macro call.

Unlike MacroCallKind::original_call_range, this also spans the item of attributes and derives.

source

pub fn original_call_range(self, db: &dyn ExpandDatabase) -> FileRange

Returns the original file range that best describes the location of this macro call.

Here we try to roughly match what rustc does to improve diagnostics: fn-like macros get the whole ast::MacroCall, attribute macros get the attribute’s range, and derives get only the specific derive that is being referred to.

Trait Implementations§

source§

impl Clone for MacroCallKind

source§

fn clone(&self) -> MacroCallKind

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for MacroCallKind

source§

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

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

impl Hash for MacroCallKind

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl PartialEq for MacroCallKind

source§

fn eq(&self, other: &MacroCallKind) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Eq for MacroCallKind

source§

impl StructuralPartialEq for MacroCallKind

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> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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.

§

impl<T> IntoBox<dyn Any> for T
where T: Any,

§

fn into_box(self) -> Box<dyn Any>

Convert self into the appropriate boxed form.
§

impl<T> IntoBox<dyn Any + Send> for T
where T: Any + Send,

§

fn into_box(self) -> Box<dyn Any + Send>

Convert self into the appropriate boxed form.
§

impl<T> IntoBox<dyn Any + Sync + Send> for T
where T: Any + Send + Sync,

§

fn into_box(self) -> Box<dyn Any + Sync + Send>

Convert self into the appropriate boxed form.
source§

impl<T> IntoEither for T

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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 more
source§

impl<T> ToOwned for T
where T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more