summaryrefslogtreecommitdiffstats
path: root/tests/ui/binop/borrow-suggestion-109352-2.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 03:59:24 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 03:59:24 +0000
commit023939b627b7dc93b01471f7d41fb8553ddb4ffa (patch)
tree60fc59477c605c72b0a1051409062ddecc43f877 /tests/ui/binop/borrow-suggestion-109352-2.rs
parentAdding debian version 1.72.1+dfsg1-1. (diff)
downloadrustc-023939b627b7dc93b01471f7d41fb8553ddb4ffa.tar.xz
rustc-023939b627b7dc93b01471f7d41fb8553ddb4ffa.zip
Merging upstream version 1.73.0+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/ui/binop/borrow-suggestion-109352-2.rs')
-rw-r--r--tests/ui/binop/borrow-suggestion-109352-2.rs27
1 files changed, 27 insertions, 0 deletions
diff --git a/tests/ui/binop/borrow-suggestion-109352-2.rs b/tests/ui/binop/borrow-suggestion-109352-2.rs
new file mode 100644
index 000000000..43dab9529
--- /dev/null
+++ b/tests/ui/binop/borrow-suggestion-109352-2.rs
@@ -0,0 +1,27 @@
+struct Bar;
+
+impl std::ops::Mul for &mut Bar {
+ type Output = Bar;
+
+ fn mul(self, _rhs: Self) -> Self::Output {
+ unimplemented!()
+ }
+}
+
+fn main() {
+ let ref_mut_bar: &mut Bar = &mut Bar;
+ let ref_bar: &Bar = &Bar;
+ let owned_bar: Bar = Bar;
+
+ let _ = ref_mut_bar * ref_mut_bar;
+
+ // FIXME: we should be able to suggest borrowing both side
+ let _ = owned_bar * owned_bar;
+ //~^ ERROR cannot multiply
+ let _ = ref_bar * ref_bar;
+ //~^ ERROR cannot multiply
+ let _ = ref_bar * ref_mut_bar;
+ //~^ ERROR cannot multiply
+ let _ = ref_mut_bar * ref_bar;
+ //~^ ERROR mismatched types
+}