From 7b072166abf81b2eb880a3454cc7e8f4b2667a26 Mon Sep 17 00:00:00 2001 From: SwayStar123 <46050679+SwayStar123@users.noreply.github.com> Date: Fri, 13 Sep 2024 06:53:52 +0530 Subject: [PATCH] Add Eq for Result (#6140) ## Description Closes #6077 ## Checklist - [x] I have linked to any relevant issues. - [x] I have commented my code, particularly in hard-to-understand areas. - [ ] I have updated the documentation where relevant (API docs, the reference, and the Sway book). - [ ] If my change requires substantial documentation changes, I have [requested support from the DevRel team](https://github.com/FuelLabs/devrel-requests/issues/new/choose) - [x] I have added tests that prove my fix is effective or that my feature works. - [ ] I have added (or requested a maintainer to add) the necessary `Breaking*` or `New Feature` labels where relevant. - [x] I have done my best to ensure that my PR adheres to [the Fuel Labs Code Review Standards](https://github.com/FuelLabs/rfcs/blob/master/text/code-standards/external-contributors.md). - [ ] I have requested a review from the relevant team or maintainers. --------- Co-authored-by: K1-R1 <77465250+K1-R1@users.noreply.github.com> --- sway-lib-std/src/result.sw | 14 +++ .../result_inline_tests/src/eq.sw | 114 ++++++++++++++++++ .../result_inline_tests/src/main.sw | 2 + 3 files changed, 130 insertions(+) create mode 100644 test/src/in_language_tests/test_programs/result_inline_tests/src/eq.sw diff --git a/sway-lib-std/src/result.sw b/sway-lib-std/src/result.sw index f4f5f79a2b0..9b0532ee567 100644 --- a/sway-lib-std/src/result.sw +++ b/sway-lib-std/src/result.sw @@ -269,3 +269,17 @@ impl Result { // - `ok(self) -> Option` // - `err(self) -> Option` } + +impl Eq for Result +where + T: Eq, + E: Eq, +{ + fn eq(self, other: Self) -> bool { + match (self, other) { + (Self::Ok(a), Self::Ok(b)) => a == b, + (Self::Err(a), Self::Err(b)) => a == b, + _ => false, + } + } +} diff --git a/test/src/in_language_tests/test_programs/result_inline_tests/src/eq.sw b/test/src/in_language_tests/test_programs/result_inline_tests/src/eq.sw new file mode 100644 index 00000000000..18ce687b26e --- /dev/null +++ b/test/src/in_language_tests/test_programs/result_inline_tests/src/eq.sw @@ -0,0 +1,114 @@ +library; + +#[test] +fn test_eq_u64_u64() { + let a: Result = Ok(0); + let b: Result = Ok(0); + assert_eq(a, b); + + let a: Result = Ok(1); + let b: Result = Ok(1); + assert_eq(a, b); + + let a: Result = Ok(42); + let b: Result = Ok(42); + assert_eq(a, b); + + let a: Result = Ok(u64::max()); + let b: Result = Ok(u64::max()); + assert_eq(a, b); +} + +#[test] +fn test_neq_u64_u64() { + // Ok + let a: Result = Ok(0); + let b: Result = Ok(1); + assert_ne(a, b); + + let a: Result = Ok(0); + let b: Result = Ok(42); + assert_ne(a, b); + + let a: Result = Ok(0); + let b: Result = Ok(u64::max()); + assert_ne(a, b); + + let a: Result = Ok(1); + let b: Result = Ok(0); + assert_ne(a, b); + + let a: Result = Ok(42); + let b: Result = Ok(0); + assert_ne(a, b); + + let a: Result = Ok(u64::max()); + let b: Result = Ok(0); + assert_ne(a, b); + + // Err + let a: Result = Err(0); + let b: Result = Err(1); + assert_ne(a, b); + + let a: Result = Err(0); + let b: Result = Err(42); + assert_ne(a, b); + + let a: Result = Err(0); + let b: Result = Err(u64::max()); + assert_ne(a, b); + + let a: Result = Err(1); + let b: Result = Err(0); + assert_ne(a, b); + + let a: Result = Err(42); + let b: Result = Err(0); + assert_ne(a, b); + + let a: Result = Err(u64::max()); + let b: Result = Err(0); + assert_ne(a, b); + + // Ok-Err + let a: Result = Ok(0); + let b: Result = Err(0); + assert_ne(a, b); + + let a: Result = Ok(1); + let b: Result = Err(1); + assert_ne(a, b); + + let a: Result = Ok(42); + let b: Result = Err(42); + assert_ne(a, b); + + let a: Result = Ok(u64::max()); + let b: Result = Err(u64::max()); + assert_ne(a, b); + + let a: Result = Ok(0); + let b: Result = Err(1); + assert_ne(a, b); + + let a: Result = Ok(0); + let b: Result = Err(42); + assert_ne(a, b); + + let a: Result = Ok(0); + let b: Result = Err(u64::max()); + assert_ne(a, b); + + let a: Result = Ok(1); + let b: Result = Err(0); + assert_ne(a, b); + + let a: Result = Ok(42); + let b: Result = Err(0); + assert_ne(a, b); + + let a: Result = Ok(u64::max()); + let b: Result = Err(0); + assert_ne(a, b); +} diff --git a/test/src/in_language_tests/test_programs/result_inline_tests/src/main.sw b/test/src/in_language_tests/test_programs/result_inline_tests/src/main.sw index 2166d4b643b..381c4ec24f5 100644 --- a/test/src/in_language_tests/test_programs/result_inline_tests/src/main.sw +++ b/test/src/in_language_tests/test_programs/result_inline_tests/src/main.sw @@ -1,5 +1,7 @@ library; +mod eq; + #[test] fn result_is_ok() { use std::bytes::Bytes;