diff options
author | Lu Guanqun <guanqun.lu@gmail.com> | 2016-01-14 09:58:09 +0800 |
---|---|---|
committer | Lu Guanqun <guanqun.lu@gmail.com> | 2016-01-15 15:12:23 +0800 |
commit | e130bc7e7cc647b15c448133f725a060910da587 (patch) | |
tree | 1a9fc6044c17de3d22fb75c64fe70c987f89bc30 /libsolidity/interface | |
parent | 02c1aacd25652d39678005294ecbb6180a283134 (diff) | |
download | dexon-solidity-e130bc7e7cc647b15c448133f725a060910da587.tar.gz dexon-solidity-e130bc7e7cc647b15c448133f725a060910da587.tar.zst dexon-solidity-e130bc7e7cc647b15c448133f725a060910da587.zip |
check whether break/continue is in the loop
Diffstat (limited to 'libsolidity/interface')
-rw-r--r-- | libsolidity/interface/CompilerStack.cpp | 6 | ||||
-rw-r--r-- | libsolidity/interface/Exceptions.cpp | 3 | ||||
-rw-r--r-- | libsolidity/interface/Exceptions.h | 1 |
3 files changed, 10 insertions, 0 deletions
diff --git a/libsolidity/interface/CompilerStack.cpp b/libsolidity/interface/CompilerStack.cpp index a6f6f224..8a0d2f5e 100644 --- a/libsolidity/interface/CompilerStack.cpp +++ b/libsolidity/interface/CompilerStack.cpp @@ -30,6 +30,7 @@ #include <libsolidity/analysis/NameAndTypeResolver.h> #include <libsolidity/analysis/TypeChecker.h> #include <libsolidity/analysis/DocStringAnalyser.h> +#include <libsolidity/analysis/SyntaxChecker.h> #include <libsolidity/codegen/Compiler.h> #include <libsolidity/interface/CompilerStack.h> #include <libsolidity/interface/InterfaceHandler.h> @@ -122,6 +123,11 @@ bool CompilerStack::parse() resolveImports(); bool noErrors = true; + SyntaxChecker syntaxChecker(m_errors); + for (Source const* source: m_sourceOrder) + if (!syntaxChecker.checkSyntax(*source->ast)) + return false; + DocStringAnalyser docStringAnalyser(m_errors); for (Source const* source: m_sourceOrder) if (!docStringAnalyser.analyseDocStrings(*source->ast)) diff --git a/libsolidity/interface/Exceptions.cpp b/libsolidity/interface/Exceptions.cpp index 465c3d2f..6d72520b 100644 --- a/libsolidity/interface/Exceptions.cpp +++ b/libsolidity/interface/Exceptions.cpp @@ -39,6 +39,9 @@ Error::Error(Type _type): m_type(_type) case Type::ParserError: m_typeName = "Parser Error"; break; + case Type::SyntaxError: + m_typeName = "Syntax Error"; + break; case Type::TypeError: m_typeName = "Type Error"; break; diff --git a/libsolidity/interface/Exceptions.h b/libsolidity/interface/Exceptions.h index 14be3c3d..07835320 100644 --- a/libsolidity/interface/Exceptions.h +++ b/libsolidity/interface/Exceptions.h @@ -47,6 +47,7 @@ public: DocstringParsingError, ParserError, TypeError, + SyntaxError, Why3TranslatorError, Warning }; |