Rollup merge of #83313 - cjgillot:assert, r=michaelwoerister
Only enable assert_dep_graph when query-dep-graph is enabled. This is a debugging option. The only effect should be on rustc tests. r? ``@michaelwoerister``
This commit is contained in:
commit
2f611da1d6
8 changed files with 77 additions and 1 deletions
|
@ -57,6 +57,10 @@ pub fn assert_dep_graph(tcx: TyCtxt<'_>) {
|
|||
dump_graph(tcx);
|
||||
}
|
||||
|
||||
if !tcx.sess.opts.debugging_opts.query_dep_graph {
|
||||
return;
|
||||
}
|
||||
|
||||
// if the `rustc_attrs` feature is not enabled, then the
|
||||
// attributes we are interested in cannot be present anyway, so
|
||||
// skip the walk.
|
||||
|
|
|
@ -148,6 +148,10 @@ impl Assertion {
|
|||
}
|
||||
|
||||
pub fn check_dirty_clean_annotations(tcx: TyCtxt<'_>) {
|
||||
if !tcx.sess.opts.debugging_opts.query_dep_graph {
|
||||
return;
|
||||
}
|
||||
|
||||
// can't add `#[rustc_dirty]` etc without opting in to this feature
|
||||
if !tcx.features().rustc_attrs {
|
||||
return;
|
||||
|
|
|
@ -99,6 +99,12 @@ impl CheckAttrVisitor<'tcx> {
|
|||
self.check_naked(hir_id, attr, span, target)
|
||||
} else if self.tcx.sess.check_name(attr, sym::rustc_legacy_const_generics) {
|
||||
self.check_rustc_legacy_const_generics(&attr, span, target, item)
|
||||
} else if self.tcx.sess.check_name(attr, sym::rustc_clean)
|
||||
|| self.tcx.sess.check_name(attr, sym::rustc_dirty)
|
||||
|| self.tcx.sess.check_name(attr, sym::rustc_if_this_changed)
|
||||
|| self.tcx.sess.check_name(attr, sym::rustc_then_this_would_need)
|
||||
{
|
||||
self.check_rustc_dirty_clean(&attr)
|
||||
} else {
|
||||
// lint-only checks
|
||||
if self.tcx.sess.check_name(attr, sym::cold) {
|
||||
|
@ -1012,6 +1018,20 @@ impl CheckAttrVisitor<'tcx> {
|
|||
}
|
||||
}
|
||||
|
||||
/// Checks that the dep-graph debugging attributes are only present when the query-dep-graph
|
||||
/// option is passed to the compiler.
|
||||
fn check_rustc_dirty_clean(&self, attr: &Attribute) -> bool {
|
||||
if self.tcx.sess.opts.debugging_opts.query_dep_graph {
|
||||
true
|
||||
} else {
|
||||
self.tcx
|
||||
.sess
|
||||
.struct_span_err(attr.span, "attribute requires -Z query-dep-graph to be enabled")
|
||||
.emit();
|
||||
false
|
||||
}
|
||||
}
|
||||
|
||||
/// Checks if `#[link_section]` is applied to a function or static.
|
||||
fn check_link_section(&self, hir_id: HirId, attr: &Attribute, span: &Span, target: Target) {
|
||||
match target {
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
|
||||
// revisions: cfail1 cfail2
|
||||
// build-pass (FIXME(62277): could be check-pass?)
|
||||
// compile-flags: -Z query-dep-graph
|
||||
|
||||
#![crate_type = "rlib"]
|
||||
#![feature(rustc_attrs)]
|
||||
|
|
|
@ -2,6 +2,7 @@
|
|||
// `use` to something different.
|
||||
|
||||
// revisions: rpass1 rpass2 rpass3
|
||||
// compile-flags: -Z query-dep-graph
|
||||
|
||||
#![feature(rustc_attrs)]
|
||||
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
|
||||
// revisions:rpass1 rpass2
|
||||
|
||||
// compile-flags: -C overflow-checks=on
|
||||
// compile-flags: -C overflow-checks=on -Z query-dep-graph
|
||||
|
||||
#![feature(rustc_attrs)]
|
||||
|
||||
|
|
20
src/test/ui/dep-graph/dep-graph-check-attr.rs
Normal file
20
src/test/ui/dep-graph/dep-graph-check-attr.rs
Normal file
|
@ -0,0 +1,20 @@
|
|||
// Test that using rustc_clean/dirty/if_this_changed/then_this_would_need
|
||||
// are forbidden when `-Z query-dep-graph` is not enabled.
|
||||
|
||||
#![feature(rustc_attrs)]
|
||||
#![allow(dead_code)]
|
||||
#![allow(unused_variables)]
|
||||
|
||||
#[rustc_dirty(hir_owner)] //~ ERROR attribute requires -Z query-dep-graph
|
||||
fn main() {}
|
||||
|
||||
#[rustc_if_this_changed(hir_owner)] //~ ERROR attribute requires -Z query-dep-graph
|
||||
struct Foo<T> {
|
||||
f: T,
|
||||
}
|
||||
|
||||
#[rustc_clean(hir_owner)] //~ ERROR attribute requires -Z query-dep-graph
|
||||
type TypeAlias<T> = Foo<T>;
|
||||
|
||||
#[rustc_then_this_would_need(variances_of)] //~ ERROR attribute requires -Z query-dep-graph
|
||||
trait Use<T> {}
|
26
src/test/ui/dep-graph/dep-graph-check-attr.stderr
Normal file
26
src/test/ui/dep-graph/dep-graph-check-attr.stderr
Normal file
|
@ -0,0 +1,26 @@
|
|||
error: attribute requires -Z query-dep-graph to be enabled
|
||||
--> $DIR/dep-graph-check-attr.rs:8:1
|
||||
|
|
||||
LL | #[rustc_dirty(hir_owner)]
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: attribute requires -Z query-dep-graph to be enabled
|
||||
--> $DIR/dep-graph-check-attr.rs:11:1
|
||||
|
|
||||
LL | #[rustc_if_this_changed(hir_owner)]
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: attribute requires -Z query-dep-graph to be enabled
|
||||
--> $DIR/dep-graph-check-attr.rs:16:1
|
||||
|
|
||||
LL | #[rustc_clean(hir_owner)]
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: attribute requires -Z query-dep-graph to be enabled
|
||||
--> $DIR/dep-graph-check-attr.rs:19:1
|
||||
|
|
||||
LL | #[rustc_then_this_would_need(variances_of)]
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: aborting due to 4 previous errors
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue