summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2012-02-28 00:08:39 -0600
committerJohn Wiegley <johnw@newartisans.com>2012-02-28 00:08:39 -0600
commitfc62402c60cd3faac37f3cd60ee417d119869929 (patch)
tree66aeec13f31162eda41f8d3eed114c34859c386c
parent6d04f605738fe47477fdc95342008dfe7d091c1a (diff)
downloadfork-ledger-fc62402c60cd3faac37f3cd60ee417d119869929.tar.gz
fork-ledger-fc62402c60cd3faac37f3cd60ee417d119869929.tar.bz2
fork-ledger-fc62402c60cd3faac37f3cd60ee417d119869929.zip
Fixed nasty problem related to interval reporting
-rw-r--r--src/filters.cc4
-rw-r--r--src/filters.h4
-rw-r--r--src/times.h4
3 files changed, 8 insertions, 4 deletions
diff --git a/src/filters.cc b/src/filters.cc
index 331073eb..f57f37e7 100644
--- a/src/filters.cc
+++ b/src/filters.cc
@@ -924,7 +924,7 @@ void interval_posts::operator()(post_t& post)
report_subtotal(last_interval);
if (generate_empty_posts) {
- for (++last_interval; interval != last_interval; ++last_interval) {
+ for (++last_interval; last_interval < interval; ++last_interval) {
// Generate a null posting, so the intervening periods can be
// seen when -E is used, or if the calculated amount ends up being
// non-zero
@@ -940,7 +940,7 @@ void interval_posts::operator()(post_t& post)
report_subtotal(last_interval);
}
- assert(interval == last_interval);
+ assert(last_interval <= interval);
} else {
last_interval = interval;
}
diff --git a/src/filters.h b/src/filters.h
index e7a2eefa..d207d842 100644
--- a/src/filters.h
+++ b/src/filters.h
@@ -732,8 +732,8 @@ public:
virtual void flush() {
if (last_post && interval.duration) {
- if (interval.is_valid())
- report_subtotal(interval);
+ if (last_interval && interval != last_interval)
+ report_subtotal(last_interval);
subtotal_posts::flush();
}
}
diff --git a/src/times.h b/src/times.h
index 39945824..a2680ae3 100644
--- a/src/times.h
+++ b/src/times.h
@@ -553,6 +553,10 @@ public:
return (start == other.start &&
(! start || *start == *other.start));
}
+ bool operator<(const date_interval_t& other) const {
+ return (start == other.start &&
+ (! start || *start < *other.start));
+ }
operator bool() const {
return is_valid();