From 05db5a269868c11a0d3916665a478962d4648a6b Mon Sep 17 00:00:00 2001 From: memoryruins Date: Fri, 11 Oct 2019 16:36:50 -0400 Subject: [PATCH 1/2] Report lint in external macros --- src/librustc/lint/builtin.rs | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/librustc/lint/builtin.rs b/src/librustc/lint/builtin.rs index 5ca474a8b1d91..983e3a9922ec2 100644 --- a/src/librustc/lint/builtin.rs +++ b/src/librustc/lint/builtin.rs @@ -21,7 +21,8 @@ declare_lint! { declare_lint! { pub CONST_ERR, Deny, - "constant evaluation detected erroneous expression" + "constant evaluation detected erroneous expression", + report_in_external_macro: true } declare_lint! { From 95a65cd1e3d0242339d71326cfdd638e869a37d6 Mon Sep 17 00:00:00 2001 From: memoryruins Date: Fri, 11 Oct 2019 17:13:38 -0400 Subject: [PATCH 2/2] Add regression test for CONST_ERR lints in extern macros --- src/test/ui/consts/auxiliary/external_macro.rs | 14 ++++++++++++++ .../ui/consts/const-external-macro-const-err.rs | 13 +++++++++++++ .../consts/const-external-macro-const-err.stderr | 11 +++++++++++ 3 files changed, 38 insertions(+) create mode 100644 src/test/ui/consts/auxiliary/external_macro.rs create mode 100644 src/test/ui/consts/const-external-macro-const-err.rs create mode 100644 src/test/ui/consts/const-external-macro-const-err.stderr diff --git a/src/test/ui/consts/auxiliary/external_macro.rs b/src/test/ui/consts/auxiliary/external_macro.rs new file mode 100644 index 0000000000000..d260634c9963b --- /dev/null +++ b/src/test/ui/consts/auxiliary/external_macro.rs @@ -0,0 +1,14 @@ +#![feature(allow_internal_unstable)] + +// Macro to help ensure CONST_ERR lint errors +// are not silenced in external macros. +// https://github.com/rust-lang/rust/issues/65300 + +#[macro_export] +#[allow_internal_unstable(type_ascription)] +macro_rules! static_assert { + ($test:expr) => { + #[allow(dead_code)] + const _: () = [()][!($test: bool) as usize]; + } +} diff --git a/src/test/ui/consts/const-external-macro-const-err.rs b/src/test/ui/consts/const-external-macro-const-err.rs new file mode 100644 index 0000000000000..616d24f4a7bcf --- /dev/null +++ b/src/test/ui/consts/const-external-macro-const-err.rs @@ -0,0 +1,13 @@ +// edition:2018 +// aux-build:external_macro.rs + +// Ensure that CONST_ERR lint errors +// are not silenced in external macros. +// https://github.com/rust-lang/rust/issues/65300 + +extern crate external_macro; +use external_macro::static_assert; + +fn main() { + static_assert!(2 + 2 == 5); //~ ERROR +} diff --git a/src/test/ui/consts/const-external-macro-const-err.stderr b/src/test/ui/consts/const-external-macro-const-err.stderr new file mode 100644 index 0000000000000..237c4d792c9ea --- /dev/null +++ b/src/test/ui/consts/const-external-macro-const-err.stderr @@ -0,0 +1,11 @@ +error: any use of this value will cause an error + --> $DIR/const-external-macro-const-err.rs:12:5 + | +LL | static_assert!(2 + 2 == 5); + | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ index out of bounds: the len is 1 but the index is 1 + | + = note: `#[deny(const_err)]` on by default + = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) + +error: aborting due to previous error +