summaryrefslogtreecommitdiff
path: root/amount.h
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2004-09-21 03:41:40 -0400
committerJohn Wiegley <johnw@newartisans.com>2004-09-21 03:41:40 -0400
commit9f8a32ab48d38fe74da2042c0a438fc88543acef (patch)
tree5b344e35b8f3cb72c04c2e5d9716113e1c09f13e /amount.h
parent565a128b1a2eac7d6603d972dd3e14ce80c53c61 (diff)
downloadfork-ledger-9f8a32ab48d38fe74da2042c0a438fc88543acef.tar.gz
fork-ledger-9f8a32ab48d38fe74da2042c0a438fc88543acef.tar.bz2
fork-ledger-9f8a32ab48d38fe74da2042c0a438fc88543acef.zip
fixed several issues in value_t's core
Diffstat (limited to 'amount.h')
-rw-r--r--amount.h80
1 files changed, 53 insertions, 27 deletions
diff --git a/amount.h b/amount.h
index 3d165b34..dd8ff335 100644
--- a/amount.h
+++ b/amount.h
@@ -91,16 +91,20 @@ class amount_t
amount_t& operator*=(const amount_t& amt);
amount_t& operator/=(const amount_t& amt);
- amount_t& operator+=(const int value) {
+ template <typename T>
+ amount_t& operator+=(T value) {
return *this += amount_t(value);
}
- amount_t& operator-=(const int value) {
+ template <typename T>
+ amount_t& operator-=(T value) {
return *this -= amount_t(value);
}
- amount_t& operator*=(const int value) {
+ template <typename T>
+ amount_t& operator*=(T value) {
return *this *= amount_t(value);
}
- amount_t& operator/=(const int value) {
+ template <typename T>
+ amount_t& operator/=(T value) {
return *this /= amount_t(value);
}
@@ -126,22 +130,26 @@ class amount_t
return temp;
}
- amount_t operator+(const int value) const {
+ template <typename T>
+ amount_t operator+(T value) const {
amount_t temp = *this;
temp += value;
return temp;
}
- amount_t operator-(const int value) const {
+ template <typename T>
+ amount_t operator-(T value) const {
amount_t temp = *this;
temp -= value;
return temp;
}
- amount_t operator*(const int value) const {
+ template <typename T>
+ amount_t operator*(T value) const {
amount_t temp = *this;
temp *= value;
return temp;
}
- amount_t operator/(const int value) const {
+ template <typename T>
+ amount_t operator/(T value) const {
amount_t temp = *this;
temp /= value;
return temp;
@@ -161,25 +169,6 @@ class amount_t
// test for non-zero (use ! for zero)
operator bool() const;
- // integer comparisons
- bool operator<(const int num) const;
- bool operator<=(const int num) const;
- bool operator>(const int num) const;
- bool operator>=(const int num) const;
- bool operator==(const int num) const;
- bool operator!=(const int num) const {
- return ! (*this == num);
- }
-
- bool operator<(const unsigned int num) const;
- bool operator<=(const unsigned int num) const;
- bool operator>(const unsigned int num) const;
- bool operator>=(const unsigned int num) const;
- bool operator==(const unsigned int num) const;
- bool operator!=(const unsigned int num) const {
- return ! (*this == num);
- }
-
// comparisons between amounts
bool operator<(const amount_t& amt) const;
bool operator<=(const amount_t& amt) const;
@@ -192,6 +181,43 @@ class amount_t
return ! (*this == amt);
}
+ template <typename T>
+ void parse_num(T num) {
+ std::string str;
+ { std::ostringstream strstr(str);
+ strstr << num;
+ }
+ { std::istringstream strstr(str);
+ parse(strstr);
+ }
+ }
+
+ int sign() const;
+
+ // POD comparisons
+#define AMOUNT_CMP_INT(OP) \
+ template <typename T> \
+ bool operator OP (T num) const { \
+ if (num == 0) { \
+ return sign() OP 0; \
+ } else { \
+ amount_t amt; \
+ amt.parse_num(num); \
+ return *this OP amt; \
+ } \
+ }
+
+ AMOUNT_CMP_INT(<)
+ AMOUNT_CMP_INT(<=)
+ AMOUNT_CMP_INT(>)
+ AMOUNT_CMP_INT(>=)
+ AMOUNT_CMP_INT(==)
+
+ template <typename T>
+ bool operator!=(T num) const {
+ return ! (*this == num);
+ }
+
amount_t value(const std::time_t moment) const;
void abs() {