summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2004-07-30 20:06:56 -0400
committerJohn Wiegley <johnw@newartisans.com>2004-07-30 20:06:56 -0400
commit5087a60deef7c618a07562511e9a1fbf2414776c (patch)
treea8f8ef2b2f9f6352db1ec0b7cc5e17c13918bcec
parentabae9138e9b7746a23d66d56673e10343a9cec11 (diff)
downloadfork-ledger-5087a60deef7c618a07562511e9a1fbf2414776c.tar.gz
fork-ledger-5087a60deef7c618a07562511e9a1fbf2414776c.tar.bz2
fork-ledger-5087a60deef7c618a07562511e9a1fbf2414776c.zip
added error checking to value expression parsing
-rw-r--r--error.h14
-rw-r--r--expr.cc38
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();
}