use super::{BigUint, IntDigits}; use core::ops::{BitAnd, BitAndAssign, BitOr, BitOrAssign, BitXor, BitXorAssign}; forward_val_val_binop!(impl BitAnd for BigUint, bitand); forward_ref_val_binop!(impl BitAnd for BigUint, bitand); // do not use forward_ref_ref_binop_commutative! for bitand so that we can // clone the smaller value rather than the larger, avoiding over-allocation impl BitAnd<&BigUint> for &BigUint { type Output = BigUint; #[inline] fn bitand(self, other: &BigUint) -> BigUint { // forward to val-ref, choosing the smaller to clone if self.data.len() <= other.data.len() { self.clone() & other } else { other.clone() & self } } } forward_val_assign!(impl BitAndAssign for BigUint, bitand_assign); impl BitAnd<&BigUint> for BigUint { type Output = BigUint; #[inline] fn bitand(mut self, other: &BigUint) -> BigUint { self &= other; self } } impl BitAndAssign<&BigUint> for BigUint { #[inline] fn bitand_assign(&mut self, other: &BigUint) { for (ai, &bi) in self.data.iter_mut().zip(other.data.iter()) { *ai &= bi; } self.data.truncate(other.data.len()); self.normalize(); } } forward_all_binop_to_val_ref_commutative!(impl BitOr for BigUint, bitor); forward_val_assign!(impl BitOrAssign for BigUint, bitor_assign); impl BitOr<&BigUint> for BigUint { type Output = BigUint; fn bitor(mut self, other: &BigUint) -> BigUint { self |= other; self } } impl BitOrAssign<&BigUint> for BigUint { #[inline] fn bitor_assign(&mut self, other: &BigUint) { for (ai, &bi) in self.data.iter_mut().zip(other.data.iter()) { *ai |= bi; } if other.data.len() > self.data.len() { let extra = &other.data[self.data.len()..]; self.data.extend(extra.iter().cloned()); } } } forward_all_binop_to_val_ref_commutative!(impl BitXor for BigUint, bitxor); forward_val_assign!(impl BitXorAssign for BigUint, bitxor_assign); impl BitXor<&BigUint> for BigUint { type Output = BigUint; fn bitxor(mut self, other: &BigUint) -> BigUint { self ^= other; self } } impl BitXorAssign<&BigUint> for BigUint { #[inline] fn bitxor_assign(&mut self, other: &BigUint) { for (ai, &bi) in self.data.iter_mut().zip(other.data.iter()) { *ai ^= bi; } if other.data.len() > self.data.len() { let extra = &other.data[self.data.len()..]; self.data.extend(extra.iter().cloned()); } self.normalize(); } }