From de8a651df4e4930bdb1c37f080dccb2d3f02f3cd Mon Sep 17 00:00:00 2001 From: Marc Zinnschlag Date: Mon, 28 Jun 2010 01:01:48 +0200 Subject: [PATCH] improved error handling --- apps/mwcompiler/main.cpp | 39 +++++++++++++++++++++++++++++---- components/compiler/scanner.cpp | 3 +++ 2 files changed, 38 insertions(+), 4 deletions(-) diff --git a/apps/mwcompiler/main.cpp b/apps/mwcompiler/main.cpp index 114315930..231496846 100644 --- a/apps/mwcompiler/main.cpp +++ b/apps/mwcompiler/main.cpp @@ -8,6 +8,7 @@ #include #include #include +#include int main (int argc, char **argv) { @@ -17,12 +18,42 @@ int main (int argc, char **argv) Compiler::StreamErrorHandler errorHandler (std::cout); Compiler::FileParser parser (errorHandler, context); - std::ifstream file (argc>1 ? argv[1] : "test.mwscript"); - Compiler::Scanner scanner (errorHandler, file); + try + { + std::string filename = argc>1 ? argv[1] : "test.mwscript"; - scanner.scan (parser); + std::ifstream file (filename.c_str()); + + if (!file.is_open()) + { + std::cout << "can't open script file: " << filename << std::endl; + return 1; + } + + Compiler::Scanner scanner (errorHandler, file); - std::cout << "parsed script: " << parser.getName() << std::endl; + scanner.scan (parser); + } + catch (const Compiler::SourceException&) + { + // ignore exception (problem has already been reported to the user) + } + + if (errorHandler.countErrors() || errorHandler.countWarnings()) + { + std::cout + << errorHandler.countErrors() << " error(s), " + << errorHandler.countWarnings() << " warning(s)" << std::endl + << std::endl; + } + + if (errorHandler.isGood()) + { + std::cout << "parsed script: " << parser.getName() << std::endl; + return 0; + } + + return 1; } catch (const std::exception &e) { diff --git a/components/compiler/scanner.cpp b/components/compiler/scanner.cpp index f82ee73d0..83c5b2d17 100644 --- a/components/compiler/scanner.cpp +++ b/components/compiler/scanner.cpp @@ -386,6 +386,9 @@ namespace Compiler else return false; + if (special==S_newline) + mLoc.mLiteral = ""; + TokenLoc loc (mLoc); mLoc.mLiteral.clear();