summaryrefslogtreecommitdiffstats
path: root/src/test/ui/overloaded/overloaded-autoderef-order.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
commit698f8c2f01ea549d77d7dc3338a12e04c11057b9 (patch)
tree173a775858bd501c378080a10dca74132f05bc50 /src/test/ui/overloaded/overloaded-autoderef-order.rs
parentInitial commit. (diff)
downloadrustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.tar.xz
rustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.zip
Adding upstream version 1.64.0+dfsg1.upstream/1.64.0+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/test/ui/overloaded/overloaded-autoderef-order.rs')
-rw-r--r--src/test/ui/overloaded/overloaded-autoderef-order.rs73
1 files changed, 73 insertions, 0 deletions
diff --git a/src/test/ui/overloaded/overloaded-autoderef-order.rs b/src/test/ui/overloaded/overloaded-autoderef-order.rs
new file mode 100644
index 000000000..f48bae55f
--- /dev/null
+++ b/src/test/ui/overloaded/overloaded-autoderef-order.rs
@@ -0,0 +1,73 @@
+// run-pass
+
+#![allow(dead_code)]
+
+use std::rc::Rc;
+use std::ops::Deref;
+
+#[derive(Copy, Clone)]
+struct DerefWrapper<X, Y> {
+ x: X,
+ y: Y
+}
+
+impl<X, Y> DerefWrapper<X, Y> {
+ fn get_x(self) -> X {
+ self.x
+ }
+}
+
+impl<X, Y> Deref for DerefWrapper<X, Y> {
+ type Target = Y;
+
+ fn deref(&self) -> &Y {
+ &self.y
+ }
+}
+
+mod priv_test {
+ use std::ops::Deref;
+
+ #[derive(Copy, Clone)]
+ pub struct DerefWrapperHideX<X, Y> {
+ x: X,
+ pub y: Y
+ }
+
+ impl<X, Y> DerefWrapperHideX<X, Y> {
+ pub fn new(x: X, y: Y) -> DerefWrapperHideX<X, Y> {
+ DerefWrapperHideX {
+ x: x,
+ y: y
+ }
+ }
+ }
+
+ impl<X, Y> Deref for DerefWrapperHideX<X, Y> {
+ type Target = Y;
+
+ fn deref(&self) -> &Y {
+ &self.y
+ }
+ }
+}
+
+pub fn main() {
+ let nested = DerefWrapper {x: true, y: DerefWrapper {x: 0, y: 1}};
+
+ // Use the first field that you can find.
+ assert_eq!(nested.x, true);
+ assert_eq!((*nested).x, 0);
+
+ // Same for methods, even though there are multiple
+ // candidates (at different nesting levels).
+ assert_eq!(nested.get_x(), true);
+ assert_eq!((*nested).get_x(), 0);
+
+ // Also go through multiple levels of indirection.
+ assert_eq!(Rc::new(nested).x, true);
+
+ let nested_priv = priv_test::DerefWrapperHideX::new(true, DerefWrapper {x: 0, y: 1});
+ assert_eq!(nested_priv.x, 0);
+ assert_eq!((*nested_priv).x, 0);
+}