about summary refs log tree commit diff
diff options
context:
space:
mode:
authorDylan MacKenzie <ecstaticmorse@gmail.com>2020-02-05 09:35:32 -0800
committerDylan MacKenzie <ecstaticmorse@gmail.com>2020-02-18 21:03:28 -0800
commitd6d6d25c343fb4fdf6c853bd23524a77efc4c53b (patch)
tree6e65bccb28f8df0de694c4c80cc31efc99f702d1
parent323ff193b8eda1c89eada54a1b3ac5c20d9e24c7 (diff)
downloadrust-d6d6d25c343fb4fdf6c853bd23524a77efc4c53b.tar.gz
rust-d6d6d25c343fb4fdf6c853bd23524a77efc4c53b.zip
Split const trait method test and impl `ops::Add`
-rw-r--r--src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method-fail.rs (renamed from src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method.rs)2
-rw-r--r--src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method-fail.stderr (renamed from src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method.stderr)2
-rw-r--r--src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method-pass.rs41
3 files changed, 43 insertions, 2 deletions
diff --git a/src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method.rs b/src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method-fail.rs
index ed6c07e4653..8e6ef12810c 100644
--- a/src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method.rs
+++ b/src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method-fail.rs
@@ -19,7 +19,7 @@ impl Plus for u32 {
 }
 
 pub const fn add_i32(a: i32, b: i32) -> i32 {
-    a.plus(b)
+    a.plus(b) // ok
 }
 
 pub const fn add_u32(a: u32, b: u32) -> u32 {
diff --git a/src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method.stderr b/src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method-fail.stderr
index 7216876c83a..0c320d54c76 100644
--- a/src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method.stderr
+++ b/src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method-fail.stderr
@@ -1,5 +1,5 @@
 error[E0015]: calls in constant functions are limited to constant functions, tuple structs and tuple variants
-  --> $DIR/call-const-trait-method.rs:26:5
+  --> $DIR/call-const-trait-method-fail.rs:26:5
    |
 LL |     a.plus(b)
    |     ^^^^^^^^^
diff --git a/src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method-pass.rs b/src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method-pass.rs
new file mode 100644
index 00000000000..6a2112ea554
--- /dev/null
+++ b/src/test/ui/rfc-2632-const-trait-impl/call-const-trait-method-pass.rs
@@ -0,0 +1,41 @@
+// run-pass
+
+#![allow(incomplete_features)]
+#![feature(const_trait_impl)]
+#![feature(const_fn)]
+
+struct Int(i32);
+
+impl const std::ops::Add for Int {
+    type Output = Int;
+
+    fn add(self, rhs: Self) -> Self {
+        Int(self.0.plus(rhs.0))
+    }
+}
+
+impl const PartialEq for Int {
+    fn eq(&self, rhs: &Self) -> bool {
+        self.0 == rhs.0
+    }
+}
+
+pub trait Plus {
+    fn plus(self, rhs: Self) -> Self;
+}
+
+impl const Plus for i32 {
+    fn plus(self, rhs: Self) -> Self {
+        self + rhs
+    }
+}
+
+pub const fn add_i32(a: i32, b: i32) -> i32 {
+    a.plus(b)
+}
+
+const ADD_INT: Int = Int(1i32) + Int(2i32);
+
+fn main() {
+    assert!(ADD_INT == Int(3i32));
+}