2016-07-27 14:42:58 -04:00
|
|
|
// Check that the hash of `foo` doesn't change just because we ordered
|
|
|
|
// the nested items (or even added new ones).
|
|
|
|
|
2017-11-08 11:32:16 +01:00
|
|
|
// revisions: cfail1 cfail2
|
2019-07-03 06:30:28 +09:00
|
|
|
// build-pass (FIXME(62277): could be check-pass?)
|
2016-07-27 14:42:58 -04:00
|
|
|
|
2017-11-08 11:32:16 +01:00
|
|
|
#![crate_type = "rlib"]
|
2016-07-27 14:42:58 -04:00
|
|
|
#![feature(rustc_attrs)]
|
|
|
|
|
2020-02-12 18:50:30 +01:00
|
|
|
#[rustc_clean(label = "hir_owner", cfg = "cfail2")]
|
2020-03-18 03:48:17 +02:00
|
|
|
#[rustc_dirty(label = "hir_owner_nodes", cfg = "cfail2")]
|
2017-11-08 11:32:16 +01:00
|
|
|
pub fn foo() {
|
2017-12-04 12:47:16 +01:00
|
|
|
#[cfg(cfail1)]
|
2020-02-12 18:50:30 +01:00
|
|
|
pub fn baz() {} // order is different...
|
2016-07-27 14:42:58 -04:00
|
|
|
|
2020-02-12 18:50:30 +01:00
|
|
|
// FIXME: Make "hir_owner" use `rustc_clean` here. Currently "hir_owner" includes a reference to
|
|
|
|
// the parent node, which is the statement holding this item. Changing the position of
|
|
|
|
// `bar` in `foo` will update that reference and make `hir_owner(bar)` dirty.
|
|
|
|
#[rustc_dirty(label = "hir_owner", cfg = "cfail2")]
|
2020-03-18 03:48:17 +02:00
|
|
|
#[rustc_clean(label = "hir_owner_nodes", cfg = "cfail2")]
|
2020-02-12 18:50:30 +01:00
|
|
|
pub fn bar() {} // but that doesn't matter.
|
2016-07-27 14:42:58 -04:00
|
|
|
|
2017-12-04 12:47:16 +01:00
|
|
|
#[cfg(cfail2)]
|
2020-02-12 18:50:30 +01:00
|
|
|
pub fn baz() {} // order is different...
|
2017-12-04 12:47:16 +01:00
|
|
|
|
2020-02-12 18:50:30 +01:00
|
|
|
pub fn bap() {} // neither does adding a new item
|
2016-07-27 14:42:58 -04:00
|
|
|
}
|