diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/predicate.cc | 90 | ||||
-rw-r--r-- | src/predicate.h | 15 |
2 files changed, 77 insertions, 28 deletions
diff --git a/src/predicate.cc b/src/predicate.cc index d5b41362..46d973c4 100644 --- a/src/predicate.cc +++ b/src/predicate.cc @@ -147,16 +147,16 @@ query_lexer_t::token_t query_lexer_t::next_token() return token_t(token_t::TOK_OR); else if (ident == "not") return token_t(token_t::TOK_NOT); - else if (ident == "account") - return token_t(token_t::TOK_ACCOUNT); + else if (ident == "code") + return token_t(token_t::TOK_CODE); else if (ident == "desc") return token_t(token_t::TOK_PAYEE); else if (ident == "payee") return token_t(token_t::TOK_PAYEE); - else if (ident == "code") - return token_t(token_t::TOK_CODE); else if (ident == "note") return token_t(token_t::TOK_NOTE); + else if (ident == "account") + return token_t(token_t::TOK_ACCOUNT); else if (ident == "tag") return token_t(token_t::TOK_META); else if (ident == "meta") @@ -169,9 +169,16 @@ query_lexer_t::token_t query_lexer_t::next_token() DEBUG("pred.show", "string = " << (*begin).as_string()); return token_t(token_t::END_REACHED); } +#if 0 + // jww (2009-11-06): This is disabled for the time being. + else if (ident == "date") { + // The date keyword takes the whole of the next string as its argument. + consume_whitespace = true; + return token_t(token_t::TOK_DATE); + } +#endif else if (ident == "expr") { - // The expr keyword takes the whole of the next string as its - // argument. + // The expr keyword takes the whole of the next string as its argument. consume_whitespace = true; return token_t(token_t::TOK_EXPR); } @@ -227,10 +234,11 @@ query_parser_t::parse_query_term(query_lexer_t::token_t::kind_t tok_context) case query_lexer_t::token_t::END_REACHED: break; - case query_lexer_t::token_t::TOK_ACCOUNT: - case query_lexer_t::token_t::TOK_PAYEE: + case query_lexer_t::token_t::TOK_DATE: case query_lexer_t::token_t::TOK_CODE: + case query_lexer_t::token_t::TOK_PAYEE: case query_lexer_t::token_t::TOK_NOTE: + case query_lexer_t::token_t::TOK_ACCOUNT: case query_lexer_t::token_t::TOK_META: case query_lexer_t::token_t::TOK_EXPR: node = parse_query_term(tok.kind); @@ -241,16 +249,54 @@ query_parser_t::parse_query_term(query_lexer_t::token_t::kind_t tok_context) case query_lexer_t::token_t::TERM: assert(tok.value); - if (tok_context == query_lexer_t::token_t::TOK_META) { + switch (tok_context) { + case query_lexer_t::token_t::TOK_DATE: { + expr_t::ptr_op_t ident = new expr_t::op_t(expr_t::op_t::IDENT); + ident->set_ident("date"); + + date_interval_t interval(*tok.value); + + if (interval.start) { + node = new expr_t::op_t(expr_t::op_t::O_GTE); + node->set_left(ident); + + expr_t::ptr_op_t arg1 = new expr_t::op_t(expr_t::op_t::VALUE); + arg1->set_value(*interval.start); + node->set_right(arg1); + } + + if (interval.end) { + expr_t::ptr_op_t lt = new expr_t::op_t(expr_t::op_t::O_LT); + lt->set_left(ident); + + expr_t::ptr_op_t arg1 = new expr_t::op_t(expr_t::op_t::VALUE); + arg1->set_value(*interval.end); + lt->set_right(arg1); + + if (node) { + expr_t::ptr_op_t prev(node); + node = new expr_t::op_t(expr_t::op_t::O_AND); + node->set_left(prev); + node->set_right(lt); + } else { + node = lt; + } + } + break; + } + + case query_lexer_t::token_t::TOK_EXPR: + node = expr_t(*tok.value).get_op(); + break; + + case query_lexer_t::token_t::TOK_META: { node = new expr_t::op_t(expr_t::op_t::O_CALL); - expr_t::ptr_op_t ident; - ident = new expr_t::op_t(expr_t::op_t::IDENT); + expr_t::ptr_op_t ident = new expr_t::op_t(expr_t::op_t::IDENT); ident->set_ident("has_tag"); node->set_left(ident); - expr_t::ptr_op_t arg1; - arg1 = new expr_t::op_t(expr_t::op_t::VALUE); + expr_t::ptr_op_t arg1 = new expr_t::op_t(expr_t::op_t::VALUE); arg1->set_value(mask_t(*tok.value)); tok = lexer.peek_token(); @@ -261,11 +307,9 @@ query_parser_t::parse_query_term(query_lexer_t::token_t::kind_t tok_context) throw_(parse_error, _("Metadata equality operator not followed by term")); - expr_t::ptr_op_t cons; - cons = new expr_t::op_t(expr_t::op_t::O_CONS); + expr_t::ptr_op_t cons = new expr_t::op_t(expr_t::op_t::O_CONS); - expr_t::ptr_op_t arg2; - arg2 = new expr_t::op_t(expr_t::op_t::VALUE); + expr_t::ptr_op_t arg2 = new expr_t::op_t(expr_t::op_t::VALUE); assert(tok.value); arg2->set_value(mask_t(*tok.value)); @@ -275,11 +319,13 @@ query_parser_t::parse_query_term(query_lexer_t::token_t::kind_t tok_context) } else { node->set_right(arg1); } - } else { + break; + } + + default: { node = new expr_t::op_t(expr_t::op_t::O_MATCH); - expr_t::ptr_op_t ident; - ident = new expr_t::op_t(expr_t::op_t::IDENT); + expr_t::ptr_op_t ident = new expr_t::op_t(expr_t::op_t::IDENT); switch (tok_context) { case query_lexer_t::token_t::TOK_ACCOUNT: ident->set_ident("account"); break; @@ -293,13 +339,13 @@ query_parser_t::parse_query_term(query_lexer_t::token_t::kind_t tok_context) assert(0); break; } - expr_t::ptr_op_t mask; - mask = new expr_t::op_t(expr_t::op_t::VALUE); + expr_t::ptr_op_t mask = new expr_t::op_t(expr_t::op_t::VALUE); mask->set_value(mask_t(*tok.value)); node->set_left(ident); node->set_right(mask); } + } break; case query_lexer_t::token_t::LPAREN: diff --git a/src/predicate.h b/src/predicate.h index 577e872a..739356b6 100644 --- a/src/predicate.h +++ b/src/predicate.h @@ -135,10 +135,11 @@ public: TOK_OR, TOK_EQ, - TOK_ACCOUNT, - TOK_PAYEE, + TOK_DATE, TOK_CODE, + TOK_PAYEE, TOK_NOTE, + TOK_ACCOUNT, TOK_META, TOK_EXPR, @@ -184,10 +185,11 @@ public: case TOK_AND: return "TOK_AND"; case TOK_OR: return "TOK_OR"; case TOK_EQ: return "TOK_EQ"; - case TOK_ACCOUNT: return "TOK_ACCOUNT"; - case TOK_PAYEE: return "TOK_PAYEE"; + case TOK_DATE: return "TOK_DATE"; case TOK_CODE: return "TOK_CODE"; + case TOK_PAYEE: return "TOK_PAYEE"; case TOK_NOTE: return "TOK_NOTE"; + case TOK_ACCOUNT: return "TOK_ACCOUNT"; case TOK_META: return "TOK_META"; case TOK_EXPR: return "TOK_EXPR"; case TERM: return string("TERM(") + *value + ")"; @@ -203,10 +205,11 @@ public: case TOK_AND: return "and"; case TOK_OR: return "or"; case TOK_EQ: return "="; - case TOK_ACCOUNT: return "account"; - case TOK_PAYEE: return "payee"; + case TOK_DATE: return "date"; case TOK_CODE: return "code"; + case TOK_PAYEE: return "payee"; case TOK_NOTE: return "note"; + case TOK_ACCOUNT: return "account"; case TOK_META: return "meta"; case TOK_EXPR: return "expr"; |