diff options
| author | Eric Huss <eric@huss.org> | 2021-09-17 13:08:56 -0700 |
|---|---|---|
| committer | Eric Huss <eric@huss.org> | 2021-09-25 09:03:15 -0700 |
| commit | 75f058dbfd1c02daa191efb6eb53dc91fda8add6 (patch) | |
| tree | 8348ab28c41ab996e2b534c28aa6d3a79d21d6b0 /compiler/rustc_interface/src/util.rs | |
| parent | 5f8c571e50f1e0e98bb225e1dc909e73251a69be (diff) | |
| download | rust-75f058dbfd1c02daa191efb6eb53dc91fda8add6.tar.gz rust-75f058dbfd1c02daa191efb6eb53dc91fda8add6.zip | |
Check for macros in built-in attributes that don't support them.
Diffstat (limited to 'compiler/rustc_interface/src/util.rs')
| -rw-r--r-- | compiler/rustc_interface/src/util.rs | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/compiler/rustc_interface/src/util.rs b/compiler/rustc_interface/src/util.rs index 24975702b87..a1d1b63c8fa 100644 --- a/compiler/rustc_interface/src/util.rs +++ b/compiler/rustc_interface/src/util.rs @@ -10,6 +10,7 @@ use rustc_errors::registry::Registry; use rustc_metadata::dynamic_lib::DynamicLibrary; #[cfg(parallel_compiler)] use rustc_middle::ty::tls; +use rustc_parse::validate_attr; #[cfg(parallel_compiler)] use rustc_query_impl::QueryCtxt; use rustc_resolve::{self, Resolver}; @@ -475,7 +476,7 @@ pub fn get_codegen_sysroot( } pub(crate) fn check_attr_crate_type( - _sess: &Session, + sess: &Session, attrs: &[ast::Attribute], lint_buffer: &mut LintBuffer, ) { @@ -515,6 +516,19 @@ pub(crate) fn check_attr_crate_type( ); } } + } else { + // This is here mainly to check for using a macro, such as + // #![crate_type = foo!()]. That is not supported since the + // crate type needs to be known very early in compilation long + // before expansion. Otherwise, validation would normally be + // caught in AstValidator (via `check_builtin_attribute`), but + // by the time that runs the macro is expanded, and it doesn't + // give an error. + validate_attr::emit_fatal_malformed_builtin_attribute( + &sess.parse_sess, + a, + sym::crate_type, + ); } } } |
