|
@ -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()) |
|
|