Rename `Zero` variant to `NoSign`

This commit is contained in:
Jorge Aparicio 2014-09-20 19:58:59 -05:00
parent 998e6c89b1
commit dc3fed0add
1 changed files with 31 additions and 31 deletions

View File

@ -616,7 +616,7 @@ impl ToBigUint for BigInt {
fn to_biguint(&self) -> Option<BigUint> { fn to_biguint(&self) -> Option<BigUint> {
if self.sign == Plus { if self.sign == Plus {
Some(self.data.clone()) Some(self.data.clone())
} else if self.sign == Zero { } else if self.sign == NoSign {
Some(Zero::zero()) Some(Zero::zero())
} else { } else {
None None
@ -836,7 +836,7 @@ fn get_radix_base(radix: uint) -> (DoubleBigDigit, uint) {
/// A Sign is a `BigInt`'s composing element. /// A Sign is a `BigInt`'s composing element.
#[deriving(PartialEq, PartialOrd, Eq, Ord, Clone, Show)] #[deriving(PartialEq, PartialOrd, Eq, Ord, Clone, Show)]
pub enum Sign { Minus, Zero, Plus } pub enum Sign { Minus, NoSign, Plus }
impl Neg<Sign> for Sign { impl Neg<Sign> for Sign {
/// Negate Sign value. /// Negate Sign value.
@ -844,7 +844,7 @@ impl Neg<Sign> for Sign {
fn neg(&self) -> Sign { fn neg(&self) -> Sign {
match *self { match *self {
Minus => Plus, Minus => Plus,
Zero => Zero, NoSign => NoSign,
Plus => Minus Plus => Minus
} }
} }
@ -880,7 +880,7 @@ impl Ord for BigInt {
if scmp != Equal { return scmp; } if scmp != Equal { return scmp; }
match self.sign { match self.sign {
Zero => Equal, NoSign => Equal,
Plus => self.data.cmp(&other.data), Plus => self.data.cmp(&other.data),
Minus => other.data.cmp(&self.data), Minus => other.data.cmp(&self.data),
} }
@ -931,11 +931,11 @@ impl Shr<uint, BigInt> for BigInt {
impl Zero for BigInt { impl Zero for BigInt {
#[inline] #[inline]
fn zero() -> BigInt { fn zero() -> BigInt {
BigInt::from_biguint(Zero, Zero::zero()) BigInt::from_biguint(NoSign, Zero::zero())
} }
#[inline] #[inline]
fn is_zero(&self) -> bool { self.sign == Zero } fn is_zero(&self) -> bool { self.sign == NoSign }
} }
impl One for BigInt { impl One for BigInt {
@ -949,7 +949,7 @@ impl Signed for BigInt {
#[inline] #[inline]
fn abs(&self) -> BigInt { fn abs(&self) -> BigInt {
match self.sign { match self.sign {
Plus | Zero => self.clone(), Plus | NoSign => self.clone(),
Minus => BigInt::from_biguint(Plus, self.data.clone()) Minus => BigInt::from_biguint(Plus, self.data.clone())
} }
} }
@ -964,7 +964,7 @@ impl Signed for BigInt {
match self.sign { match self.sign {
Plus => BigInt::from_biguint(Plus, One::one()), Plus => BigInt::from_biguint(Plus, One::one()),
Minus => BigInt::from_biguint(Minus, One::one()), Minus => BigInt::from_biguint(Minus, One::one()),
Zero => Zero::zero(), NoSign => Zero::zero(),
} }
} }
@ -979,8 +979,8 @@ impl Add<BigInt, BigInt> for BigInt {
#[inline] #[inline]
fn add(&self, other: &BigInt) -> BigInt { fn add(&self, other: &BigInt) -> BigInt {
match (self.sign, other.sign) { match (self.sign, other.sign) {
(Zero, _) => other.clone(), (NoSign, _) => other.clone(),
(_, Zero) => self.clone(), (_, NoSign) => self.clone(),
(Plus, Plus) => BigInt::from_biguint(Plus, self.data + other.data), (Plus, Plus) => BigInt::from_biguint(Plus, self.data + other.data),
(Plus, Minus) => self - (-*other), (Plus, Minus) => self - (-*other),
(Minus, Plus) => other - (-*self), (Minus, Plus) => other - (-*self),
@ -993,8 +993,8 @@ impl Sub<BigInt, BigInt> for BigInt {
#[inline] #[inline]
fn sub(&self, other: &BigInt) -> BigInt { fn sub(&self, other: &BigInt) -> BigInt {
match (self.sign, other.sign) { match (self.sign, other.sign) {
(Zero, _) => -other, (NoSign, _) => -other,
(_, Zero) => self.clone(), (_, NoSign) => self.clone(),
(Plus, Plus) => match self.data.cmp(&other.data) { (Plus, Plus) => match self.data.cmp(&other.data) {
Less => BigInt::from_biguint(Minus, other.data - self.data), Less => BigInt::from_biguint(Minus, other.data - self.data),
Greater => BigInt::from_biguint(Plus, self.data - other.data), Greater => BigInt::from_biguint(Plus, self.data - other.data),
@ -1011,7 +1011,7 @@ impl Mul<BigInt, BigInt> for BigInt {
#[inline] #[inline]
fn mul(&self, other: &BigInt) -> BigInt { fn mul(&self, other: &BigInt) -> BigInt {
match (self.sign, other.sign) { match (self.sign, other.sign) {
(Zero, _) | (_, Zero) => Zero::zero(), (NoSign, _) | (_, NoSign) => Zero::zero(),
(Plus, Plus) | (Minus, Minus) => { (Plus, Plus) | (Minus, Minus) => {
BigInt::from_biguint(Plus, self.data * other.data) BigInt::from_biguint(Plus, self.data * other.data)
}, },
@ -1085,9 +1085,9 @@ impl Integer for BigInt {
let d = BigInt::from_biguint(Plus, d_ui); let d = BigInt::from_biguint(Plus, d_ui);
let r = BigInt::from_biguint(Plus, r_ui); let r = BigInt::from_biguint(Plus, r_ui);
match (self.sign, other.sign) { match (self.sign, other.sign) {
(_, Zero) => fail!(), (_, NoSign) => fail!(),
(Plus, Plus) | (Zero, Plus) => ( d, r), (Plus, Plus) | (NoSign, Plus) => ( d, r),
(Plus, Minus) | (Zero, Minus) => (-d, r), (Plus, Minus) | (NoSign, Minus) => (-d, r),
(Minus, Plus) => (-d, -r), (Minus, Plus) => (-d, -r),
(Minus, Minus) => ( d, -r) (Minus, Minus) => ( d, -r)
} }
@ -1111,9 +1111,9 @@ impl Integer for BigInt {
let d = BigInt::from_biguint(Plus, d_ui); let d = BigInt::from_biguint(Plus, d_ui);
let m = BigInt::from_biguint(Plus, m_ui); let m = BigInt::from_biguint(Plus, m_ui);
match (self.sign, other.sign) { match (self.sign, other.sign) {
(_, Zero) => fail!(), (_, NoSign) => fail!(),
(Plus, Plus) | (Zero, Plus) => (d, m), (Plus, Plus) | (NoSign, Plus) => (d, m),
(Plus, Minus) | (Zero, Minus) => if m.is_zero() { (Plus, Minus) | (NoSign, Minus) => if m.is_zero() {
(-d, Zero::zero()) (-d, Zero::zero())
} else { } else {
(-d - One::one(), m + *other) (-d - One::one(), m + *other)
@ -1164,7 +1164,7 @@ impl ToPrimitive for BigInt {
fn to_i64(&self) -> Option<i64> { fn to_i64(&self) -> Option<i64> {
match self.sign { match self.sign {
Plus => self.data.to_i64(), Plus => self.data.to_i64(),
Zero => Some(0), NoSign => Some(0),
Minus => { Minus => {
self.data.to_u64().and_then(|n| { self.data.to_u64().and_then(|n| {
let m: u64 = 1 << 63; let m: u64 = 1 << 63;
@ -1184,7 +1184,7 @@ impl ToPrimitive for BigInt {
fn to_u64(&self) -> Option<u64> { fn to_u64(&self) -> Option<u64> {
match self.sign { match self.sign {
Plus => self.data.to_u64(), Plus => self.data.to_u64(),
Zero => Some(0), NoSign => Some(0),
Minus => None Minus => None
} }
} }
@ -1270,7 +1270,7 @@ impl ToStrRadix for BigInt {
fn to_str_radix(&self, radix: uint) -> String { fn to_str_radix(&self, radix: uint) -> String {
match self.sign { match self.sign {
Plus => self.data.to_str_radix(radix), Plus => self.data.to_str_radix(radix),
Zero => "0".to_string(), NoSign => "0".to_string(),
Minus => format!("-{}", self.data.to_str_radix(radix)), Minus => format!("-{}", self.data.to_str_radix(radix)),
} }
} }
@ -1332,7 +1332,7 @@ impl<R: Rng> RandBigInt for R {
if self.gen() { if self.gen() {
return self.gen_bigint(bit_size); return self.gen_bigint(bit_size);
} else { } else {
Zero NoSign
} }
} else if self.gen() { } else if self.gen() {
Plus Plus
@ -1383,8 +1383,8 @@ impl BigInt {
/// The digits are be in base 2^32. /// The digits are be in base 2^32.
#[inline] #[inline]
pub fn from_biguint(sign: Sign, data: BigUint) -> BigInt { pub fn from_biguint(sign: Sign, data: BigUint) -> BigInt {
if sign == Zero || data.is_zero() { if sign == NoSign || data.is_zero() {
return BigInt { sign: Zero, data: Zero::zero() }; return BigInt { sign: NoSign, data: Zero::zero() };
} }
BigInt { sign: sign, data: data } BigInt { sign: sign, data: data }
} }
@ -1413,7 +1413,7 @@ impl BigInt {
pub fn to_biguint(&self) -> Option<BigUint> { pub fn to_biguint(&self) -> Option<BigUint> {
match self.sign { match self.sign {
Plus => Some(self.data.clone()), Plus => Some(self.data.clone()),
Zero => Some(Zero::zero()), NoSign => Some(Zero::zero()),
Minus => None Minus => None
} }
} }
@ -2286,7 +2286,7 @@ mod biguint_tests {
mod bigint_tests { mod bigint_tests {
use Integer; use Integer;
use super::{BigDigit, BigUint, ToBigUint}; use super::{BigDigit, BigUint, ToBigUint};
use super::{Sign, Minus, Zero, Plus, BigInt, RandBigInt, ToBigInt}; use super::{Sign, Minus, NoSign, Plus, BigInt, RandBigInt, ToBigInt};
use std::cmp::{Less, Equal, Greater}; use std::cmp::{Less, Equal, Greater};
use std::i64; use std::i64;
@ -2305,9 +2305,9 @@ mod bigint_tests {
assert_eq!(inp, ans); assert_eq!(inp, ans);
} }
check(Plus, 1, Plus, 1); check(Plus, 1, Plus, 1);
check(Plus, 0, Zero, 0); check(Plus, 0, NoSign, 0);
check(Minus, 1, Minus, 1); check(Minus, 1, Minus, 1);
check(Zero, 1, Zero, 0); check(NoSign, 1, NoSign, 0);
} }
#[test] #[test]
@ -2355,8 +2355,8 @@ mod bigint_tests {
#[test] #[test]
fn test_hash() { fn test_hash() {
let a = BigInt::new(Zero, vec!()); let a = BigInt::new(NoSign, vec!());
let b = BigInt::new(Zero, vec!(0)); let b = BigInt::new(NoSign, vec!(0));
let c = BigInt::new(Plus, vec!(1)); let c = BigInt::new(Plus, vec!(1));
let d = BigInt::new(Plus, vec!(1,0,0,0,0,0)); let d = BigInt::new(Plus, vec!(1,0,0,0,0,0));
let e = BigInt::new(Plus, vec!(0,0,0,0,0,1)); let e = BigInt::new(Plus, vec!(0,0,0,0,0,1));