diff options
| author | Dylan MacKenzie <ecstaticmorse@gmail.com> | 2020-02-05 09:35:32 -0800 |
|---|---|---|
| committer | Dylan MacKenzie <ecstaticmorse@gmail.com> | 2020-02-18 21:03:28 -0800 |
| commit | d6d6d25c343fb4fdf6c853bd23524a77efc4c53b (patch) | |
| tree | 6e65bccb28f8df0de694c4c80cc31efc99f702d1 | |
| parent | 323ff193b8eda1c89eada54a1b3ac5c20d9e24c7 (diff) | |
| download | rust-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.rs | 41 |
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)); +} |
