From 91d1c03f44c505a2e88e1d6b1d28cbf800932560 Mon Sep 17 00:00:00 2001 From: Josh Pschorr Date: Tue, 7 Jan 2025 10:26:54 -0800 Subject: [PATCH] Fix deep-equality as per specification of `eqg` --- extension/partiql-extension-ion/src/boxed_ion.rs | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/extension/partiql-extension-ion/src/boxed_ion.rs b/extension/partiql-extension-ion/src/boxed_ion.rs index 68242f21..4ed715f8 100644 --- a/extension/partiql-extension-ion/src/boxed_ion.rs +++ b/extension/partiql-extension-ion/src/boxed_ion.rs @@ -233,7 +233,12 @@ impl<'a, const NULLS_EQUAL: bool, const NAN_EQUAL: bool> NullableEq { fn eq(&self, rhs: &Self) -> Value { let wrap = IonEqualityValue::<'a, { NULLS_EQUAL }, { NAN_EQUAL }, _>; - wrap(&self.0.doc).eq(&wrap(&rhs.0.doc)) + NullableEq::eq(&wrap(&self.0.doc), &wrap(&rhs.0.doc)) + } + #[inline(always)] + fn eqg(&self, rhs: &Self) -> Value { + let wrap = IonEqualityValue::<'_, true, { NAN_EQUAL }, _>; + NullableEq::eq(&wrap(self.0), &wrap(rhs.0)) } #[inline(always)] @@ -650,7 +655,7 @@ impl<'a, const NULLS_EQUAL: bool, const NAN_EQUAL: bool> NullableEq let (l, r) = (self.0, other.0); let l = l.iter().map(wrap); let r = r.iter().map(wrap); - let res = l.zip(r).all(|(l, r)| l == r); + let res = l.zip(r).all(|(l, r)| l.eqg(&r) == Value::Boolean(true)); Value::Boolean(res) } @@ -669,9 +674,9 @@ impl<'a, const NULLS_EQUAL: bool, const NAN_EQUAL: bool> NullableEq let (l, r) = (self.0, other.0); let l = l.iter().map(|(s, elt)| (s, wrap(elt))); let r = r.iter().map(|(s, elt)| (s, wrap(elt))); - let res = l.zip(r).all(|((ls, lelt), (rs, relt))| { - ls == rs && NullableEq::eq(&lelt, &relt) == Value::Boolean(true) - }); + let res = l + .zip(r) + .all(|((ls, lelt), (rs, relt))| ls == rs && lelt.eqg(&relt) == Value::Boolean(true)); Value::Boolean(res) }