summaryrefslogtreecommitdiff
path: root/src/precmd.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2009-11-09 13:25:45 -0500
committerJohn Wiegley <johnw@newartisans.com>2009-11-09 13:25:45 -0500
commit865c0ff828f88ed1d00eea73a3fc55b3e57d21b3 (patch)
tree5acdfae32811b25fb46271bf349a216bea41fddb /src/precmd.cc
parent55c7792c9329f97dd19fc5aeca466cb2de4fbf9c (diff)
parent9b396b41220646cf73fcd2a8afebcee06dde2a29 (diff)
downloadfork-ledger-865c0ff828f88ed1d00eea73a3fc55b3e57d21b3.tar.gz
fork-ledger-865c0ff828f88ed1d00eea73a3fc55b3e57d21b3.tar.bz2
fork-ledger-865c0ff828f88ed1d00eea73a3fc55b3e57d21b3.zip
Merge branch 'next'
Diffstat (limited to 'src/precmd.cc')
-rw-r--r--src/precmd.cc24
1 files changed, 12 insertions, 12 deletions
diff --git a/src/precmd.cc b/src/precmd.cc
index 4cf541f4..92483dc8 100644
--- a/src/precmd.cc
+++ b/src/precmd.cc
@@ -35,6 +35,7 @@
#include "xact.h"
#include "post.h"
#include "account.h"
+#include "query.h"
#include "session.h"
#include "report.h"
#include "format.h"
@@ -147,7 +148,7 @@ value_t format_command(call_scope_t& args)
out << std::endl << _("--- Formatted string ---") << std::endl;
bind_scope_t bound_scope(args, *post);
out << '"';
- fmt.format(out, bound_scope);
+ out << fmt(bound_scope);
out << "\"\n";
return NULL_VALUE;
@@ -223,37 +224,36 @@ value_t args_command(call_scope_t& args)
report_t& report(find_scope<report_t>(args));
std::ostream& out(report.output_stream);
- value_t::sequence_t::const_iterator begin = args.value().begin();
- value_t::sequence_t::const_iterator end = args.value().end();
-
out << _("--- Input arguments ---") << std::endl;
args.value().dump(out);
out << std::endl << std::endl;
- std::pair<expr_t, query_parser_t> info = args_to_predicate(begin, end);
- if (! info.first)
+ query_t query(args.value(), report.what_to_keep());
+ if (! query)
throw_(std::runtime_error,
_("Invalid query predicate: %1") << join_args(args));
call_scope_t sub_args(static_cast<scope_t&>(args));
- sub_args.push_back(string_value(info.first.text()));
+ sub_args.push_back(string_value(query.text()));
parse_command(sub_args);
- if (info.second.tokens_remaining()) {
+ if (query.tokens_remaining()) {
out << std::endl << _("====== Display predicate ======")
<< std::endl << std::endl;
- call_scope_t disp_sub_args(static_cast<scope_t&>(args));
- info = args_to_predicate(info.second);
- if (! info.first)
+ query.parse_again();
+
+ if (! query)
throw_(std::runtime_error,
_("Invalid display predicate: %1") << join_args(args));
- disp_sub_args.push_back(string_value(info.first.text()));
+ call_scope_t disp_sub_args(static_cast<scope_t&>(args));
+ disp_sub_args.push_back(string_value(query.text()));
parse_command(disp_sub_args);
}
+
return NULL_VALUE;
}