summaryrefslogtreecommitdiffstats
path: root/src/test/ui/derives/derive-partial-ord.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
commit698f8c2f01ea549d77d7dc3338a12e04c11057b9 (patch)
tree173a775858bd501c378080a10dca74132f05bc50 /src/test/ui/derives/derive-partial-ord.rs
parentInitial commit. (diff)
downloadrustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.tar.xz
rustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.zip
Adding upstream version 1.64.0+dfsg1.upstream/1.64.0+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/test/ui/derives/derive-partial-ord.rs')
-rw-r--r--src/test/ui/derives/derive-partial-ord.rs60
1 files changed, 60 insertions, 0 deletions
diff --git a/src/test/ui/derives/derive-partial-ord.rs b/src/test/ui/derives/derive-partial-ord.rs
new file mode 100644
index 000000000..9078a7ffa
--- /dev/null
+++ b/src/test/ui/derives/derive-partial-ord.rs
@@ -0,0 +1,60 @@
+// Checks that in a derived implementation of PartialOrd the lt, le, ge, gt methods are consistent
+// with partial_cmp. Also verifies that implementation is consistent with that for tuples.
+//
+// run-pass
+
+#[derive(PartialEq, PartialOrd)]
+struct P(f64, f64);
+
+fn main() {
+ let values: &[f64] = &[1.0, 2.0, f64::NAN];
+ for a in values {
+ for b in values {
+ for c in values {
+ for d in values {
+ // Check impl for a tuple.
+ check(&(*a, *b), &(*c, *d));
+
+ // Check derived impl.
+ check(&P(*a, *b), &P(*c, *d));
+
+ // Check that impls agree with each other.
+ assert_eq!(
+ PartialOrd::partial_cmp(&(*a, *b), &(*c, *d)),
+ PartialOrd::partial_cmp(&P(*a, *b), &P(*c, *d)),
+ );
+ }
+ }
+ }
+ }
+}
+
+fn check<T: PartialOrd>(a: &T, b: &T) {
+ use std::cmp::Ordering::*;
+ match PartialOrd::partial_cmp(a, b) {
+ None => {
+ assert!(!(a < b));
+ assert!(!(a <= b));
+ assert!(!(a > b));
+ assert!(!(a >= b));
+ }
+ Some(Equal) => {
+ assert!(!(a < b));
+ assert!(a <= b);
+ assert!(!(a > b));
+ assert!(a >= b);
+ }
+ Some(Less) => {
+ assert!(a < b);
+ assert!(a <= b);
+ assert!(!(a > b));
+ assert!(!(a >= b));
+ }
+ Some(Greater) => {
+ assert!(!(a < b));
+ assert!(!(a <= b));
+ assert!(a > b);
+ assert!(a >= b);
+ }
+ }
+}