mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Fix: Resolve function types of all contracts before checking types inside functions.
This commit is contained in:
		
							parent
							
								
									5b802b685e
								
							
						
					
					
						commit
						147e77b61f
					
				| @ -73,6 +73,15 @@ void CompilerStack::parse() | |||||||
| 				resolver.resolveNamesAndTypes(*contract); | 				resolver.resolveNamesAndTypes(*contract); | ||||||
| 				m_contracts[contract->getName()].contract = contract; | 				m_contracts[contract->getName()].contract = contract; | ||||||
| 			} | 			} | ||||||
|  | 	for (Source const* source: m_sourceOrder) | ||||||
|  | 		for (ASTPointer<ASTNode> const& node: source->ast->getNodes()) | ||||||
|  | 			if (ContractDefinition* contract = dynamic_cast<ContractDefinition*>(node.get())) | ||||||
|  | 			{ | ||||||
|  | 				m_globalContext->setCurrentContract(*contract); | ||||||
|  | 				resolver.updateDeclaration(*m_globalContext->getCurrentThis()); | ||||||
|  | 				resolver.checkTypeRequirements(*contract); | ||||||
|  | 				m_contracts[contract->getName()].contract = contract; | ||||||
|  | 			} | ||||||
| 	m_parseSuccessful = true; | 	m_parseSuccessful = true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -49,8 +49,6 @@ void NameAndTypeResolver::resolveNamesAndTypes(ContractDefinition& _contract) | |||||||
| 	m_currentScope = &m_scopes[&_contract]; | 	m_currentScope = &m_scopes[&_contract]; | ||||||
| 	for (ASTPointer<StructDefinition> const& structDef: _contract.getDefinedStructs()) | 	for (ASTPointer<StructDefinition> const& structDef: _contract.getDefinedStructs()) | ||||||
| 		ReferencesResolver resolver(*structDef, *this, nullptr); | 		ReferencesResolver resolver(*structDef, *this, nullptr); | ||||||
| 	for (ASTPointer<StructDefinition> const& structDef: _contract.getDefinedStructs()) |  | ||||||
| 		structDef->checkValidityOfMembers(); |  | ||||||
| 	for (ASTPointer<VariableDeclaration> const& variable: _contract.getStateVariables()) | 	for (ASTPointer<VariableDeclaration> const& variable: _contract.getStateVariables()) | ||||||
| 		ReferencesResolver resolver(*variable, *this, nullptr); | 		ReferencesResolver resolver(*variable, *this, nullptr); | ||||||
| 	for (ASTPointer<FunctionDefinition> const& function: _contract.getDefinedFunctions()) | 	for (ASTPointer<FunctionDefinition> const& function: _contract.getDefinedFunctions()) | ||||||
| @ -59,13 +57,16 @@ void NameAndTypeResolver::resolveNamesAndTypes(ContractDefinition& _contract) | |||||||
| 		ReferencesResolver referencesResolver(*function, *this, | 		ReferencesResolver referencesResolver(*function, *this, | ||||||
| 											  function->getReturnParameterList().get()); | 											  function->getReturnParameterList().get()); | ||||||
| 	} | 	} | ||||||
| 	// First, the parameter types of all functions need to be resolved before we can check
 |  | ||||||
| 	// the types, since it is possible to call functions that are only defined later
 |  | ||||||
| 	// in the source.
 |  | ||||||
| 	_contract.checkTypeRequirements(); |  | ||||||
| 	m_currentScope = &m_scopes[nullptr]; | 	m_currentScope = &m_scopes[nullptr]; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void NameAndTypeResolver::checkTypeRequirements(ContractDefinition& _contract) | ||||||
|  | { | ||||||
|  | 	for (ASTPointer<StructDefinition> const& structDef: _contract.getDefinedStructs()) | ||||||
|  | 		structDef->checkValidityOfMembers(); | ||||||
|  | 	_contract.checkTypeRequirements(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void NameAndTypeResolver::updateDeclaration(Declaration const& _declaration) | void NameAndTypeResolver::updateDeclaration(Declaration const& _declaration) | ||||||
| { | { | ||||||
| 	m_scopes[nullptr].registerDeclaration(_declaration, true); | 	m_scopes[nullptr].registerDeclaration(_declaration, true); | ||||||
|  | |||||||
| @ -46,6 +46,8 @@ public: | |||||||
| 	void registerDeclarations(SourceUnit& _sourceUnit); | 	void registerDeclarations(SourceUnit& _sourceUnit); | ||||||
| 	/// Resolves all names and types referenced from the given contract.
 | 	/// Resolves all names and types referenced from the given contract.
 | ||||||
| 	void resolveNamesAndTypes(ContractDefinition& _contract); | 	void resolveNamesAndTypes(ContractDefinition& _contract); | ||||||
|  | 	/// Check all type requirements in the given contract.
 | ||||||
|  | 	void checkTypeRequirements(ContractDefinition& _contract); | ||||||
| 	/// Updates the given global declaration (used for "this"). Not to be used with declarations
 | 	/// Updates the given global declaration (used for "this"). Not to be used with declarations
 | ||||||
| 	/// that create their own scope.
 | 	/// that create their own scope.
 | ||||||
| 	void updateDeclaration(Declaration const& _declaration); | 	void updateDeclaration(Declaration const& _declaration); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user