From a791ec75e2e73130afee391958651453acc8d781 Mon Sep 17 00:00:00 2001 From: chriseth Date: Tue, 14 Feb 2017 13:32:48 +0100 Subject: [PATCH] Review comments. --- libsolidity/analysis/NameAndTypeResolver.cpp | 2 +- libsolidity/analysis/NameAndTypeResolver.h | 5 ++++- libsolidity/analysis/TypeChecker.cpp | 7 ++----- 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/libsolidity/analysis/NameAndTypeResolver.cpp b/libsolidity/analysis/NameAndTypeResolver.cpp index fd6fc0587..013842602 100644 --- a/libsolidity/analysis/NameAndTypeResolver.cpp +++ b/libsolidity/analysis/NameAndTypeResolver.cpp @@ -139,7 +139,7 @@ bool NameAndTypeResolver::resolveNamesAndTypes(ASTNode& _node, bool _resolveInsi solAssert(!!m_currentScope, ""); for (ASTPointer const& baseContract: contract->baseContracts()) - if (!resolveNamesAndTypes(*baseContract, false)) + if (!resolveNamesAndTypes(*baseContract, true)) success = false; m_currentScope = m_scopes[contract].get(); diff --git a/libsolidity/analysis/NameAndTypeResolver.h b/libsolidity/analysis/NameAndTypeResolver.h index 4de40e87a..828b566fc 100644 --- a/libsolidity/analysis/NameAndTypeResolver.h +++ b/libsolidity/analysis/NameAndTypeResolver.h @@ -42,6 +42,9 @@ namespace solidity class NameAndTypeResolver: private boost::noncopyable { public: + /// Creates the resolver with the given declarations added to the global scope. + /// @param _scopes mapping of scopes to be used (usually default constructed), these + /// are filled during the lifetime of this object. NameAndTypeResolver( std::vector const& _globals, std::map>& _scopes, @@ -57,7 +60,7 @@ public: /// Resolves all names and types referenced from the given AST Node. /// This is usually only called at the contract level, but with a bit of care, it can also /// be called at deeper levels. - /// @param _avoidCode if false, does not descend into nodes that contain code. + /// @param _resolveInsideCode if false, does not descend into nodes that contain code. /// @returns false in case of error. bool resolveNamesAndTypes(ASTNode& _node, bool _resolveInsideCode = true); /// Updates the given global declaration (used for "this"). Not to be used with declarations diff --git a/libsolidity/analysis/TypeChecker.cpp b/libsolidity/analysis/TypeChecker.cpp index 06a9e1cea..28cb9acc3 100644 --- a/libsolidity/analysis/TypeChecker.cpp +++ b/libsolidity/analysis/TypeChecker.cpp @@ -427,12 +427,9 @@ bool TypeChecker::visit(StructDefinition const& _struct) bool TypeChecker::visit(FunctionDefinition const& _function) { - bool isLibraryFunction = false; - if ( + bool isLibraryFunction = dynamic_cast(_function.scope()) && - dynamic_cast(_function.scope())->isLibrary() - ) - isLibraryFunction = true; + dynamic_cast(_function.scope())->isLibrary(); if (_function.isPayable()) { if (isLibraryFunction)