summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2008-07-19 16:52:16 -0400
committerJohn Wiegley <johnw@newartisans.com>2008-07-19 16:52:16 -0400
commit911b86623047bdadd2ac6fde2f8006d9b1c672f8 (patch)
tree1c6d9b8e8d45c43fba2cabbe69bdf1e8d6f87380
parent2aeee0bb64b56959ebcf86165c0b31630e0f92ac (diff)
downloadfork-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.cc10
-rw-r--r--walk.cc5
2 files changed, 10 insertions, 5 deletions
diff --git a/value.cc b/value.cc
index 1ced0b96..4bb74650 100644
--- a/value.cc
+++ b/value.cc
@@ -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;
diff --git a/walk.cc b/walk.cc
index b3b024f5..88b5461a 100644
--- a/walk.cc
+++ b/walk.cc
@@ -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;
}