summaryrefslogtreecommitdiff
path: root/value.h
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2006-03-06 03:53:36 +0000
committerJohn Wiegley <johnw@newartisans.com>2008-04-13 02:41:29 -0400
commitb737cd8e6dd185beeae902caa4eee6c4cee8bc36 (patch)
tree967b198e0d52c8d0f2ae2215c90224a6ff48194d /value.h
parentd02f74efea3e6b631810bfd3c3d8adcaa4299902 (diff)
downloadfork-ledger-b737cd8e6dd185beeae902caa4eee6c4cee8bc36.tar.gz
fork-ledger-b737cd8e6dd185beeae902caa4eee6c4cee8bc36.tar.bz2
fork-ledger-b737cd8e6dd185beeae902caa4eee6c4cee8bc36.zip
Added a DATETIME value type.
Diffstat (limited to 'value.h')
-rw-r--r--value.h72
1 files changed, 33 insertions, 39 deletions
diff --git a/value.h b/value.h
index 9c14ed10..22110b43 100644
--- a/value.h
+++ b/value.h
@@ -36,6 +36,7 @@ class value_t
enum type_t {
BOOLEAN,
INTEGER,
+ DATETIME,
AMOUNT,
BALANCE,
BALANCE_PAIR
@@ -57,6 +58,10 @@ class value_t
*((long *) data) = value;
type = INTEGER;
}
+ value_t(const datetime_t value) {
+ *((datetime_t *) data) = value;
+ type = DATETIME;
+ }
value_t(const unsigned long value) {
new((amount_t *) data) amount_t(value);
type = AMOUNT;
@@ -108,6 +113,14 @@ class value_t
}
return *this;
}
+ value_t& operator=(const datetime_t value) {
+ if ((datetime_t *) data != &value) {
+ destroy();
+ *((datetime_t *) data) = value;
+ type = DATETIME;
+ }
+ return *this;
+ }
value_t& operator=(const unsigned long value) {
return *this = amount_t(value);
}
@@ -284,6 +297,8 @@ class value_t
return ! *((bool *) data);
case INTEGER:
return *((long *) data) == 0;
+ case DATETIME:
+ return ! *((datetime_t *) data);
case AMOUNT:
return ((amount_t *) data)->realzero();
case BALANCE:
@@ -299,46 +314,19 @@ class value_t
return 0;
}
- void abs();
- void cast(type_t cast_type);
- value_t cost() const;
- value_t price() const;
- value_t date() const;
- value_t reduce(const bool keep_price = false,
- const bool keep_date = false,
- const bool keep_tag = false) const;
- value_t& add(const amount_t& amount, const amount_t * cost = NULL);
+ void abs();
+ void cast(type_t cast_type);
+ value_t cost() const;
+ value_t price() const;
+ value_t date() const;
- value_t value(const std::time_t moment) const {
- switch (type) {
- case BOOLEAN:
- case INTEGER:
- return *this;
- case AMOUNT:
- return ((amount_t *) data)->value(moment);
- case BALANCE:
- return ((balance_t *) data)->value(moment);
- case BALANCE_PAIR:
- return ((balance_pair_t *) data)->quantity.value(moment);
- }
- }
+ value_t strip_annotations(const bool keep_price = amount_t::keep_price,
+ const bool keep_date = amount_t::keep_date,
+ const bool keep_tag = amount_t::keep_tag) const;
- void round() {
- switch (type) {
- case BOOLEAN:
- case INTEGER:
- break;
- case AMOUNT:
- *((amount_t *) data) = ((amount_t *) data)->round();
- break;
- case BALANCE:
- ((balance_t *) data)->round();
- break;
- case BALANCE_PAIR:
- ((balance_pair_t *) data)->round();
- break;
- }
- }
+ value_t& add(const amount_t& amount, const amount_t * cost = NULL);
+ value_t value(const std::time_t moment) const;
+ void round();
};
#define DEF_VALUE_AUX_OP(OP) \
@@ -379,6 +367,8 @@ value_t::operator T() const
return *((bool *) data);
case INTEGER:
return *((long *) data);
+ case DATETIME:
+ return *((datetime_t *) data);
case AMOUNT:
return *((amount_t *) data);
case BALANCE:
@@ -395,6 +385,7 @@ value_t::operator T() const
}
template <> value_t::operator long() const;
+template <> value_t::operator datetime_t() const;
template <> value_t::operator double() const;
inline value_t abs(const value_t& value) {
@@ -406,11 +397,14 @@ inline value_t abs(const value_t& value) {
inline std::ostream& operator<<(std::ostream& out, const value_t& value) {
switch (value.type) {
case value_t::BOOLEAN:
- out << *((bool *) value.data);
+ out << *((bool *) value.data) ? "true" : "false";
break;
case value_t::INTEGER:
out << *((long *) value.data);
break;
+ case value_t::DATETIME:
+ out << *((datetime_t *) value.data);
+ break;
case value_t::AMOUNT:
out << *((amount_t *) value.data);
break;