summaryrefslogtreecommitdiffstats
path: root/tests/incremental/change_private_impl_method_cc
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:19:13 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:19:13 +0000
commit218caa410aa38c29984be31a5229b9fa717560ee (patch)
treec54bd55eeb6e4c508940a30e94c0032fbd45d677 /tests/incremental/change_private_impl_method_cc
parentReleasing progress-linux version 1.67.1+dfsg1-1~progress7.99u1. (diff)
downloadrustc-218caa410aa38c29984be31a5229b9fa717560ee.tar.xz
rustc-218caa410aa38c29984be31a5229b9fa717560ee.zip
Merging upstream version 1.68.2+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/incremental/change_private_impl_method_cc')
-rw-r--r--tests/incremental/change_private_impl_method_cc/auxiliary/point.rs25
-rw-r--r--tests/incremental/change_private_impl_method_cc/struct_point.rs73
2 files changed, 98 insertions, 0 deletions
diff --git a/tests/incremental/change_private_impl_method_cc/auxiliary/point.rs b/tests/incremental/change_private_impl_method_cc/auxiliary/point.rs
new file mode 100644
index 000000000..2441da06b
--- /dev/null
+++ b/tests/incremental/change_private_impl_method_cc/auxiliary/point.rs
@@ -0,0 +1,25 @@
+pub struct Point {
+ pub x: f32,
+ pub y: f32,
+}
+
+impl Point {
+ fn distance_squared(&self) -> f32 {
+ #[cfg(cfail1)]
+ return self.x + self.y;
+
+ #[cfg(cfail2)]
+ return self.x * self.x + self.y * self.y;
+ }
+
+ pub fn distance_from_origin(&self) -> f32 {
+ self.distance_squared().sqrt()
+ }
+}
+
+impl Point {
+ pub fn translate(&mut self, x: f32, y: f32) {
+ self.x += x;
+ self.y += y;
+ }
+}
diff --git a/tests/incremental/change_private_impl_method_cc/struct_point.rs b/tests/incremental/change_private_impl_method_cc/struct_point.rs
new file mode 100644
index 000000000..9fe8b5df9
--- /dev/null
+++ b/tests/incremental/change_private_impl_method_cc/struct_point.rs
@@ -0,0 +1,73 @@
+// Test where we change the body of a private method in an impl.
+// We then test what sort of functions must be rebuilt as a result.
+
+// revisions:cfail1 cfail2
+// compile-flags: -Z query-dep-graph
+// aux-build:point.rs
+// build-pass (FIXME(62277): could be check-pass?)
+
+#![crate_type = "rlib"]
+#![feature(rustc_attrs)]
+#![feature(stmt_expr_attributes)]
+#![allow(dead_code)]
+
+#![rustc_partition_reused(module="struct_point-fn_read_field", cfg="cfail2")]
+#![rustc_partition_reused(module="struct_point-fn_write_field", cfg="cfail2")]
+#![rustc_partition_reused(module="struct_point-fn_make_struct", cfg="cfail2")]
+
+#![rustc_partition_reused(module="struct_point-fn_calls_methods_in_same_impl", cfg="cfail2")]
+#![rustc_partition_reused(module="struct_point-fn_calls_methods_in_another_impl", cfg="cfail2")]
+
+extern crate point;
+
+/// A fn item that calls (public) methods on `Point` from the same impl which changed
+pub mod fn_calls_methods_in_same_impl {
+ use point::Point;
+
+ #[rustc_clean(cfg="cfail2")]
+ pub fn check() {
+ let x = Point { x: 2.0, y: 2.0 };
+ x.distance_from_origin();
+ }
+}
+
+/// A fn item that calls (public) methods on `Point` from another impl
+pub mod fn_calls_methods_in_another_impl {
+ use point::Point;
+
+ #[rustc_clean(cfg="cfail2")]
+ pub fn dirty() {
+ let mut x = Point { x: 2.0, y: 2.0 };
+ x.translate(3.0, 3.0);
+ }
+}
+
+/// A fn item that makes an instance of `Point` but does not invoke methods
+pub mod fn_make_struct {
+ use point::Point;
+
+ #[rustc_clean(cfg="cfail2")]
+ pub fn make_origin() -> Point {
+ Point { x: 2.0, y: 2.0 }
+ }
+}
+
+/// A fn item that reads fields from `Point` but does not invoke methods
+pub mod fn_read_field {
+ use point::Point;
+
+ #[rustc_clean(cfg="cfail2")]
+ pub fn get_x(p: Point) -> f32 {
+ p.x
+ }
+}
+
+/// A fn item that writes to a field of `Point` but does not invoke methods
+pub mod fn_write_field {
+ use point::Point;
+
+ #[rustc_clean(cfg="cfail2")]
+ pub fn inc_x(p: &mut Point) {
+ p.x += 1.0;
+ }
+}