summaryrefslogtreecommitdiff
path: root/src/predicate.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2009-02-01 22:10:32 -0400
committerJohn Wiegley <johnw@newartisans.com>2009-02-01 22:10:32 -0400
commitfb5428ce85127413da6cba184dda178352a82b3c (patch)
treee72d931ec737a7442a61bdfc3a61379a3fa8de48 /src/predicate.cc
parent7128fdb6373c901c9c68e2d8ddac911891466c40 (diff)
downloadfork-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.cc47
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 << ")";