mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Check for hash collisions already before compiling.
This commit is contained in:
		
							parent
							
								
									80eec8b308
								
							
						
					
					
						commit
						6e16107870
					
				
							
								
								
									
										38
									
								
								AST.cpp
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								AST.cpp
									
									
									
									
									
								
							| @ -50,18 +50,27 @@ void ContractDefinition::checkTypeRequirements() | |||||||
| 
 | 
 | ||||||
| 	for (ASTPointer<FunctionDefinition> const& function: getDefinedFunctions()) | 	for (ASTPointer<FunctionDefinition> const& function: getDefinedFunctions()) | ||||||
| 		function->checkTypeRequirements(); | 		function->checkTypeRequirements(); | ||||||
|  | 
 | ||||||
|  | 	// check for hash collisions in function signatures
 | ||||||
|  | 	vector<pair<FixedHash<4>, FunctionDefinition const*>> exportedFunctionList = getInterfaceFunctionList(); | ||||||
|  | 	set<FixedHash<4>> hashes; | ||||||
|  | 	for (auto const& hashAndFunction: getInterfaceFunctionList()) | ||||||
|  | 	{ | ||||||
|  | 		FixedHash<4> const& hash = hashAndFunction.first; | ||||||
|  | 		if (hashes.count(hash)) | ||||||
|  | 			BOOST_THROW_EXCEPTION(createTypeError("Function signature hash collision for " + | ||||||
|  | 												  hashAndFunction.second->getCanonicalSignature())); | ||||||
|  | 		hashes.insert(hash); | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| map<FixedHash<4>, FunctionDefinition const*> ContractDefinition::getInterfaceFunctions() const | map<FixedHash<4>, FunctionDefinition const*> ContractDefinition::getInterfaceFunctions() const | ||||||
| { | { | ||||||
| 	map<FixedHash<4>, FunctionDefinition const*> exportedFunctions; | 	vector<pair<FixedHash<4>, FunctionDefinition const*>> exportedFunctionList = getInterfaceFunctionList(); | ||||||
| 	for (ASTPointer<FunctionDefinition> const& f: m_definedFunctions) | 	map<FixedHash<4>, FunctionDefinition const*> exportedFunctions(exportedFunctionList.begin(), | ||||||
| 		if (f->isPublic() && f->getName() != getName()) | 																   exportedFunctionList.end()); | ||||||
| 		{ | 	solAssert(exportedFunctionList.size() == exportedFunctions.size(), | ||||||
| 			FixedHash<4> hash(dev::sha3(f->getCanonicalSignature())); | 			  "Hash collision at Function Definition Hash calculation"); | ||||||
| 			auto res = exportedFunctions.insert(std::make_pair(hash,f.get())); |  | ||||||
| 			solAssert(res.second, "Hash collision at Function Definition Hash calculation"); |  | ||||||
| 		} |  | ||||||
| 
 | 
 | ||||||
| 	return exportedFunctions; | 	return exportedFunctions; | ||||||
| } | } | ||||||
| @ -74,6 +83,19 @@ FunctionDefinition const* ContractDefinition::getConstructor() const | |||||||
| 	return nullptr; | 	return nullptr; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | vector<pair<FixedHash<4>, FunctionDefinition const*>> ContractDefinition::getInterfaceFunctionList() const | ||||||
|  | { | ||||||
|  | 	vector<pair<FixedHash<4>, FunctionDefinition const*>> exportedFunctions; | ||||||
|  | 	for (ASTPointer<FunctionDefinition> const& f: m_definedFunctions) | ||||||
|  | 		if (f->isPublic() && f->getName() != getName()) | ||||||
|  | 		{ | ||||||
|  | 			FixedHash<4> hash(dev::sha3(f->getCanonicalSignature())); | ||||||
|  | 			exportedFunctions.push_back(make_pair(hash, f.get())); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 	return exportedFunctions; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void StructDefinition::checkMemberTypes() const | void StructDefinition::checkMemberTypes() const | ||||||
| { | { | ||||||
| 	for (ASTPointer<VariableDeclaration> const& member: getMembers()) | 	for (ASTPointer<VariableDeclaration> const& member: getMembers()) | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								AST.h
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								AST.h
									
									
									
									
									
								
							| @ -191,6 +191,8 @@ public: | |||||||
| 	FunctionDefinition const* getConstructor() const; | 	FunctionDefinition const* getConstructor() const; | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|  | 	std::vector<std::pair<FixedHash<4>, FunctionDefinition const*>> getInterfaceFunctionList() const; | ||||||
|  | 
 | ||||||
| 	std::vector<ASTPointer<StructDefinition>> m_definedStructs; | 	std::vector<ASTPointer<StructDefinition>> m_definedStructs; | ||||||
| 	std::vector<ASTPointer<VariableDeclaration>> m_stateVariables; | 	std::vector<ASTPointer<VariableDeclaration>> m_stateVariables; | ||||||
| 	std::vector<ASTPointer<FunctionDefinition>> m_definedFunctions; | 	std::vector<ASTPointer<FunctionDefinition>> m_definedFunctions; | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user