about summary refs log tree commit diff
path: root/src/test/incremental
diff options
context:
space:
mode:
authorNiko Matsakis <niko@alum.mit.edu>2016-08-23 11:57:27 -0400
committerNiko Matsakis <niko@alum.mit.edu>2016-08-23 11:57:27 -0400
commitea2d90e903af29dcfc5bff3bb08ddbc6c4464975 (patch)
tree846cde52ccaa06428a038f5bca10aaa94958386e /src/test/incremental
parentc42e0a34519d44ef0424574093999126fae1d13f (diff)
downloadrust-ea2d90e903af29dcfc5bff3bb08ddbc6c4464975.tar.gz
rust-ea2d90e903af29dcfc5bff3bb08ddbc6c4464975.zip
consider DepNode::Krate to be an input
This seems not only more correct but allows us to write tests that check
whether the krate hash as a whole is clean/dirty
Diffstat (limited to 'src/test/incremental')
-rw-r--r--src/test/incremental/crate_hash_reorder.rs40
1 files changed, 40 insertions, 0 deletions
diff --git a/src/test/incremental/crate_hash_reorder.rs b/src/test/incremental/crate_hash_reorder.rs
new file mode 100644
index 00000000000..1dec361eb07
--- /dev/null
+++ b/src/test/incremental/crate_hash_reorder.rs
@@ -0,0 +1,40 @@
+// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+// Test incremental compilation tracking where we change field names
+// in between revisions (hashing should be stable).
+
+// revisions:rpass1 rpass2 rpass3
+// compile-flags: -Z query-dep-graph
+
+#![feature(rustc_attrs)]
+
+// Check that reordering otherwise identical items is not considered a
+// change at all.
+#[rustc_clean(label="Krate", cfg="rpass2")]
+
+// But removing an item, naturally, is.
+#[rustc_dirty(label="Krate", cfg="rpass3")]
+
+#[cfg(rpass1)]
+pub struct X {
+    pub x: u32,
+}
+
+pub struct Y {
+    pub x: u32,
+}
+
+#[cfg(rpass2)]
+pub struct X {
+    pub x: u32,
+}
+
+pub fn main() { }