summaryrefslogtreecommitdiff
path: root/src/predicate.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2009-02-08 05:19:02 -0400
committerJohn Wiegley <johnw@newartisans.com>2009-02-08 05:19:02 -0400
commit769b4ba1d0a913b23d5bb8084c0f63cbfad4625a (patch)
treeaba849e1e7289805660d4179751bb17b123738b8 /src/predicate.cc
parent59aefb5a3b0df32b1008bb5f5008daf879f5ff5f (diff)
downloadfork-ledger-769b4ba1d0a913b23d5bb8084c0f63cbfad4625a.tar.gz
fork-ledger-769b4ba1d0a913b23d5bb8084c0f63cbfad4625a.tar.bz2
fork-ledger-769b4ba1d0a913b23d5bb8084c0f63cbfad4625a.zip
Inverted the logical sense of query arguments; they now implicit use OR.
Diffstat (limited to 'src/predicate.cc')
-rw-r--r--src/predicate.cc61
1 files changed, 19 insertions, 42 deletions
diff --git a/src/predicate.cc b/src/predicate.cc
index 26d9279d..12f7865c 100644
--- a/src/predicate.cc
+++ b/src/predicate.cc
@@ -37,7 +37,7 @@ string args_to_predicate_expr(value_t::sequence_t::const_iterator begin,
value_t::sequence_t::const_iterator end)
{
std::ostringstream expr;
- bool append_and = false;
+ bool append_or = false;
bool only_parenthesis;
while (begin != end) {
@@ -48,29 +48,29 @@ string args_to_predicate_expr(value_t::sequence_t::const_iterator begin,
bool only_closed_parenthesis = false;;
if (arg == "not" || arg == "NOT") {
- if (append_and)
- prefix = " & ! ";
+ if (append_or)
+ prefix = " | ! ";
else
prefix = " ! ";
parse_argument = false;
- append_and = false;
+ append_or = false;
}
else if (arg == "and" || arg == "AND") {
prefix = " & ";
parse_argument = false;
- append_and = false;
+ append_or = false;
}
else if (arg == "or" || arg == "OR") {
prefix = " | ";
parse_argument = false;
- append_and = false;
+ append_or = false;
}
- else if (append_and) {
+ else if (append_or) {
if (! only_parenthesis)
- prefix = " & ";
+ prefix = " | ";
}
else {
- append_and = true;
+ append_or = true;
}
value_t::sequence_t::const_iterator next = begin;
@@ -94,7 +94,6 @@ string args_to_predicate_expr(value_t::sequence_t::const_iterator begin,
if (parse_argument) {
bool in_prefix = true;
- bool in_suffix = false;
bool found_specifier = false;
bool no_final_slash = false;
@@ -110,12 +109,6 @@ string args_to_predicate_expr(value_t::sequence_t::const_iterator begin,
if (in_prefix) {
switch (*c) {
- case ')':
- if (only_parenthesis)
- only_closed_parenthesis = true;
- break;
- case '(':
- break;
case '@':
buf << "(payee =~ /";
found_specifier = true;
@@ -149,8 +142,10 @@ string args_to_predicate_expr(value_t::sequence_t::const_iterator begin,
consumed = true;
break;
}
- case '/':
- case '_':
+ case ')':
+ if (only_parenthesis)
+ only_closed_parenthesis = true;
+ // fall_through...
default:
if (! found_specifier) {
buf << "(account =~ /";
@@ -159,40 +154,22 @@ string args_to_predicate_expr(value_t::sequence_t::const_iterator begin,
in_prefix = false;
break;
}
- } else {
- switch (*c) {
- case ')':
- if (! in_suffix) {
- if (found_specifier) {
- if (! no_final_slash)
- buf << "/";
- buf << ")";
- }
- in_suffix = true;
- }
- break;
- default:
- if (in_suffix)
- throw_(parse_error, "Invalid text in specification argument");
- break;
- }
}
if (! consumed)
buf << *c;
}
- if (! prefix.empty() && ! only_closed_parenthesis)
+ if (! prefix.empty() &&
+ ! (only_parenthesis && only_closed_parenthesis))
expr << prefix;
expr << buf.str();
- if (! in_suffix) {
- if (found_specifier) {
- if (! no_final_slash)
- expr << "/";
- expr << ")";
- }
+ if (found_specifier) {
+ if (! no_final_slash)
+ expr << "/";
+ expr << ")";
}
} else {
expr << prefix;