diff options
author | John Wiegley <johnw@newartisans.com> | 2004-08-21 01:43:50 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2004-08-21 01:43:50 -0400 |
commit | 06ac87ab208210bef6a30cf71e116847080d2383 (patch) | |
tree | 4b9a20ad43a8723a3ab5f880f06e63c8611d669a /amount.h | |
parent | ec7f071bdd529e372fe9b8d123cebadf74e76e29 (diff) | |
download | fork-ledger-06ac87ab208210bef6a30cf71e116847080d2383.tar.gz fork-ledger-06ac87ab208210bef6a30cf71e116847080d2383.tar.bz2 fork-ledger-06ac87ab208210bef6a30cf71e116847080d2383.zip |
support arbitrary precision after the decimal point; increase speed 0-10%
Diffstat (limited to 'amount.h')
-rw-r--r-- | amount.h | 37 |
1 files changed, 23 insertions, 14 deletions
@@ -18,10 +18,12 @@ class amount_t void _init(); void _copy(const amount_t& amt); void _clear(); + void _resize(int prec); public: - base_type quantity; // amount, to MAX_PRECISION - commodity_t * commodity; + base_type quantity; // amount, to MAX_PRECISION + unsigned short precision; + commodity_t * commodity; bool valid() const { if (quantity) @@ -32,13 +34,15 @@ class amount_t // constructors amount_t(commodity_t * _commodity = NULL) - : quantity(NULL), commodity(_commodity) {} + : quantity(NULL), precision(0), commodity(_commodity) {} amount_t(const amount_t& amt) : quantity(NULL) { - if (amt.quantity) + if (amt.quantity) { _copy(amt); - else + } else { commodity = amt.commodity; + precision = amt.precision; + } } amount_t(const std::string& value) { parse(value); @@ -67,12 +71,11 @@ class amount_t amount_t& operator=(const double value); // general methods - amount_t round(int precision = -1) const; + amount_t round(int prec = -1) const; // in-place arithmetic amount_t& operator*=(const amount_t& amt); amount_t& operator/=(const amount_t& amt); - amount_t& operator%=(const amount_t& amt); amount_t& operator+=(const amount_t& amt); amount_t& operator-=(const amount_t& amt); @@ -87,11 +90,6 @@ class amount_t temp /= amt; return temp; } - amount_t operator%(const amount_t& amt) const { - amount_t temp = *this; - temp %= amt; - return temp; - } amount_t operator+(const amount_t& amt) const { amount_t temp = *this; temp += amt; @@ -209,6 +207,7 @@ class commodity_t typedef unsigned long ident_t; std::string symbol; + bool quote; std::string name; std::string note; unsigned short precision; @@ -244,9 +243,19 @@ class commodity_t // Now the per-object constructor and methods commodity_t(const std::string& _symbol = "", - unsigned int _precision = 2, + unsigned int _precision = 0, unsigned int _flags = COMMODITY_STYLE_DEFAULTS) - : symbol(_symbol), precision(_precision), flags(_flags) {} + : symbol(_symbol), quote(false), precision(_precision), flags(_flags) { + check_symbol(); + } + + void check_symbol() { + for (const char * p = symbol.c_str(); *p; p++) + if (std::isspace(*p) || std::isdigit(*p) || *p == '-' || *p == '.') { + quote = true; + return; + } + } void add_price(const std::time_t date, const amount_t& price) { history.insert(history_pair(date, price)); |