aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity
diff options
context:
space:
mode:
authorchriseth <c@ethdev.com>2015-10-16 00:30:32 +0800
committerchriseth <c@ethdev.com>2015-10-16 00:30:32 +0800
commit030c868f58bd5156f8c657865ed60b15d81ab7a0 (patch)
treee11c26ce9e159d93726629b6fdfdff5d08ac6ca8 /libsolidity
parent7ba42f470753f9af25531017f319cf94eb26d3f2 (diff)
parentec5b9c2e92959b28d4f7f74245fac0c42ae82314 (diff)
downloaddexon-solidity-030c868f58bd5156f8c657865ed60b15d81ab7a0.tar
dexon-solidity-030c868f58bd5156f8c657865ed60b15d81ab7a0.tar.gz
dexon-solidity-030c868f58bd5156f8c657865ed60b15d81ab7a0.tar.bz2
dexon-solidity-030c868f58bd5156f8c657865ed60b15d81ab7a0.tar.lz
dexon-solidity-030c868f58bd5156f8c657865ed60b15d81ab7a0.tar.xz
dexon-solidity-030c868f58bd5156f8c657865ed60b15d81ab7a0.tar.zst
dexon-solidity-030c868f58bd5156f8c657865ed60b15d81ab7a0.zip
Merge pull request #136 from LianaHus/sol_error_types_refuctoring
changed the way of reporting error during contract checking
Diffstat (limited to 'libsolidity')
-rw-r--r--libsolidity/CompilerStack.cpp12
1 files changed, 3 insertions, 9 deletions
diff --git a/libsolidity/CompilerStack.cpp b/libsolidity/CompilerStack.cpp
index 1165d6f6..12e49b58 100644
--- a/libsolidity/CompilerStack.cpp
+++ b/libsolidity/CompilerStack.cpp
@@ -113,7 +113,6 @@ bool CompilerStack::parse()
resolveImports();
m_globalContext = make_shared<GlobalContext>();
- bool success = true;
NameAndTypeResolver resolver(m_globalContext->declarations(), m_errors);
for (Source const* source: m_sourceOrder)
if (!resolver.registerDeclarations(*source->ast))
@@ -124,17 +123,12 @@ bool CompilerStack::parse()
if (ContractDefinition* contract = dynamic_cast<ContractDefinition*>(node.get()))
{
m_globalContext->setCurrentContract(*contract);
- success = success && resolver.updateDeclaration(*m_globalContext->currentThis());
- success = success && resolver.updateDeclaration(*m_globalContext->currentSuper());
- success = success && resolver.resolveNamesAndTypes(*contract);
+ if (!resolver.updateDeclaration(*m_globalContext->currentThis())) return false;
+ if (!resolver.updateDeclaration(*m_globalContext->currentSuper())) return false;
+ if (!resolver.resolveNamesAndTypes(*contract)) return false;
m_contracts[contract->name()].contract = contract;
}
- if (!success)
- {
- m_parseSuccessful = false;
- return m_parseSuccessful;
- }
InterfaceHandler interfaceHandler;
bool typesFine = true;
for (Source const* source: m_sourceOrder)