mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 21:54:42 +00:00
Fix name resolution of shadowed builtin macro
This commit is contained in:
parent
8db40df2a3
commit
1cd707e693
3 changed files with 33 additions and 1 deletions
|
@ -1606,7 +1606,11 @@ impl ModCollector<'_, '_> {
|
|||
|
||||
// Prelude module is always considered to be `#[macro_use]`.
|
||||
if let Some((prelude_module, _use)) = self.def_collector.def_map.prelude {
|
||||
if prelude_module.krate != krate && is_crate_root {
|
||||
// Don't insert macros from the prelude into blocks, as they can be shadowed by other macros.
|
||||
if prelude_module.krate != krate
|
||||
&& is_crate_root
|
||||
&& self.def_collector.def_map.block.is_none()
|
||||
{
|
||||
cov_mark::hit!(prelude_is_macro_use);
|
||||
self.def_collector.import_macros_from_extern_crate(
|
||||
prelude_module.krate,
|
||||
|
|
|
@ -2731,4 +2731,23 @@ fn main() {
|
|||
"#,
|
||||
)
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn shadow_builtin_macro() {
|
||||
check(
|
||||
r#"
|
||||
//- minicore: column
|
||||
//- /a.rs crate:a
|
||||
#[macro_export]
|
||||
macro_rules! column { () => {} }
|
||||
// ^^^^^^
|
||||
|
||||
//- /b.rs crate:b deps:a
|
||||
use a::column;
|
||||
fn foo() {
|
||||
$0column!();
|
||||
}
|
||||
"#,
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -63,6 +63,7 @@
|
|||
//! unsize: sized
|
||||
//! todo: panic
|
||||
//! unimplemented: panic
|
||||
//! column:
|
||||
|
||||
#![rustc_coherence_is_core]
|
||||
|
||||
|
@ -1617,6 +1618,14 @@ pub mod error {
|
|||
}
|
||||
// endregion:error
|
||||
|
||||
// region:column
|
||||
#[rustc_builtin_macro]
|
||||
#[macro_export]
|
||||
macro_rules! column {
|
||||
() => {};
|
||||
}
|
||||
// endregion:column
|
||||
|
||||
pub mod prelude {
|
||||
pub mod v1 {
|
||||
pub use crate::{
|
||||
|
|
Loading…
Reference in a new issue