diff options
| author | AngelicosPhosphoros <xuzin.timur@gmail.com> | 2021-04-03 20:58:15 +0300 |
|---|---|---|
| committer | AngelicosPhosphoros <xuzin.timur@gmail.com> | 2021-04-04 20:37:48 +0300 |
| commit | ed0d8fa3e8c061fdd22fb95f6cfadbada864118d (patch) | |
| tree | 5837cfff4937ffad5d36c881cfdea4234550c4b0 /src/test/codegen | |
| parent | 836c31742687ba4e2f857b5b698e1e9e6b67619c (diff) | |
| download | rust-ed0d8fa3e8c061fdd22fb95f6cfadbada864118d.tar.gz rust-ed0d8fa3e8c061fdd22fb95f6cfadbada864118d.zip | |
Optimize PartialOrd le
Closes https://github.com/rust-lang/rust/issues/73338 This change stops default implementation of `le()` method from generating jumps.
Diffstat (limited to 'src/test/codegen')
| -rw-r--r-- | src/test/codegen/issue-73338-effecient-cmp.rs | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/src/test/codegen/issue-73338-effecient-cmp.rs b/src/test/codegen/issue-73338-effecient-cmp.rs new file mode 100644 index 00000000000..85c2bbfd040 --- /dev/null +++ b/src/test/codegen/issue-73338-effecient-cmp.rs @@ -0,0 +1,39 @@ +// This test checks that comparison operation +// generated by #[derive(PartialOrd)] +// doesn't contain jumps for C enums + +// compile-flags: -Copt-level=3 + +#![crate_type="lib"] + +#[repr(u32)] +#[derive(Copy, Clone, Eq, PartialEq, PartialOrd)] +pub enum Foo { + Zero, + One, + Two, +} + +#[no_mangle] +pub fn compare_less(a: Foo, b: Foo)->bool{ + // CHECK-NOT: br {{.*}} + a < b +} + +#[no_mangle] +pub fn compare_le(a: Foo, b: Foo)->bool{ + // CHECK-NOT: br {{.*}} + a <= b +} + +#[no_mangle] +pub fn compare_ge(a: Foo, b: Foo)->bool{ + // CHECK-NOT: br {{.*}} + a >= b +} + +#[no_mangle] +pub fn compare_greater(a: Foo, b: Foo)->bool{ + // CHECK-NOT: br {{.*}} + a > b +} |
