Merge pull request #2212 from ethereum/cli-assemble-errors

Catch errors gracefully in CLI assembler
This commit is contained in:
Alex Beregszaszi 2017-05-06 11:18:32 +01:00 committed by GitHub
commit 822c90573c

View File

@ -984,6 +984,8 @@ bool CommandLineInterface::assemble()
bool successful = true;
map<string, shared_ptr<Scanner>> scanners;
for (auto const& src: m_sourceCodes)
{
try
{
auto scanner = make_shared<Scanner>(CharStream(src.second), src.first);
scanners[src.first] = scanner;
@ -993,6 +995,17 @@ bool CommandLineInterface::assemble()
//@TODO we should not just throw away the result here
m_assemblyStacks[src.first].assemble();
}
catch (Exception const& _exception)
{
cerr << "Exception in assembler: " << boost::diagnostic_information(_exception) << endl;
return false;
}
catch (...)
{
cerr << "Unknown exception in assembler." << endl;
return false;
}
}
for (auto const& stack: m_assemblyStacks)
{
for (auto const& error: stack.second.errors())