summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNicolas "Pixel" Noble <pixel@nobis-crew.org>2013-08-12 00:59:14 +0200
committerNicolas "Pixel" Noble <pixel@nobis-crew.org>2013-08-12 00:59:14 +0200
commit0bea5c6d944beaa8fc880f646be207b03d1486fd (patch)
tree6c831cfe98d6172f05f17543eb8f45fa7828b43a
parentf4568a9015f99c40e69c3ced829833155316cf04 (diff)
Normalizing the neg syntax, and adding the import / export calls.
-rw-r--r--includes/BigInt.h7
-rw-r--r--src/BigInt.cc38
2 files changed, 38 insertions, 7 deletions
diff --git a/includes/BigInt.h b/includes/BigInt.h
index 55a5c75..a94396c 100644
--- a/includes/BigInt.h
+++ b/includes/BigInt.h
@@ -56,7 +56,8 @@ class BigInt {
comp_t comp(const BigInt &) const throw (GeneralException);
comp_t comp(unsigned int) const throw (GeneralException);
- BigInt & neg() throw (GeneralException);
+ BigInt neg() const throw (GeneralException);
+ BigInt & do_neg() throw (GeneralException);
BigInt sqrt() const throw (GeneralException);
BigInt & do_sqrt() throw (GeneralException);
@@ -93,6 +94,10 @@ class BigInt {
bool isPrime() const throw (GeneralException);
+ size_t exportSize() const;
+ void exportBin(void *) const throw (GeneralException);
+ void importBin(const void *, size_t) throw (GeneralException);
+
String toString(int radix = 10) const;
char * makeString(int radix = 10) const;
diff --git a/src/BigInt.cc b/src/BigInt.cc
index 3f4b275..3735ad7 100644
--- a/src/BigInt.cc
+++ b/src/BigInt.cc
@@ -82,7 +82,7 @@ void Balau::BigInt::set(int64_t v) {
} else {
v = -v;
set((uint64_t) v);
- neg();
+ do_neg();
}
}
@@ -97,7 +97,7 @@ void Balau::BigInt::set(int32_t v) {
} else {
v = -v;
set((uint32_t) v);
- neg();
+ do_neg();
}
}
@@ -262,9 +262,7 @@ Balau::BigInt & Balau::BigInt::operator>>=(unsigned int a) {
}
Balau::BigInt Balau::BigInt::operator-() const throw (GeneralException) {
- BigInt r(*this);
- r.neg();
- return r;
+ return neg();
}
Balau::BigInt & Balau::BigInt::operator++() {
@@ -289,9 +287,17 @@ Balau::BigInt Balau::BigInt::operator--(int) {
return r;
}
-Balau::BigInt & Balau::BigInt::neg() throw (GeneralException) {
+Balau::BigInt Balau::BigInt::neg() const throw (GeneralException) {
+ BigInt r;
+ if (mp_neg(m_bi, r.m_bi) != CRYPT_OK)
+ throw GeneralException("Error while calling mp_neg");
+ return r;
+}
+
+Balau::BigInt & Balau::BigInt::do_neg() throw (GeneralException) {
if (mp_neg(m_bi, m_bi) != CRYPT_OK)
throw GeneralException("Error while calling mp_neg");
+ return *this;
}
Balau::BigInt Balau::BigInt::sqrt() const throw (GeneralException) {
@@ -494,6 +500,26 @@ bool Balau::BigInt::isPrime() const throw (GeneralException) {
return r == LTC_MP_YES;
}
+size_t Balau::BigInt::exportSize() const {
+ return mp_unsigned_bin_size(m_bi) + 1;
+}
+
+void Balau::BigInt::exportBin(void * _buf) const throw (GeneralException) {
+ unsigned char * buf = (unsigned char *) _buf;
+ buf[0] = comp(0) == LT ? 0xff : 0;
+ if (mp_to_unsigned_bin(m_bi, buf + 1) != CRYPT_OK)
+ throw GeneralException("Error while calling mp_to_unsigned_bin");
+}
+
+void Balau::BigInt::importBin(const void * _buf, size_t size) throw (GeneralException) {
+ unsigned char * buf = (unsigned char *) _buf;
+ bool isNeg = buf[0] != 0;
+ if (mp_read_unsigned_bin(m_bi, buf + 1, size - 1) != CRYPT_OK)
+ throw GeneralException("Error while calling mp_read_unsigned_bin");
+ if (isNeg)
+ do_neg();
+}
+
Balau::String Balau::BigInt::toString(int radix) const {
char * out = (char *) alloca(mp_count_bits(m_bi) / (radix >= 10 ? 3 : 1) + 3);
mp_toradix(m_bi, out, radix);