diff options
author | John Wiegley <johnw@newartisans.com> | 2008-07-19 16:52:16 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2008-07-19 16:52:16 -0400 |
commit | 911b86623047bdadd2ac6fde2f8006d9b1c672f8 (patch) | |
tree | 1c6d9b8e8d45c43fba2cabbe69bdf1e8d6f87380 | |
parent | 2aeee0bb64b56959ebcf86165c0b31630e0f92ac (diff) | |
download | fork-ledger-911b86623047bdadd2ac6fde2f8006d9b1c672f8.tar.gz fork-ledger-911b86623047bdadd2ac6fde2f8006d9b1c672f8.tar.bz2 fork-ledger-911b86623047bdadd2ac6fde2f8006d9b1c672f8.zip |
When converting datetime_t to a long, I now need to directly access the 'when'
member, otherwise C++ chooses the bool conversion, which is always wrong.
-rw-r--r-- | value.cc | 10 | ||||
-rw-r--r-- | walk.cc | 5 |
2 files changed, 10 insertions, 5 deletions
@@ -630,7 +630,7 @@ bool value_t::operator OP(const value_t& value) \ \ case DATETIME: \ return (*((long *) data) OP \ - ((long) *((datetime_t *) value.data))); \ + ((long) ((datetime_t *) value.data)->when)); \ \ case AMOUNT: \ return (amount_t(*((long *) data)) OP \ @@ -657,7 +657,7 @@ bool value_t::operator OP(const value_t& value) \ \ case INTEGER: \ return (*((datetime_t *) data) OP \ - datetime_t(*((long *) value.data))); \ + datetime_t(std::time_t(*((long *) value.data)))); \ \ case DATETIME: \ return (*((datetime_t *) data) OP \ @@ -786,7 +786,7 @@ value_t::operator long() const case INTEGER: return *((long *) data); case DATETIME: - return *((datetime_t *) data); + return ((datetime_t *) data)->when; case AMOUNT: return *((amount_t *) data); case BALANCE: @@ -884,7 +884,7 @@ void value_t::cast(type_t cast_type) case INTEGER: break; case DATETIME: - *((datetime_t *) data) = datetime_t(*((long *) data)); + *((datetime_t *) data) = datetime_t(std::time_t(*((long *) data))); break; case AMOUNT: new((amount_t *)data) amount_t(*((long *) data)); @@ -908,7 +908,7 @@ void value_t::cast(type_t cast_type) *((bool *) data) = *((datetime_t *) data); break; case INTEGER: - *((long *) data) = *((datetime_t *) data); + *((long *) data) = ((datetime_t *) data)->when; break; case DATETIME: break; @@ -28,6 +28,11 @@ bool compare_items<transaction_t>::operator()(const transaction_t * left, rxdata.dflags |= TRANSACTION_SORT_CALC; } + DEBUG_PRINT("ledger.walk.compare_items_xact", + "lxdata.sort_value = " << lxdata.sort_value); + DEBUG_PRINT("ledger.walk.compare_items_xact", + "rxdata.sort_value = " << rxdata.sort_value); + return lxdata.sort_value < rxdata.sort_value; } |