summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/amount.cc21
1 files changed, 13 insertions, 8 deletions
diff --git a/src/amount.cc b/src/amount.cc
index e53a2434..885eaf43 100644
--- a/src/amount.cc
+++ b/src/amount.cc
@@ -75,7 +75,7 @@ struct amount_t::bigint_t : public supports_flags<>
}
bool valid() const {
- if (prec > 128) {
+ if (prec > 1024) {
DEBUG("ledger.validate", "amount_t::bigint_t: prec > 128");
return false;
}
@@ -83,6 +83,11 @@ struct amount_t::bigint_t : public supports_flags<>
DEBUG("ledger.validate", "amount_t::bigint_t: ref > 16535");
return false;
}
+ if (flags() & ~(BIGINT_BULK_ALLOC | BIGINT_KEEP_PREC)) {
+ DEBUG("ledger.validate",
+ "amount_t::bigint_t: flags() & ~(BULK_ALLOC | KEEP_PREC)");
+ return false;
+ }
return true;
}
};
@@ -142,12 +147,12 @@ void amount_t::_copy(const amount_t& amt)
}
commodity_ = amt.commodity_;
- assert(valid());
+ VERIFY(valid());
}
void amount_t::_dup()
{
- assert(valid());
+ VERIFY(valid());
if (quantity->ref > 1) {
bigint_t * q = new bigint_t(*quantity);
@@ -155,7 +160,7 @@ void amount_t::_dup()
quantity = q;
}
- assert(valid());
+ VERIFY(valid());
}
void amount_t::_clear()
@@ -171,7 +176,7 @@ void amount_t::_clear()
void amount_t::_release()
{
- assert(valid());
+ VERIFY(valid());
DEBUG("amounts.refs", quantity << " ref--, now " << (quantity->ref - 1));
@@ -184,7 +189,7 @@ void amount_t::_release()
commodity_ = NULL;
}
- assert(valid());
+ VERIFY(valid());
}
@@ -982,7 +987,7 @@ bool amount_t::parse(std::istream& in, const parse_flags_t& flags)
safe_holder.release(); // `this->quantity' owns the pointer
- assert(valid());
+ VERIFY(valid());
return true;
}
@@ -1008,7 +1013,7 @@ void amount_t::parse_conversion(const string& larger_str,
void amount_t::print(std::ostream& _out) const
{
- assert(valid());
+ VERIFY(valid());
if (! quantity) {
_out << "<null>";