From 8c3b2de11c8ea4cefe13ccdd807ce390d75f0ee9 Mon Sep 17 00:00:00 2001 From: Alice Ryhl Date: Sat, 2 Sep 2017 23:37:54 +0200 Subject: [PATCH] Implement BitAndAssign and BitOrAssign for BigUint --- bigint/src/biguint.rs | 38 +++++++++++++++++++++++++------------- 1 file changed, 25 insertions(+), 13 deletions(-) diff --git a/bigint/src/biguint.rs b/bigint/src/biguint.rs index d65e06f..678617d 100644 --- a/bigint/src/biguint.rs +++ b/bigint/src/biguint.rs @@ -1,7 +1,7 @@ use std::borrow::Cow; use std::default::Default; use std::iter::repeat; -use std::ops::{Add, BitAnd, BitOr, BitXor, Div, Mul, Neg, Rem, Shl, Shr, Sub, AddAssign, SubAssign, MulAssign, DivAssign, RemAssign}; +use std::ops::{Add, BitAnd, BitOr, BitXor, Div, Mul, Neg, Rem, Shl, Shr, Sub, AddAssign, SubAssign, MulAssign, DivAssign, RemAssign, BitAndAssign, BitOrAssign}; use std::str::{self, FromStr}; use std::fmt; use std::cmp; @@ -268,36 +268,48 @@ impl Num for BigUint { } forward_all_binop_to_val_ref_commutative!(impl BitAnd for BigUint, bitand); +forward_val_assign!(impl BitAndAssign for BigUint, bitand_assign); impl<'a> BitAnd<&'a BigUint> for BigUint { type Output = BigUint; #[inline] - fn bitand(self, other: &BigUint) -> BigUint { - let mut data = self.data; - for (ai, &bi) in data.iter_mut().zip(other.data.iter()) { + fn bitand(mut self, other: &BigUint) -> BigUint { + self &= other; + self + } +} +impl<'a> BitAndAssign<&'a 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; } - data.truncate(other.data.len()); - BigUint::new(data) + self.data.truncate(other.data.len()); } } forward_all_binop_to_val_ref_commutative!(impl BitOr for BigUint, bitor); +forward_val_assign!(impl BitOrAssign for BigUint, bitor_assign); impl<'a> BitOr<&'a BigUint> for BigUint { type Output = BigUint; - fn bitor(self, other: &BigUint) -> BigUint { - let mut data = self.data; - for (ai, &bi) in data.iter_mut().zip(other.data.iter()) { + fn bitor(mut self, other: &BigUint) -> BigUint { + self |= other; + self + } +} +impl<'a> BitOrAssign<&'a 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() > data.len() { - let extra = &other.data[data.len()..]; - data.extend(extra.iter().cloned()); + if other.data.len() > self.data.len() { + let extra = &other.data[self.data.len()..]; + self.data.extend(extra.iter().cloned()); } - BigUint::new(data) } }