Cleaned up exception story

This commit is contained in:
Jonathan Turner 2009-07-09 22:53:09 +00:00
parent aa0f54c53f
commit 06604e14b5
3 changed files with 45 additions and 38 deletions

View File

@ -45,15 +45,8 @@ namespace chaiscript
*/ */
const dispatchkit::Boxed_Value eval(const std::vector<dispatchkit::Boxed_Value> &vals) { const dispatchkit::Boxed_Value eval(const std::vector<dispatchkit::Boxed_Value> &vals) {
std::string val; std::string val;
try { val = dispatchkit::boxed_cast<std::string &>(vals[0]);
val = dispatchkit::boxed_cast<std::string &>(vals[0]);
}
catch (Eval_Error &ee) {
throw Eval_Error("Can not evaluate string: " + val + " reason: " + ee.reason, TokenPtr());
}
catch (std::exception &) {
throw Eval_Error("Can not evaluate string: " + val, TokenPtr());
}
return evaluate_string(val); return evaluate_string(val);
} }
@ -112,20 +105,6 @@ namespace chaiscript
catch (const Return_Value &rv) { catch (const Return_Value &rv) {
value = rv.retval; value = rv.retval;
} }
catch (Parse_Error &pe) {
std::cout << pe.reason << " in " << pe.filename << " at " << pe.position.line << ", " << pe.position.column << std::endl;
}
catch (Eval_Error &ee) {
if (filename != std::string("__EVAL__")) {
std::cout << "Eval error: \"" << ee.reason << "\" in '" << ee.location->filename << "' line: " << ee.location->start.line << std::endl;
}
else {
std::cout << "Eval error: \"" << ee.reason << "\"" << std::endl;
}
}
catch (std::exception &e) {
std::cout << "Exception: " << e.what() << std::endl;
}
return value; return value;
} }

View File

@ -422,7 +422,7 @@ namespace chaiscript
} }
catch(const dispatchkit::dispatch_error &e){ catch(const dispatchkit::dispatch_error &e){
ss.set_stack(prev_stack); ss.set_stack(prev_stack);
throw Eval_Error("Engine error: " + std::string(e.what()) + " with function '" + node->children[0]->text + "'", node->children[0]); throw Eval_Error(std::string(e.what()) + " with function '" + node->children[0]->text + "'", node->children[0]);
} }
catch(Return_Value &rv) { catch(Return_Value &rv) {
ss.set_stack(prev_stack); ss.set_stack(prev_stack);
@ -477,9 +477,9 @@ namespace chaiscript
retval = dispatch(fn, plb); retval = dispatch(fn, plb);
ss.set_stack(prev_stack); ss.set_stack(prev_stack);
} }
catch(const dispatchkit::dispatch_error &){ catch(const dispatchkit::dispatch_error &e){
ss.set_stack(prev_stack); ss.set_stack(prev_stack);
throw Eval_Error("Can not find appropriate '" + fun_name + "'", node); throw Eval_Error(std::string(e.what()) + " with function '" + fun_name + "'", node->children[i]);
} }
catch(Return_Value &rv) { catch(Return_Value &rv) {
ss.set_stack(prev_stack); ss.set_stack(prev_stack);

View File

@ -10,11 +10,9 @@ void print_help() {
} }
int main(int argc, char *argv[]) { int main(int argc, char *argv[]) {
std::string input; std::string input;
chaiscript::ChaiScript_Engine chai; chaiscript::ChaiScript_Engine chai;
chai.build_eval_system(); chai.build_eval_system();
if (argc < 2) { if (argc < 2) {
@ -28,15 +26,29 @@ int main(int argc, char *argv[]) {
print_help(); print_help();
} }
else { else {
val = chai.evaluate_string(input); try {
//First, we evaluate it
val = chai.evaluate_string(input);
if (val.get_type_info().m_bare_type_info && *(val.get_type_info().m_bare_type_info) != typeid(void)) { //Then, we try to print the result of the evaluation to the user
try { if (val.get_type_info().m_bare_type_info && *(val.get_type_info().m_bare_type_info) != typeid(void)) {
dispatchkit::dispatch(chai.get_eval_engine().get_function("print"), dispatchkit::Param_List_Builder() << val); try {
} catch (const std::runtime_error &e) { dispatchkit::dispatch(chai.get_eval_engine().get_function("print"), dispatchkit::Param_List_Builder() << val);
std::cout << e.what() << std::endl; }
catch (...) {
//If we can't, do nothing
}
} }
} }
catch (chaiscript::Parse_Error &pe) {
std::cout << pe.reason << " in " << pe.filename << " at " << pe.position.line << ", " << pe.position.column << std::endl;
}
catch (chaiscript::Eval_Error &ee) {
std::cout << ee.reason << std::endl;
}
catch (std::exception &e) {
std::cout << e.what() << std::endl;
}
} }
std::cout << "eval> "; std::cout << "eval> ";
@ -45,12 +57,28 @@ int main(int argc, char *argv[]) {
} }
else { else {
for (int i = 1; i < argc; ++i) { for (int i = 1; i < argc; ++i) {
std::string filename(argv[i]);
try { try {
dispatchkit::Boxed_Value val = chai.evaluate_file(argv[i]); dispatchkit::Boxed_Value val = chai.evaluate_file(argv[i]);
} }
catch (std::exception &) { catch (chaiscript::Parse_Error &pe) {
std::cerr << "Could not open: " << argv[i] << std::endl; if (filename != std::string("__EVAL__")) {
exit(1); std::cout << pe.reason << " in " << pe.filename << " at " << pe.position.line << ", " << pe.position.column << std::endl;
}
else {
std::cout << pe.reason << std::endl;
}
}
catch (chaiscript::Eval_Error &ee) {
if (filename != std::string("__EVAL__")) {
std::cout << ee.reason << " in '" << ee.location->filename << "' at " << ee.location->start.line << ", " << ee.location->start.column << std::endl;
}
else {
std::cout << ee.reason << std::endl;
}
}
catch (std::exception &e) {
std::cout << e.what() << std::endl;
} }
} }
} }