diff options
author | Philip Herron <herron.philip@googlemail.com> | 2023-02-13 22:22:06 +0000 |
---|---|---|
committer | Philip Herron <philip.herron@embecosm.com> | 2023-02-14 22:55:07 +0000 |
commit | dac6d99a873759e7cca355508e814ef03e5659d1 (patch) | |
tree | e60a4c5c5a21a816adc3b6122a2a874e051b6e92 | |
parent | 84eb2e24d93c581c33ea817d678bc0612c2a225e (diff) | |
download | gcc-dac6d99a873759e7cca355508e814ef03e5659d1.zip gcc-dac6d99a873759e7cca355508e814ef03e5659d1.tar.gz gcc-dac6d99a873759e7cca355508e814ef03e5659d1.tar.bz2 |
gccrs: Fix regression in testcase
Fixes #776
Signed-off-by: Philip Herron <herron.philip@googlemail.com>
gcc/testsuite/ChangeLog:
* rust/compile/torture/traits10.rs: Fix test-case
-rw-r--r-- | gcc/testsuite/rust/compile/torture/traits10.rs | 64 |
1 files changed, 62 insertions, 2 deletions
diff --git a/gcc/testsuite/rust/compile/torture/traits10.rs b/gcc/testsuite/rust/compile/torture/traits10.rs index a029270..4cf36e3 100644 --- a/gcc/testsuite/rust/compile/torture/traits10.rs +++ b/gcc/testsuite/rust/compile/torture/traits10.rs @@ -1,5 +1,65 @@ -trait Foo // where -// Self: Sized, +#[lang = "sized"] +pub trait Sized {} + +#[lang = "clone"] +pub trait Clone: Sized { + fn clone(&self) -> Self; + + fn clone_from(&mut self, source: &Self) { + *self = source.clone() + } +} + +mod impls { + use super::Clone; + + macro_rules! impl_clone { + ($($t:ty)*) => { + $( + impl Clone for $t { + fn clone(&self) -> Self { + *self + } + } + )* + } + } + + impl_clone! { + usize u8 u16 u32 u64 // u128 + isize i8 i16 i32 i64 // i128 + f32 f64 + bool char + } +} + +#[lang = "copy"] +pub trait Copy: Clone { + // Empty. +} + +mod copy_impls { + use super::Copy; + + macro_rules! impl_copy { + ($($t:ty)*) => { + $( + impl Copy for $t {} + )* + } + } + + impl_copy! { + usize u8 u16 u32 u64 // u128 + isize i8 i16 i32 i64 // i128 + f32 f64 + bool char + } +} + +trait Foo +where + Self: Sized, { fn get(self) -> i32; |