velvia commented on a change in pull request #8688: URL: https://github.com/apache/arrow/pull/8688#discussion_r528960800
########## File path: rust/arrow/src/compute/kernels/boolean.rs ########## @@ -457,4 +517,42 @@ mod tests { assert_eq!(true, res.value(2)); assert_eq!(false, res.value(3)); } + + fn assert_array_eq<T: ArrowNumericType>( + expected: PrimitiveArray<T>, + actual: ArrayRef, + ) { + let actual = actual + .as_any() + .downcast_ref::<PrimitiveArray<T>>() + .expect("Actual array should unwrap to type of expected array"); + + for i in 0..expected.len() { + if expected.is_null(i) { + assert!(actual.is_null(i)); + } else { + assert_eq!(expected.value(i), actual.value(i)); + } + } + } + Review comment: Thanks everyone for their comments. It seems to me that taking a slice of the data buffer would be even more expensive than shifting the null buffer? However it is easier to implement for now, so I will try @jhorstmann 's suggestion using `bit_slice()` on the data buffers - would rather get in something that works sooner and iterate later when @vertexclique 's PR is merged. ---------------------------------------------------------------- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. For queries about this service, please contact Infrastructure at: us...@infra.apache.org