diff options
author | John Wiegley <johnw@newartisans.com> | 2004-07-30 20:06:56 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2004-07-30 20:06:56 -0400 |
commit | 5087a60deef7c618a07562511e9a1fbf2414776c (patch) | |
tree | a8f8ef2b2f9f6352db1ec0b7cc5e17c13918bcec | |
parent | abae9138e9b7746a23d66d56673e10343a9cec11 (diff) | |
download | fork-ledger-5087a60deef7c618a07562511e9a1fbf2414776c.tar.gz fork-ledger-5087a60deef7c618a07562511e9a1fbf2414776c.tar.bz2 fork-ledger-5087a60deef7c618a07562511e9a1fbf2414776c.zip |
added error checking to value expression parsing
-rw-r--r-- | error.h | 14 | ||||
-rw-r--r-- | expr.cc | 38 |
2 files changed, 39 insertions, 13 deletions
@@ -18,6 +18,20 @@ class error : public std::exception } }; +class compute_error : public error +{ + public: + compute_error(const std::string& reason) throw() : error(reason) {} + virtual ~compute_error() throw() {} +}; + +class expr_error : public error +{ + public: + expr_error(const std::string& reason) throw() : error(reason) {} + virtual ~expr_error() throw() {} +}; + class parse_error : public error { unsigned int line; @@ -1,4 +1,5 @@ #include "expr.h" +#include "error.h" #include "textual.h" namespace ledger { @@ -87,7 +88,8 @@ balance_t node_t::compute(const item_t * item, case DATE: moment = item->date; break; case BEGIN_DATE: moment = begin; break; case END_DATE: moment = end; break; - default: assert(0); break; + default: + throw compute_error("Invalid date passed to P(v,d)"); } } temp = temp.value(moment); @@ -173,7 +175,7 @@ node_t * parse_term(std::istream& in, ledger_t * ledger) if (c == '}') in.get(c); else - ident = "0"; + throw expr_error("Missing '}'"); } else { while (! in.eof() && std::isdigit(c) || c == '.') { in.get(c); @@ -244,6 +246,8 @@ node_t * parse_term(std::istream& in, ledger_t * ledger) } if (in.peek() == ')') in.get(c); + else + throw expr_error("Missing ')'"); } else { node->left = parse_term(in, ledger); } @@ -266,7 +270,7 @@ node_t * parse_term(std::istream& in, ledger_t * ledger) node = new node_t(F_REGEXP); node->mask = new mask_t(ident); } else { - assert(0); + throw expr_error("Missing closing '/'"); } break; } @@ -276,7 +280,7 @@ node_t * parse_term(std::istream& in, ledger_t * ledger) if (in.peek() == ')') in.get(c); else - assert(0); + throw expr_error("Missing ')'"); break; case '[': { @@ -292,9 +296,9 @@ node_t * parse_term(std::istream& in, ledger_t * ledger) in.get(c); node = new node_t(CONSTANT_T); if (! parse_date(ident.c_str(), &node->constant_t)) - assert(0); + throw expr_error("Failed to parse date"); } else { - assert(0); + throw expr_error("Missing ']'"); } break; } @@ -427,9 +431,11 @@ node_t * parse_logic_expr(std::istream& in, ledger_t * ledger) } default: - if (! in.eof()) - assert(0); - break; + if (! in.eof()) { + std::ostringstream err; + err << "Unexpected character '" << c << "'"; + throw expr_error(err.str()); + } } } } @@ -472,16 +478,22 @@ node_t * parse_expr(std::istream& in, ledger_t * ledger) node->right = choices; choices->left = parse_logic_expr(in, ledger); c = in.peek(); - assert(c == ':'); + if (c != ':') { + std::ostringstream err; + err << "Unexpected character '" << c << "'"; + throw expr_error(err.str()); + } in.get(c); choices->right = parse_logic_expr(in, ledger); break; } default: - if (! in.eof()) - assert(0); - break; + if (! in.eof()) { + std::ostringstream err; + err << "Unexpected character '" << c << "'"; + throw expr_error(err.str()); + } } c = in.peek(); } |