summaryrefslogtreecommitdiff
path: root/amount.cc
diff options
context:
space:
mode:
Diffstat (limited to 'amount.cc')
-rw-r--r--amount.cc30
1 files changed, 20 insertions, 10 deletions
diff --git a/amount.cc b/amount.cc
index a7d26256..8a880e5b 100644
--- a/amount.cc
+++ b/amount.cc
@@ -7,6 +7,8 @@
namespace ledger {
+#define MAX_PRECISION 10 // must be 2 or higher
+
//////////////////////////////////////////////////////////////////////
//
// The `amount' structure. Every transaction has an associated amount,
@@ -16,8 +18,6 @@ namespace ledger {
// default commodity is the US dollar, with a price of 1.00.
//
-#define MAX_PRECISION 10 // must be 2 or higher
-
class gmp_amount : public amount
{
bool priced;
@@ -42,13 +42,16 @@ class gmp_amount : public amount
mpz_clear(quantity);
}
+ virtual commodity * comm() const {
+ return quantity_comm;
+ }
virtual const std::string& comm_symbol() const {
assert(quantity_comm);
return quantity_comm->symbol;
}
virtual amount * copy() const;
- virtual amount * value() const;
+ virtual amount * value(amount *) const;
virtual operator bool() const;
@@ -184,13 +187,21 @@ amount * gmp_amount::copy() const
return new_amt;
}
-amount * gmp_amount::value() const
+amount * gmp_amount::value(amount * pr) const
{
- if (! priced) {
+ if (pr) {
+ gmp_amount * p = dynamic_cast<gmp_amount *>(pr);
+ assert(p);
+ gmp_amount * new_amt = new gmp_amount();
+ multiply(new_amt->quantity, quantity, p->quantity);
+ new_amt->quantity_comm = p->quantity_comm;
+ return new_amt;
+ }
+ else if (! priced) {
return copy();
- } else {
+ }
+ else {
gmp_amount * new_amt = new gmp_amount();
- new_amt->priced = false;
multiply(new_amt->quantity, quantity, price);
new_amt->quantity_comm = price_comm;
return new_amt;
@@ -455,8 +466,7 @@ static commodity * parse_amount(mpz_t out, const char * num,
commodity * comm = NULL;
if (! saw_commodity) {
- std::cerr << "Error: No commodity specified: " << value_str
- << std::endl;
+ std::cerr << "Error: No commodity specified: " << value_str << std::endl;
std::exit(1);
} else {
commodities_iterator item = commodities.find(symbol.c_str());
@@ -492,7 +502,7 @@ amount& gmp_amount::operator=(const char * num)
const char *error;
int erroffset;
static const std::string amount_re =
- "(([^-0-9/.,]+)(\\s*))?([-0-9/.,]+)((\\s*)([^-0-9/.,@]+))?";
+ "(([^-0-9/., ]+)(\\s*))?([-0-9/.,]+)((\\s*)([^-0-9/., @]+))?";
const std::string regexp =
"^" + amount_re + "(\\s*@\\s*" + amount_re + ")?$";
re = pcre_compile(regexp.c_str(), 0, &error, &erroffset, NULL);