aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/analysis
diff options
context:
space:
mode:
authorLianaHus <liana@ethdev.com>2015-11-07 01:43:17 +0800
committerLianaHus <liana@ethdev.com>2015-11-07 01:45:06 +0800
commit63060fc1f0f2f27ab4ad853c7295c2cfba373b83 (patch)
tree495d30b41f8fa1f49478d9ff19e0ef61ac0313e7 /libsolidity/analysis
parent7eb162c0df52fc6335613f00e9d105fe2a4df7ff (diff)
downloaddexon-solidity-63060fc1f0f2f27ab4ad853c7295c2cfba373b83.tar
dexon-solidity-63060fc1f0f2f27ab4ad853c7295c2cfba373b83.tar.gz
dexon-solidity-63060fc1f0f2f27ab4ad853c7295c2cfba373b83.tar.bz2
dexon-solidity-63060fc1f0f2f27ab4ad853c7295c2cfba373b83.tar.lz
dexon-solidity-63060fc1f0f2f27ab4ad853c7295c2cfba373b83.tar.xz
dexon-solidity-63060fc1f0f2f27ab4ad853c7295c2cfba373b83.tar.zst
dexon-solidity-63060fc1f0f2f27ab4ad853c7295c2cfba373b83.zip
fixed test framework
Diffstat (limited to 'libsolidity/analysis')
-rw-r--r--libsolidity/analysis/NameAndTypeResolver.cpp9
-rw-r--r--libsolidity/analysis/ReferencesResolver.h9
2 files changed, 8 insertions, 10 deletions
diff --git a/libsolidity/analysis/NameAndTypeResolver.cpp b/libsolidity/analysis/NameAndTypeResolver.cpp
index d681b99b..85944e0f 100644
--- a/libsolidity/analysis/NameAndTypeResolver.cpp
+++ b/libsolidity/analysis/NameAndTypeResolver.cpp
@@ -84,9 +84,6 @@ bool NameAndTypeResolver::resolveNamesAndTypes(ContractDefinition& _contract)
importInheritedScope(*base);
}
- if (!success)
- return false;
-
for (ASTPointer<StructDefinition> const& structDef: _contract.definedStructs())
if (!resolver.resolve(*structDef))
success = false;
@@ -100,8 +97,6 @@ bool NameAndTypeResolver::resolveNamesAndTypes(ContractDefinition& _contract)
if (!resolver.resolve(*event))
success = false;
// these can contain code, only resolve parameters for now
- if (!success)
- return false;
for (ASTPointer<ModifierDefinition> const& modifier: _contract.functionModifiers())
{
m_currentScope = &m_scopes[modifier.get()];
@@ -110,8 +105,6 @@ bool NameAndTypeResolver::resolveNamesAndTypes(ContractDefinition& _contract)
success = false;
}
- if (!success)
- return false;
for (ASTPointer<FunctionDefinition> const& function: _contract.definedFunctions())
{
m_currentScope = &m_scopes[function.get()];
@@ -138,8 +131,6 @@ bool NameAndTypeResolver::resolveNamesAndTypes(ContractDefinition& _contract)
success = false;
}
- if (!success)
- return false;
for (ASTPointer<FunctionDefinition> const& function: _contract.definedFunctions())
{
m_currentScope = &m_scopes[function.get()];
diff --git a/libsolidity/analysis/ReferencesResolver.h b/libsolidity/analysis/ReferencesResolver.h
index 237d01a0..be618f23 100644
--- a/libsolidity/analysis/ReferencesResolver.h
+++ b/libsolidity/analysis/ReferencesResolver.h
@@ -59,7 +59,14 @@ public:
/// @returns true if no errors during resolving
bool resolve(ASTNode& _root)
{
- _root.accept(*this);
+ try
+ {
+ _root.accept(*this);
+ }
+ catch (FatalError const& e)
+ {
+ solAssert(m_errorOccurred, "");
+ }
return !m_errorOccurred;
}