summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/precmd.cc55
1 files changed, 29 insertions, 26 deletions
diff --git a/src/precmd.cc b/src/precmd.cc
index 173ca517..0e439b64 100644
--- a/src/precmd.cc
+++ b/src/precmd.cc
@@ -34,11 +34,29 @@
namespace ledger {
+namespace {
+ string join_args(call_scope_t& args)
+ {
+ std::ostringstream buf;
+ bool first = true;
+
+ for (std::size_t i = 0; i < args.size(); i++) {
+ if (first) {
+ buf << args[i];
+ first = false;
+ } else {
+ buf << ' ' << args[i];
+ }
+ }
+
+ return buf.str();
+ }
+}
+
value_t parse_command(call_scope_t& args)
{
- var_t<string> arg(args, 0);
-
- if (! arg) {
+ string arg = join_args(args);
+ if (arg.empty()) {
throw std::logic_error("Usage: parse TEXT");
return 1L;
}
@@ -71,22 +89,9 @@ value_t parse_command(call_scope_t& args)
value_t eval_command(call_scope_t& args)
{
- std::ostringstream buf;
- bool first = true;
-
- for (std::size_t i = 0; i < args.size(); i++) {
- if (first) {
- buf << args[i];
- first = false;
- } else {
- buf << ' ' << args[i];
- }
- }
-
report_t& report(find_scope<report_t>(args));
-
- expr_t expr(buf.str());
- value_t result(expr.calc(args).strip_annotations(report.what_to_keep()));
+ expr_t expr(join_args(args));
+ value_t result(expr.calc(args).strip_annotations(report.what_to_keep()));
if (! result.is_null())
report.output_stream << result << std::endl;
@@ -96,9 +101,8 @@ value_t eval_command(call_scope_t& args)
value_t format_command(call_scope_t& args)
{
- var_t<string> arg(args, 0);
-
- if (! arg) {
+ string arg = join_args(args);
+ if (arg.empty()) {
throw std::logic_error("Usage: format TEXT");
return 1L;
}
@@ -106,7 +110,7 @@ value_t format_command(call_scope_t& args)
report_t& report(find_scope<report_t>(args));
std::ostream& out(report.output_stream);
- format_t fmt(*arg);
+ format_t fmt(arg);
fmt.dump(out);
return 0L;
@@ -114,9 +118,8 @@ value_t format_command(call_scope_t& args)
value_t period_command(call_scope_t& args)
{
- var_t<string> arg(args, 0);
-
- if (! arg) {
+ string arg = join_args(args);
+ if (arg.empty()) {
throw std::logic_error("Usage: period TEXT");
return 1L;
}
@@ -124,7 +127,7 @@ value_t period_command(call_scope_t& args)
report_t& report(find_scope<report_t>(args));
std::ostream& out(report.output_stream);
- interval_t interval(*arg);
+ interval_t interval(arg);
if (! is_valid(interval.begin)) {
out << "Time period has no beginning." << std::endl;