Make sure #[rustc_doc_only_macro]
and other rustc attributes are registered
This commit is contained in:
parent
3467e2120c
commit
0ffb6438a6
25 changed files with 133 additions and 191 deletions
|
@ -74,6 +74,7 @@
|
|||
#![feature(concat_idents)]
|
||||
#![feature(const_fn)]
|
||||
#![feature(const_fn_union)]
|
||||
#![feature(custom_inner_attributes)]
|
||||
#![feature(doc_cfg)]
|
||||
#![feature(doc_spotlight)]
|
||||
#![feature(extern_types)]
|
||||
|
|
|
@ -323,21 +323,13 @@ impl<'a> Resolver<'a> {
|
|||
let features = self.session.features_untracked();
|
||||
if attr_kind == NonMacroAttrKind::Custom {
|
||||
assert!(path.segments.len() == 1);
|
||||
let name = path.segments[0].ident.as_str();
|
||||
if name.starts_with("rustc_") {
|
||||
if !features.rustc_attrs {
|
||||
let msg = "unless otherwise specified, attributes with the prefix \
|
||||
`rustc_` are reserved for internal compiler diagnostics";
|
||||
self.report_unknown_attribute(path.span, &name, msg,
|
||||
sym::rustc_attrs);
|
||||
}
|
||||
} else if !features.custom_attribute {
|
||||
if !features.custom_attribute {
|
||||
let msg = format!("The attribute `{}` is currently unknown to the \
|
||||
compiler and may have meaning added to it in the \
|
||||
future", path);
|
||||
self.report_unknown_attribute(
|
||||
path.span,
|
||||
&name,
|
||||
&path.segments[0].ident.as_str(),
|
||||
&msg,
|
||||
sym::custom_attribute,
|
||||
);
|
||||
|
|
|
@ -1525,9 +1525,7 @@ impl<'feat> ExpansionConfig<'feat> {
|
|||
}
|
||||
|
||||
fn enable_custom_inner_attributes(&self) -> bool {
|
||||
self.features.map_or(false, |features| {
|
||||
features.custom_inner_attributes || features.custom_attribute || features.rustc_attrs
|
||||
})
|
||||
self.features.map_or(false, |features| features.custom_inner_attributes)
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -1290,6 +1290,18 @@ pub const BUILTIN_ATTRIBUTES: &[BuiltinAttribute] = &[
|
|||
attribute is just used for rustc unit \
|
||||
tests and will never be stable",
|
||||
cfg_fn!(rustc_attrs))),
|
||||
(sym::rustc_dump_env_program_clauses, Whitelisted, template!(Word), Gated(Stability::Unstable,
|
||||
sym::rustc_attrs,
|
||||
"the `#[rustc_dump_env_program_clauses]` \
|
||||
attribute is just used for rustc unit \
|
||||
tests and will never be stable",
|
||||
cfg_fn!(rustc_attrs))),
|
||||
(sym::rustc_object_lifetime_default, Whitelisted, template!(Word), Gated(Stability::Unstable,
|
||||
sym::rustc_attrs,
|
||||
"the `#[rustc_object_lifetime_default]` \
|
||||
attribute is just used for rustc unit \
|
||||
tests and will never be stable",
|
||||
cfg_fn!(rustc_attrs))),
|
||||
(sym::rustc_test_marker, Normal, template!(Word), Gated(Stability::Unstable,
|
||||
sym::rustc_attrs,
|
||||
"the `#[rustc_test_marker]` attribute \
|
||||
|
@ -1351,6 +1363,26 @@ pub const BUILTIN_ATTRIBUTES: &[BuiltinAttribute] = &[
|
|||
"internal implementation detail",
|
||||
cfg_fn!(rustc_attrs))),
|
||||
|
||||
(sym::rustc_allocator_nounwind, Whitelisted, template!(Word), Gated(Stability::Unstable,
|
||||
sym::rustc_attrs,
|
||||
"internal implementation detail",
|
||||
cfg_fn!(rustc_attrs))),
|
||||
|
||||
(sym::rustc_doc_only_macro, Whitelisted, template!(Word), Gated(Stability::Unstable,
|
||||
sym::rustc_attrs,
|
||||
"internal implementation detail",
|
||||
cfg_fn!(rustc_attrs))),
|
||||
|
||||
(sym::rustc_promotable, Whitelisted, template!(Word), Gated(Stability::Unstable,
|
||||
sym::rustc_attrs,
|
||||
"internal implementation detail",
|
||||
cfg_fn!(rustc_attrs))),
|
||||
|
||||
(sym::rustc_allow_const_fn_ptr, Whitelisted, template!(Word), Gated(Stability::Unstable,
|
||||
sym::rustc_attrs,
|
||||
"internal implementation detail",
|
||||
cfg_fn!(rustc_attrs))),
|
||||
|
||||
(sym::rustc_dummy, Normal, template!(Word /* doesn't matter*/), Gated(Stability::Unstable,
|
||||
sym::rustc_attrs,
|
||||
"used by the test suite",
|
||||
|
@ -1647,19 +1679,13 @@ impl<'a> Context<'a> {
|
|||
return;
|
||||
}
|
||||
}
|
||||
if !attr::is_known(attr) {
|
||||
if attr.name_or_empty().as_str().starts_with("rustc_") {
|
||||
let msg = "unless otherwise specified, attributes with the prefix `rustc_` \
|
||||
are reserved for internal compiler diagnostics";
|
||||
gate_feature!(self, rustc_attrs, attr.span, msg);
|
||||
} else if !is_macro {
|
||||
// Only run the custom attribute lint during regular feature gate
|
||||
// checking. Macro gating runs before the plugin attributes are
|
||||
// registered, so we skip this in that case.
|
||||
let msg = format!("The attribute `{}` is currently unknown to the compiler and \
|
||||
may have meaning added to it in the future", attr.path);
|
||||
gate_feature!(self, custom_attribute, attr.span, &msg);
|
||||
}
|
||||
if !is_macro && !attr::is_known(attr) {
|
||||
// Only run the custom attribute lint during regular feature gate
|
||||
// checking. Macro gating runs before the plugin attributes are
|
||||
// registered, so we skip this in that case.
|
||||
let msg = format!("The attribute `{}` is currently unknown to the compiler and \
|
||||
may have meaning added to it in the future", attr.path);
|
||||
gate_feature!(self, custom_attribute, attr.span, &msg);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -2,7 +2,8 @@
|
|||
// ignore-stage1
|
||||
// compile-flags: -D crate-not-okay
|
||||
|
||||
#![feature(plugin, rustc_attrs)]
|
||||
#![feature(plugin, custom_attribute, custom_inner_attributes)]
|
||||
|
||||
#![plugin(lint_for_crate)]
|
||||
#![rustc_crate_okay]
|
||||
#![rustc_crate_blue]
|
||||
|
@ -10,4 +11,4 @@
|
|||
#![rustc_crate_grey]
|
||||
#![rustc_crate_green]
|
||||
|
||||
pub fn main() { }
|
||||
fn main() {}
|
||||
|
|
|
@ -1,52 +0,0 @@
|
|||
#![allow(unused_attributes)]
|
||||
|
||||
// This test ensures we can attach attributes to the formals in all
|
||||
// places where generic parameter lists occur, assuming appropriate
|
||||
// feature gates are enabled.
|
||||
//
|
||||
// (We are prefixing all tested features with `rustc_`, to ensure that
|
||||
// the attributes themselves won't be rejected by the compiler when
|
||||
// using `rustc_attrs` feature. There is a separate compile-fail/ test
|
||||
// ensuring that the attribute feature-gating works in this context.)
|
||||
|
||||
#![feature(rustc_attrs)]
|
||||
#![allow(dead_code)]
|
||||
|
||||
struct StLt<#[rustc_lt_struct] 'a>(&'a u32);
|
||||
struct StTy<#[rustc_ty_struct] I>(I);
|
||||
|
||||
enum EnLt<#[rustc_lt_enum] 'b> { A(&'b u32), B }
|
||||
enum EnTy<#[rustc_ty_enum] J> { A(J), B }
|
||||
|
||||
trait TrLt<#[rustc_lt_trait] 'c> { fn foo(&self, _: &'c [u32]) -> &'c u32; }
|
||||
trait TrTy<#[rustc_ty_trait] K> { fn foo(&self, _: K); }
|
||||
|
||||
type TyLt<#[rustc_lt_type] 'd> = &'d u32;
|
||||
type TyTy<#[rustc_ty_type] L> = (L, );
|
||||
|
||||
impl<#[rustc_lt_inherent] 'e> StLt<'e> { }
|
||||
impl<#[rustc_ty_inherent] M> StTy<M> { }
|
||||
|
||||
impl<#[rustc_lt_impl_for] 'f> TrLt<'f> for StLt<'f> {
|
||||
fn foo(&self, _: &'f [u32]) -> &'f u32 { loop { } }
|
||||
}
|
||||
impl<#[rustc_ty_impl_for] N> TrTy<N> for StTy<N> {
|
||||
fn foo(&self, _: N) { }
|
||||
}
|
||||
|
||||
fn f_lt<#[rustc_lt_fn] 'g>(_: &'g [u32]) -> &'g u32 { loop { } }
|
||||
fn f_ty<#[rustc_ty_fn] O>(_: O) { }
|
||||
|
||||
impl<I> StTy<I> {
|
||||
fn m_lt<#[rustc_lt_meth] 'h>(_: &'h [u32]) -> &'h u32 { loop { } }
|
||||
fn m_ty<#[rustc_ty_meth] P>(_: P) { }
|
||||
}
|
||||
|
||||
fn hof_lt<Q>(_: Q)
|
||||
where Q: for <#[rustc_lt_hof] 'i> Fn(&'i [u32]) -> &'i u32
|
||||
{
|
||||
}
|
||||
|
||||
fn main() {
|
||||
|
||||
}
|
|
@ -6,10 +6,8 @@
|
|||
|
||||
struct RefIntPair<'a, 'b>(&'a u32, &'b u32);
|
||||
|
||||
impl<#[rustc_1] 'a, 'b, #[oops]> RefIntPair<'a, 'b> {
|
||||
impl<#[rustc_dummy] 'a, 'b, #[oops]> RefIntPair<'a, 'b> {
|
||||
//~^ ERROR trailing attribute after generic parameter
|
||||
}
|
||||
|
||||
fn main() {
|
||||
|
||||
}
|
||||
fn main() {}
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
error: trailing attribute after generic parameter
|
||||
--> $DIR/attrs-with-no-formal-in-generics-1.rs:9:25
|
||||
--> $DIR/attrs-with-no-formal-in-generics-1.rs:9:29
|
||||
|
|
||||
LL | impl<#[rustc_1] 'a, 'b, #[oops]> RefIntPair<'a, 'b> {
|
||||
| ^^^^^^^ attributes must go before parameters
|
||||
LL | impl<#[rustc_dummy] 'a, 'b, #[oops]> RefIntPair<'a, 'b> {
|
||||
| ^^^^^^^ attributes must go before parameters
|
||||
|
||||
error: aborting due to previous error
|
||||
|
||||
|
|
|
@ -6,7 +6,7 @@
|
|||
|
||||
struct RefAny<'a, T>(&'a T);
|
||||
|
||||
impl<#[rustc_1] 'a, #[rustc_2] T, #[oops]> RefAny<'a, T> {}
|
||||
impl<#[rustc_dummy] 'a, #[rustc_dummy] T, #[oops]> RefAny<'a, T> {}
|
||||
//~^ ERROR trailing attribute after generic parameter
|
||||
|
||||
fn main() {}
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
error: trailing attribute after generic parameter
|
||||
--> $DIR/attrs-with-no-formal-in-generics-2.rs:9:35
|
||||
--> $DIR/attrs-with-no-formal-in-generics-2.rs:9:43
|
||||
|
|
||||
LL | impl<#[rustc_1] 'a, #[rustc_2] T, #[oops]> RefAny<'a, T> {}
|
||||
| ^^^^^^^ attributes must go before parameters
|
||||
LL | impl<#[rustc_dummy] 'a, #[rustc_dummy] T, #[oops]> RefAny<'a, T> {}
|
||||
| ^^^^^^^ attributes must go before parameters
|
||||
|
||||
error: aborting due to previous error
|
||||
|
||||
|
|
|
@ -5,7 +5,7 @@ const fn error(_: fn()) {}
|
|||
|
||||
#[stable(feature = "rust1", since = "1.0.0")]
|
||||
#[rustc_allow_const_fn_ptr]
|
||||
//~^ ERROR unless otherwise specified, attributes with the prefix `rustc_` are reserved
|
||||
//~^ ERROR internal implementation detail
|
||||
const fn compiles(_: fn()) {}
|
||||
|
||||
fn main() {}
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
error[E0658]: unless otherwise specified, attributes with the prefix `rustc_` are reserved for internal compiler diagnostics
|
||||
--> $DIR/allow_const_fn_ptr_feature_gate.rs:7:3
|
||||
error[E0658]: internal implementation detail
|
||||
--> $DIR/allow_const_fn_ptr_feature_gate.rs:7:1
|
||||
|
|
||||
LL | #[rustc_allow_const_fn_ptr]
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
|
||||
= note: for more information, see https://github.com/rust-lang/rust/issues/29642
|
||||
= help: add #![feature(rustc_attrs)] to the crate attributes to enable
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
// Test that `#[rustc_*]` attributes are gated by `rustc_attrs` feature gate.
|
||||
|
||||
#[rustc_foo]
|
||||
//~^ ERROR unless otherwise specified, attributes with the prefix `rustc_` are reserved
|
||||
#[rustc_dummy]
|
||||
//~^ ERROR used by the test suite
|
||||
|
||||
fn main() {}
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
error[E0658]: unless otherwise specified, attributes with the prefix `rustc_` are reserved for internal compiler diagnostics
|
||||
--> $DIR/feature-gate-rustc-attrs.rs:3:3
|
||||
error[E0658]: used by the test suite
|
||||
--> $DIR/feature-gate-rustc-attrs.rs:3:1
|
||||
|
|
||||
LL | #[rustc_foo]
|
||||
| ^^^^^^^^^
|
||||
LL | #[rustc_dummy]
|
||||
| ^^^^^^^^^^^^^^
|
||||
|
|
||||
= note: for more information, see https://github.com/rust-lang/rust/issues/29642
|
||||
= help: add #![feature(rustc_attrs)] to the crate attributes to enable
|
||||
|
|
|
@ -1,44 +1,38 @@
|
|||
// This test previously ensured that attributes on formals in generic parameter
|
||||
// lists are rejected without a feature gate.
|
||||
//
|
||||
// (We are prefixing all tested features with `rustc_`, to ensure that
|
||||
// the attributes themselves won't be rejected by the compiler when
|
||||
// using `rustc_attrs` feature. There is a separate compile-fail/ test
|
||||
// ensuring that the attribute feature-gating works in this context.)
|
||||
|
||||
// compile-pass
|
||||
|
||||
#![feature(rustc_attrs)]
|
||||
#![allow(dead_code)]
|
||||
|
||||
struct StLt<#[rustc_lt_struct] 'a>(&'a u32);
|
||||
struct StTy<#[rustc_ty_struct] I>(I);
|
||||
enum EnLt<#[rustc_lt_enum] 'b> { A(&'b u32), B }
|
||||
enum EnTy<#[rustc_ty_enum] J> { A(J), B }
|
||||
trait TrLt<#[rustc_lt_trait] 'c> { fn foo(&self, _: &'c [u32]) -> &'c u32; }
|
||||
trait TrTy<#[rustc_ty_trait] K> { fn foo(&self, _: K); }
|
||||
type TyLt<#[rustc_lt_type] 'd> = &'d u32;
|
||||
type TyTy<#[rustc_ty_type] L> = (L, );
|
||||
struct StLt<#[rustc_dummy] 'a>(&'a u32);
|
||||
struct StTy<#[rustc_dummy] I>(I);
|
||||
enum EnLt<#[rustc_dummy] 'b> { A(&'b u32), B }
|
||||
enum EnTy<#[rustc_dummy] J> { A(J), B }
|
||||
trait TrLt<#[rustc_dummy] 'c> { fn foo(&self, _: &'c [u32]) -> &'c u32; }
|
||||
trait TrTy<#[rustc_dummy] K> { fn foo(&self, _: K); }
|
||||
type TyLt<#[rustc_dummy] 'd> = &'d u32;
|
||||
type TyTy<#[rustc_dummy] L> = (L, );
|
||||
|
||||
impl<#[rustc_lt_inherent] 'e> StLt<'e> { }
|
||||
impl<#[rustc_ty_inherent] M> StTy<M> { }
|
||||
impl<#[rustc_lt_impl_for] 'f> TrLt<'f> for StLt<'f> {
|
||||
impl<#[rustc_dummy] 'e> StLt<'e> { }
|
||||
impl<#[rustc_dummy] M> StTy<M> { }
|
||||
impl<#[rustc_dummy] 'f> TrLt<'f> for StLt<'f> {
|
||||
fn foo(&self, _: &'f [u32]) -> &'f u32 { loop { } }
|
||||
}
|
||||
impl<#[rustc_ty_impl_for] N> TrTy<N> for StTy<N> {
|
||||
impl<#[rustc_dummy] N> TrTy<N> for StTy<N> {
|
||||
fn foo(&self, _: N) { }
|
||||
}
|
||||
|
||||
fn f_lt<#[rustc_lt_fn] 'g>(_: &'g [u32]) -> &'g u32 { loop { } }
|
||||
fn f_ty<#[rustc_ty_fn] O>(_: O) { }
|
||||
fn f_lt<#[rustc_dummy] 'g>(_: &'g [u32]) -> &'g u32 { loop { } }
|
||||
fn f_ty<#[rustc_dummy] O>(_: O) { }
|
||||
|
||||
impl<I> StTy<I> {
|
||||
fn m_lt<#[rustc_lt_meth] 'h>(_: &'h [u32]) -> &'h u32 { loop { } }
|
||||
fn m_ty<#[rustc_ty_meth] P>(_: P) { }
|
||||
fn m_lt<#[rustc_dummy] 'h>(_: &'h [u32]) -> &'h u32 { loop { } }
|
||||
fn m_ty<#[rustc_dummy] P>(_: P) { }
|
||||
}
|
||||
|
||||
fn hof_lt<Q>(_: Q)
|
||||
where Q: for <#[rustc_lt_hof] 'i> Fn(&'i [u32]) -> &'i u32
|
||||
where Q: for <#[rustc_dummy] 'i> Fn(&'i [u32]) -> &'i u32
|
||||
{}
|
||||
|
||||
fn main() {}
|
||||
|
|
|
@ -1,10 +1,7 @@
|
|||
// compile-flags:-Zborrowck=mir -Zverbose
|
||||
|
||||
// Test that we can deduce when projections like `T::Item` outlive the
|
||||
// function body. Test that this does not imply that `T: 'a` holds.
|
||||
|
||||
#![allow(warnings)]
|
||||
#![feature(rustc_attrs)]
|
||||
// compile-flags:-Zborrowck=mir -Zverbose
|
||||
|
||||
use std::cell::Cell;
|
||||
|
||||
|
@ -18,7 +15,6 @@ where
|
|||
f(&value, Cell::new(&n));
|
||||
}
|
||||
|
||||
#[rustc_errors]
|
||||
fn generic1<T: Iterator>(value: T) {
|
||||
// No error here:
|
||||
twice(value, |value_ref, item| invoke1(item));
|
||||
|
@ -30,7 +26,6 @@ where
|
|||
{
|
||||
}
|
||||
|
||||
#[rustc_errors]
|
||||
fn generic2<T: Iterator>(value: T) {
|
||||
twice(value, |value_ref, item| invoke2(value_ref, item));
|
||||
//~^ ERROR the parameter type `T` may not live long enough
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
error[E0310]: the parameter type `T` may not live long enough
|
||||
--> $DIR/projection-implied-bounds.rs:35:18
|
||||
--> $DIR/projection-implied-bounds.rs:30:18
|
||||
|
|
||||
LL | twice(value, |value_ref, item| invoke2(value_ref, item));
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
|
|
@ -4,9 +4,6 @@
|
|||
// Test that we assume that universal types like `T` outlive the
|
||||
// function body.
|
||||
|
||||
#![allow(warnings)]
|
||||
#![feature(rustc_attrs)]
|
||||
|
||||
use std::cell::Cell;
|
||||
|
||||
fn twice<F, T>(value: T, mut f: F)
|
||||
|
@ -17,7 +14,6 @@ where
|
|||
f(Cell::new(&value));
|
||||
}
|
||||
|
||||
#[rustc_errors]
|
||||
fn generic<T>(value: T) {
|
||||
// No error here:
|
||||
twice(value, |r| invoke(r));
|
||||
|
|
|
@ -1,32 +1,8 @@
|
|||
error: 'a,Ambiguous
|
||||
--> $DIR/object-lifetime-default.rs:24:1
|
||||
error: BaseDefault
|
||||
--> $DIR/object-lifetime-default.rs:6:1
|
||||
|
|
||||
LL | struct G<'a,'b,T:'a,U:'a+'b>(&'a T, &'b U);
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: 'a,'b
|
||||
--> $DIR/object-lifetime-default.rs:21:1
|
||||
|
|
||||
LL | struct F<'a,'b,T:'a,U:'b>(&'a T, &'b U);
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: 'b
|
||||
--> $DIR/object-lifetime-default.rs:18:1
|
||||
|
|
||||
LL | struct E<'a,'b:'a,T:'b>(&'a T, &'b T);
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: Ambiguous
|
||||
--> $DIR/object-lifetime-default.rs:15:1
|
||||
|
|
||||
LL | struct D<'a,'b,T:'a+'b>(&'a T, &'b T);
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: 'a
|
||||
--> $DIR/object-lifetime-default.rs:12:1
|
||||
|
|
||||
LL | struct C<'a,T:'a>(&'a T);
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
LL | struct A<T>(T);
|
||||
| ^^^^^^^^^^^^^^^
|
||||
|
||||
error: BaseDefault
|
||||
--> $DIR/object-lifetime-default.rs:9:1
|
||||
|
@ -34,11 +10,35 @@ error: BaseDefault
|
|||
LL | struct B<'a,T>(&'a (), T);
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: BaseDefault
|
||||
--> $DIR/object-lifetime-default.rs:6:1
|
||||
error: 'a
|
||||
--> $DIR/object-lifetime-default.rs:12:1
|
||||
|
|
||||
LL | struct A<T>(T);
|
||||
| ^^^^^^^^^^^^^^^
|
||||
LL | struct C<'a,T:'a>(&'a T);
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: Ambiguous
|
||||
--> $DIR/object-lifetime-default.rs:15:1
|
||||
|
|
||||
LL | struct D<'a,'b,T:'a+'b>(&'a T, &'b T);
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: 'b
|
||||
--> $DIR/object-lifetime-default.rs:18:1
|
||||
|
|
||||
LL | struct E<'a,'b:'a,T:'b>(&'a T, &'b T);
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: 'a,'b
|
||||
--> $DIR/object-lifetime-default.rs:21:1
|
||||
|
|
||||
LL | struct F<'a,'b,T:'a,U:'b>(&'a T, &'b U);
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: 'a,Ambiguous
|
||||
--> $DIR/object-lifetime-default.rs:24:1
|
||||
|
|
||||
LL | struct G<'a,'b,T:'a,U:'a+'b>(&'a T, &'b U);
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: aborting due to 7 previous errors
|
||||
|
||||
|
|
|
@ -1,12 +1,10 @@
|
|||
// aux-build:derive-unstable-2.rs
|
||||
|
||||
#![allow(warnings)]
|
||||
|
||||
#[macro_use]
|
||||
extern crate derive_unstable_2;
|
||||
|
||||
#[derive(Unstable)]
|
||||
//~^ ERROR: reserved for internal compiler
|
||||
//~^ ERROR attribute `rustc_foo` is currently unknown
|
||||
struct A;
|
||||
|
||||
fn main() {
|
||||
|
|
|
@ -1,11 +1,11 @@
|
|||
error[E0658]: unless otherwise specified, attributes with the prefix `rustc_` are reserved for internal compiler diagnostics
|
||||
--> $DIR/expand-to-unstable-2.rs:8:10
|
||||
error[E0658]: The attribute `rustc_foo` is currently unknown to the compiler and may have meaning added to it in the future
|
||||
--> $DIR/expand-to-unstable-2.rs:6:10
|
||||
|
|
||||
LL | #[derive(Unstable)]
|
||||
| ^^^^^^^^
|
||||
|
|
||||
= note: for more information, see https://github.com/rust-lang/rust/issues/29642
|
||||
= help: add #![feature(rustc_attrs)] to the crate attributes to enable
|
||||
= help: add #![feature(custom_attribute)] to the crate attributes to enable
|
||||
|
||||
error: aborting due to previous error
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
#[rustc_attribute_should_be_reserved]
|
||||
//~^ ERROR unless otherwise specified, attributes with the prefix `rustc_` are reserved
|
||||
//~^ ERROR attribute `rustc_attribute_should_be_reserved` is currently unknown
|
||||
macro_rules! foo {
|
||||
() => (());
|
||||
}
|
||||
|
|
|
@ -1,11 +1,11 @@
|
|||
error[E0658]: unless otherwise specified, attributes with the prefix `rustc_` are reserved for internal compiler diagnostics
|
||||
error[E0658]: The attribute `rustc_attribute_should_be_reserved` is currently unknown to the compiler and may have meaning added to it in the future
|
||||
--> $DIR/reserved-attr-on-macro.rs:1:3
|
||||
|
|
||||
LL | #[rustc_attribute_should_be_reserved]
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
|
||||
= note: for more information, see https://github.com/rust-lang/rust/issues/29642
|
||||
= help: add #![feature(rustc_attrs)] to the crate attributes to enable
|
||||
= help: add #![feature(custom_attribute)] to the crate attributes to enable
|
||||
|
||||
error: cannot determine resolution for the macro `foo`
|
||||
--> $DIR/reserved-attr-on-macro.rs:8:5
|
||||
|
|
|
@ -1,13 +1,8 @@
|
|||
#[deprcated] //~ ERROR E0658
|
||||
fn foo() {} //~| HELP a built-in attribute with a similar name exists
|
||||
//~| SUGGESTION deprecated
|
||||
//~| HELP add #![feature(custom_attribute)] to the crate attributes to enable
|
||||
#[deprcated] //~ ERROR attribute `deprcated` is currently unknown
|
||||
fn foo() {}
|
||||
|
||||
#[tests] //~ ERROR E0658
|
||||
fn bar() {} //~| HELP a built-in attribute with a similar name exists
|
||||
//~| SUGGESTION test
|
||||
//~| HELP add #![feature(custom_attribute)] to the crate attributes to enable
|
||||
#[tests] //~ ERROR attribute `tests` is currently unknown to the compiler
|
||||
fn bar() {}
|
||||
|
||||
#[rustc_err] //~ ERROR E0658
|
||||
fn main() {} //~| HELP add #![feature(rustc_attrs)] to the crate attributes to enable
|
||||
// don't suggest rustc attributes
|
||||
#[rustc_err] //~ ERROR attribute `rustc_err` is currently unknown
|
||||
fn main() {}
|
||||
|
|
|
@ -1,14 +1,14 @@
|
|||
error[E0658]: unless otherwise specified, attributes with the prefix `rustc_` are reserved for internal compiler diagnostics
|
||||
--> $DIR/attribute-typos.rs:11:3
|
||||
error[E0658]: The attribute `rustc_err` is currently unknown to the compiler and may have meaning added to it in the future
|
||||
--> $DIR/attribute-typos.rs:7:3
|
||||
|
|
||||
LL | #[rustc_err]
|
||||
| ^^^^^^^^^
|
||||
|
|
||||
= note: for more information, see https://github.com/rust-lang/rust/issues/29642
|
||||
= help: add #![feature(rustc_attrs)] to the crate attributes to enable
|
||||
= help: add #![feature(custom_attribute)] to the crate attributes to enable
|
||||
|
||||
error[E0658]: The attribute `tests` is currently unknown to the compiler and may have meaning added to it in the future
|
||||
--> $DIR/attribute-typos.rs:6:3
|
||||
--> $DIR/attribute-typos.rs:4:3
|
||||
|
|
||||
LL | #[tests]
|
||||
| ^^^^^ help: a built-in attribute with a similar name exists: `test`
|
||||
|
|
Loading…
Add table
Reference in a new issue