From 47016f9ce514fd5975a4412259ce3022b877ad3d Mon Sep 17 00:00:00 2001 From: "Felix S. Klock II" Date: Fri, 10 Apr 2015 19:02:01 +0200 Subject: [PATCH] Test case for 64-bit corner cases where truncation occurred before prior commit. --- src/test/run-pass/issue-15523-big.rs | 48 ++++++++++++++++++++++++++++ src/test/run-pass/issue-15523.rs | 2 ++ 2 files changed, 50 insertions(+) create mode 100644 src/test/run-pass/issue-15523-big.rs diff --git a/src/test/run-pass/issue-15523-big.rs b/src/test/run-pass/issue-15523-big.rs new file mode 100644 index 0000000000000..33c81cab3817b --- /dev/null +++ b/src/test/run-pass/issue-15523-big.rs @@ -0,0 +1,48 @@ +// Copyright 2015 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 or the MIT license +// , at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +// Issue 15523: derive(PartialOrd) should use the provided +// discriminant values for the derived ordering. +// +// This test is checking corner cases that arise when you have +// 64-bit values in the variants. + +#[derive(PartialEq, PartialOrd)] +#[repr(u64)] +enum Eu64 { + Pos2 = 2, + PosMax = !0, + Pos1 = 1, +} + +#[derive(PartialEq, PartialOrd)] +#[repr(i64)] +enum Ei64 { + Pos2 = 2, + Neg1 = -1, + NegMin = 1 << 63, + PosMax = !(1 << 63), + Pos1 = 1, +} + +fn main() { + assert!(Eu64::Pos2 > Eu64::Pos1); + assert!(Eu64::Pos2 < Eu64::PosMax); + assert!(Eu64::Pos1 < Eu64::PosMax); + + + assert!(Ei64::Pos2 > Ei64::Pos1); + assert!(Ei64::Pos2 > Ei64::Neg1); + assert!(Ei64::Pos1 > Ei64::Neg1); + assert!(Ei64::Pos2 > Ei64::NegMin); + assert!(Ei64::Pos1 > Ei64::NegMin); + assert!(Ei64::Pos2 < Ei64::PosMax); + assert!(Ei64::Pos1 < Ei64::PosMax); +} diff --git a/src/test/run-pass/issue-15523.rs b/src/test/run-pass/issue-15523.rs index 8edf360c98563..bb8fa6791a5c4 100644 --- a/src/test/run-pass/issue-15523.rs +++ b/src/test/run-pass/issue-15523.rs @@ -10,6 +10,8 @@ // Issue 15523: derive(PartialOrd) should use the provided // discriminant values for the derived ordering. +// +// This is checking the basic functionality. #[derive(PartialEq, PartialOrd)] enum E1 {