diff options
author | John Wiegley <johnw@newartisans.com> | 2020-05-07 21:22:20 -0700 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2020-05-07 21:25:33 -0700 |
commit | 869302ae9ce303b532fa4700f78d208c3bd89310 (patch) | |
tree | 42c0a758f761e388964533f130a1062c2e728414 /src | |
parent | 853e1c0388cf0e561604bf28ac8b0be874ec7323 (diff) | |
download | fork-ledger-869302ae9ce303b532fa4700f78d208c3bd89310.tar.gz fork-ledger-869302ae9ce303b532fa4700f78d208c3bd89310.tar.bz2 fork-ledger-869302ae9ce303b532fa4700f78d208c3bd89310.zip |
Revert "Correction to the way parens are parsed in query expressions"
This reverts commit 49b07a1c19489547b859d61fbc5c240aff224dda.
Diffstat (limited to 'src')
-rw-r--r-- | src/query.cc | 55 | ||||
-rw-r--r-- | src/query.h | 1 |
2 files changed, 9 insertions, 47 deletions
diff --git a/src/query.cc b/src/query.cc index 75c017ce..883bea40 100644 --- a/src/query.cc +++ b/src/query.cc @@ -36,17 +36,6 @@ namespace ledger { -bool query_t::lexer_t::advance() -{ - if (begin == end || ++begin == end) { - return false; - } else { - arg_i = (*begin).as_string().begin(); - arg_end = (*begin).as_string().end(); - } - return true; -} - query_t::lexer_t::token_t query_t::lexer_t::next_token(query_t::lexer_t::token_t::kind_t tok_context) { @@ -57,8 +46,12 @@ query_t::lexer_t::next_token(query_t::lexer_t::token_t::kind_t tok_context) } if (arg_i == arg_end) { - if (! advance()) + if (begin == end || ++begin == end) { return token_t(token_t::END_REACHED); + } else { + arg_i = (*begin).as_string().begin(); + arg_end = (*begin).as_string().end(); + } } resume: @@ -160,6 +153,9 @@ query_t::lexer_t::next_token(query_t::lexer_t::token_t::kind_t tok_context) break; case ')': + if (! consume_next && tok_context == token_t::TOK_EXPR) + goto test_ident; + // fall through... case '(': case '&': case '|': @@ -257,23 +253,6 @@ void query_t::lexer_t::token_t::expected(char wanted, char c) } } -std::string& ltrim(std::string& str, const std::string& chars = "\t\n\v\f\r ") -{ - str.erase(0, str.find_first_not_of(chars)); - return str; -} - -std::string& rtrim(std::string& str, const std::string& chars = "\t\n\v\f\r ") -{ - str.erase(str.find_last_not_of(chars) + 1); - return str; -} - -std::string& trim(std::string& str, const std::string& chars = "\t\n\v\f\r ") -{ - return ltrim(rtrim(str, chars), chars); -} - expr_t::ptr_op_t query_t::parser_t::parse_query_term(query_t::lexer_t::token_t::kind_t tok_context) { @@ -296,29 +275,13 @@ query_t::parser_t::parse_query_term(query_t::lexer_t::token_t::kind_t tok_contex case lexer_t::token_t::TOK_NOTE: case lexer_t::token_t::TOK_ACCOUNT: case lexer_t::token_t::TOK_META: + case lexer_t::token_t::TOK_EXPR: node = parse_query_term(tok.kind); if (! node) throw_(parse_error, _f("%1% operator not followed by argument") % tok.symbol()); break; - case lexer_t::token_t::TOK_EXPR: { - string arg(lexer.arg_i, lexer.arg_end); - lexer.arg_i = lexer.arg_end; - trim(arg); - - if (arg.length() == 0) { - if (lexer.advance()) { - arg = string(lexer.arg_i, lexer.arg_end); - lexer.arg_i = lexer.arg_end; - trim(arg); - } - } - - node = expr_t(arg).get_op(); - break; - } - case lexer_t::token_t::TERM: assert(tok.value); switch (tok_context) { diff --git a/src/query.h b/src/query.h index 07093d70..f7d48d32 100644 --- a/src/query.h +++ b/src/query.h @@ -223,7 +223,6 @@ public: TRACE_DTOR(query_t::lexer_t); } - bool advance(); token_t next_token(token_t::kind_t tok_context = token_t::UNKNOWN); void push_token(token_t tok) { assert(token_cache.kind == token_t::UNKNOWN); |