summaryrefslogtreecommitdiff
path: root/amount.h
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2004-08-21 01:43:50 -0400
committerJohn Wiegley <johnw@newartisans.com>2004-08-21 01:43:50 -0400
commit06ac87ab208210bef6a30cf71e116847080d2383 (patch)
tree4b9a20ad43a8723a3ab5f880f06e63c8611d669a /amount.h
parentec7f071bdd529e372fe9b8d123cebadf74e76e29 (diff)
downloadfork-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.h37
1 files changed, 23 insertions, 14 deletions
diff --git a/amount.h b/amount.h
index 040c3ff3..2e8e526e 100644
--- a/amount.h
+++ b/amount.h
@@ -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));