rust/compiler/rustc_expand/src/mbe
Aaron Hill ddd544856e
Compute a better lint_node_id during expansion
When we need to emit a lint at a macro invocation, we currently use the
`NodeId` of its parent definition (e.g. the enclosing function). This
means that any `#[allow]` / `#[deny]` attributes placed 'closer' to the
macro (e.g. on an enclosing block or statement) will have no effect.

This commit computes a better `lint_node_id` in `InvocationCollector`.
When we visit/flat_map an AST node, we assign it a `NodeId` (earlier
than we normally would), and store than `NodeId` in current
`ExpansionData`. When we collect a macro invocation, the current
`lint_node_id` gets cloned along with our `ExpansionData`, allowing it
to be used if we need to emit a lint later on.

This improves the handling of `#[allow]` / `#[deny]` for
`SEMICOLON_IN_EXPRESSIONS_FROM_MACROS` and some `asm!`-related lints.
The 'legacy derive helpers' lint retains its current behavior
(I've inlined the now-removed `lint_node_id` function), since
there isn't an `ExpansionData` readily available.
2021-07-17 23:03:56 -05:00
..
macro_check.rs Use iter::zip in compiler/ 2021-03-26 09:32:31 -07:00
macro_parser.rs Include macro name in 'local ambiguity' error 2021-06-07 20:17:48 -05:00
macro_rules.rs Compute a better lint_node_id during expansion 2021-07-17 23:03:56 -05:00
quoted.rs Use correct edition when parsing :pat matchers 2021-05-29 13:09:14 -05:00
transcribe.rs Use LocalExpnId where possible. 2021-07-17 19:41:02 +02:00