From 5087a60deef7c618a07562511e9a1fbf2414776c Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Fri, 30 Jul 2004 20:06:56 -0400 Subject: added error checking to value expression parsing --- error.h | 14 ++++++++++++++ expr.cc | 38 +++++++++++++++++++++++++------------- 2 files changed, 39 insertions(+), 13 deletions(-) diff --git a/error.h b/error.h index f332ae4c..23386823 100644 --- a/error.h +++ b/error.h @@ -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; diff --git a/expr.cc b/expr.cc index df4d2232..7ed5bda2 100644 --- a/expr.cc +++ b/expr.cc @@ -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(); } -- cgit v1.2.3