summaryrefslogtreecommitdiff
path: root/src/report.h
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2009-11-18 05:45:48 -0500
committerJohn Wiegley <johnw@newartisans.com>2009-11-18 05:45:48 -0500
commite4b3f0bb3a74b799f0f67d8b2f1efeedad5e2021 (patch)
tree605879730937c258e41090302bff105c6d0a96a1 /src/report.h
parent7fe369eb492f737f570d0ccf4aaf5db68f900279 (diff)
downloadfork-ledger-e4b3f0bb3a74b799f0f67d8b2f1efeedad5e2021.tar.gz
fork-ledger-e4b3f0bb3a74b799f0f67d8b2f1efeedad5e2021.tar.bz2
fork-ledger-e4b3f0bb3a74b799f0f67d8b2f1efeedad5e2021.zip
The new period parser is passing all tests
Diffstat (limited to 'src/report.h')
-rw-r--r--src/report.h31
1 files changed, 18 insertions, 13 deletions
diff --git a/src/report.h b/src/report.h
index 93f6e9e0..0b1baff1 100644
--- a/src/report.h
+++ b/src/report.h
@@ -50,6 +50,7 @@
#include "option.h"
#include "commodity.h"
#include "annotate.h"
+#include "session.h"
#include "format.h"
namespace ledger {
@@ -352,7 +353,7 @@ public:
set_expr(args[0].to_string(), args[1].to_string());
});
- OPTION(report_t, amount_data);
+ OPTION(report_t, amount_data); // -j
OPTION(report_t, anon);
OPTION_(report_t, average, DO() { // -A
@@ -377,14 +378,14 @@ public:
});
OPTION_(report_t, begin_, DO_(args) { // -b
- date_interval_t interval(args[1].to_string());
- if (! interval.start)
+ date_interval_t interval(args[1].to_string());
+ optional<date_t> begin = interval.begin(parent->session.current_year);
+ if (! begin)
throw_(std::invalid_argument,
_("Could not determine beginning of period '%1'")
<< args[1].to_string());
- string predicate =
- "date>=[" + to_iso_extended_string(*interval.start) + "]";
+ string predicate = "date>=[" + to_iso_extended_string(*begin) + "]";
parent->HANDLER(limit_).on(string("--begin"), predicate);
});
@@ -524,17 +525,19 @@ public:
OPTION(report_t, empty); // -E
OPTION_(report_t, end_, DO_(args) { // -e
- date_interval_t interval(args[1].to_string());
- if (! interval.start)
+ date_interval_t interval(args[1].to_string());
+ // Use begin() here so that if the user says --end=2008, we end on
+ // 2008/01/01 instead of 2009/01/01 (which is what end() would return).
+ optional<date_t> end = interval.begin(parent->session.current_year);
+ if (! end)
throw_(std::invalid_argument,
_("Could not determine end of period '%1'")
<< args[1].to_string());
- string predicate =
- "date<[" + to_iso_extended_string(*interval.start) + "]";
+ string predicate = "date<[" + to_iso_extended_string(*end) + "]";
parent->HANDLER(limit_).on(string("--end"), predicate);
- parent->terminus = datetime_t(*interval.start);
+ parent->terminus = datetime_t(*end);
});
OPTION(report_t, equity);
@@ -622,11 +625,13 @@ public:
OPTION_(report_t, now_, DO_(args) {
date_interval_t interval(args[1].to_string());
- if (! interval.start)
+ optional<date_t> begin = interval.begin(parent->session.current_year);
+ if (! begin)
throw_(std::invalid_argument,
_("Could not determine beginning of period '%1'")
<< args[1].to_string());
- ledger::epoch = datetime_t(*interval.start);
+ ledger::epoch = parent->terminus = datetime_t(*begin);
+ parent->session.current_year = ledger::epoch->date().year();
});
OPTION__
@@ -844,7 +849,7 @@ public:
set_expr(args[0].to_string(), args[1].to_string());
});
- OPTION(report_t, total_data);
+ OPTION(report_t, total_data); // -J
OPTION_(report_t, truncate_, DO_(args) {
string style(args[1].to_string());