diff options
author | John Wiegley <johnw@newartisans.com> | 2009-02-01 22:10:32 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2009-02-01 22:10:32 -0400 |
commit | fb5428ce85127413da6cba184dda178352a82b3c (patch) | |
tree | e72d931ec737a7442a61bdfc3a61379a3fa8de48 /src/predicate.cc | |
parent | 7128fdb6373c901c9c68e2d8ddac911891466c40 (diff) | |
download | fork-ledger-fb5428ce85127413da6cba184dda178352a82b3c.tar.gz fork-ledger-fb5428ce85127413da6cba184dda178352a82b3c.tar.bz2 fork-ledger-fb5428ce85127413da6cba184dda178352a82b3c.zip |
Added support for metadata and tagging, and made regexs a first-class type.
Diffstat (limited to 'src/predicate.cc')
-rw-r--r-- | src/predicate.cc | 47 |
1 files changed, 23 insertions, 24 deletions
diff --git a/src/predicate.cc b/src/predicate.cc index 19019ec7..72b22f97 100644 --- a/src/predicate.cc +++ b/src/predicate.cc @@ -67,27 +67,29 @@ string args_to_predicate_expr(value_t::sequence_t::const_iterator begin, append_and = true; } - if (arg == "desc" || arg == "DESC" || - arg == "payee" || arg == "PAYEE") { - arg = string("@") + (*++begin).as_string(); - } - else if (arg == "note" || arg == "NOTE") { - arg = string("&") + (*++begin).as_string(); - } - else if (arg == "tag" || arg == "TAG" || - arg == "meta" || arg == "META" || - arg == "data" || arg == "DATA") { - arg = string("%") + (*++begin).as_string(); - } - else if (arg == "expr" || arg == "EXPR") { - arg = string("=") + (*++begin).as_string(); + value_t::sequence_t::const_iterator next = begin; + if (++next != end) { + if (arg == "desc" || arg == "DESC" || + arg == "payee" || arg == "PAYEE") { + arg = string("@") + (*++begin).as_string(); + } + else if (arg == "note" || arg == "NOTE") { + arg = string("&") + (*++begin).as_string(); + } + else if (arg == "tag" || arg == "TAG" || + arg == "meta" || arg == "META" || + arg == "data" || arg == "DATA") { + arg = string("%") + (*++begin).as_string(); + } + else if (arg == "expr" || arg == "EXPR") { + arg = string("=") + (*++begin).as_string(); + } } if (parse_argument) { bool in_prefix = true; bool in_suffix = false; bool found_specifier = false; - bool saw_tag_char = false; bool no_final_slash = false; only_parenthesis = true; @@ -122,15 +124,14 @@ string args_to_predicate_expr(value_t::sequence_t::const_iterator begin, bool found_metadata = false; for (const char *q = c; *q != '\0'; q++) if (*q == '=') { - expr << "(metadata(\"" - << string(c + 1, q - c - 1) << "\") =~ /"; + expr << "has_tag(/" + << string(c + 1, q - c - 1) << "/, /"; found_metadata = true; c = q; break; } if (! found_metadata) { - expr << "(tag =~ /:"; - saw_tag_char = true; + expr << "has_tag(/"; } found_specifier = true; consumed = true; @@ -151,9 +152,9 @@ string args_to_predicate_expr(value_t::sequence_t::const_iterator begin, case ')': if (! in_suffix) { if (found_specifier) { - if (saw_tag_char) - expr << ':'; - expr << "/)"; + if (! no_final_slash) + expr << "/"; + expr << ")"; } in_suffix = true; } @@ -171,8 +172,6 @@ string args_to_predicate_expr(value_t::sequence_t::const_iterator begin, if (! in_suffix) { if (found_specifier) { - if (saw_tag_char) - expr << ':'; if (! no_final_slash) expr << "/"; expr << ")"; |