Merge pull request #11957 from ethereum/canonicalname-userdefinedvaluetype

Canonicalname for user defined value types
This commit is contained in:
Harikrishnan Mulackal 2021-09-15 13:38:33 +02:00 committed by GitHub
commit ea2386adb1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 39 additions and 36 deletions

View File

@ -612,13 +612,31 @@ bool DeclarationRegistrationHelper::visitNode(ASTNode& _node)
if (auto* declaration = dynamic_cast<Declaration*>(&_node)) if (auto* declaration = dynamic_cast<Declaration*>(&_node))
registerDeclaration(*declaration); registerDeclaration(*declaration);
if (auto* annotation = dynamic_cast<TypeDeclarationAnnotation*>(&_node.annotation()))
{
string canonicalName = dynamic_cast<Declaration const&>(_node).name();
solAssert(!canonicalName.empty(), "");
for (
ASTNode const* scope = m_currentScope;
scope != nullptr;
scope = m_scopes[scope]->enclosingNode()
)
if (auto decl = dynamic_cast<Declaration const*>(scope))
{
solAssert(!decl->name().empty(), "");
canonicalName = decl->name() + "." + canonicalName;
}
annotation->canonicalName = canonicalName;
}
if (dynamic_cast<ScopeOpener const*>(&_node)) if (dynamic_cast<ScopeOpener const*>(&_node))
enterNewSubScope(_node); enterNewSubScope(_node);
if (auto* variableScope = dynamic_cast<VariableScope*>(&_node)) if (auto* variableScope = dynamic_cast<VariableScope*>(&_node))
m_currentFunction = variableScope; m_currentFunction = variableScope;
if (auto* annotation = dynamic_cast<TypeDeclarationAnnotation*>(&_node.annotation()))
annotation->canonicalName = currentCanonicalName();
return true; return true;
} }
@ -668,23 +686,4 @@ void DeclarationRegistrationHelper::registerDeclaration(Declaration& _declaratio
solAssert(_declaration.annotation().contract == m_currentContract, ""); solAssert(_declaration.annotation().contract == m_currentContract, "");
} }
string DeclarationRegistrationHelper::currentCanonicalName() const
{
string ret;
for (
ASTNode const* scope = m_currentScope;
scope != nullptr;
scope = m_scopes[scope]->enclosingNode()
)
{
if (auto decl = dynamic_cast<Declaration const*>(scope))
{
if (!ret.empty())
ret = "." + ret;
ret = decl->name() + ret;
}
}
return ret;
}
} }

View File

@ -176,9 +176,6 @@ private:
static bool isOverloadedFunction(Declaration const& _declaration1, Declaration const& _declaration2); static bool isOverloadedFunction(Declaration const& _declaration1, Declaration const& _declaration2);
/// @returns the canonical name of the current scope.
std::string currentCanonicalName() const;
std::map<ASTNode const*, std::shared_ptr<DeclarationContainer>>& m_scopes; std::map<ASTNode const*, std::shared_ptr<DeclarationContainer>>& m_scopes;
ASTNode const* m_currentScope = nullptr; ASTNode const* m_currentScope = nullptr;
VariableScope* m_currentFunction = nullptr; VariableScope* m_currentFunction = nullptr;

View File

@ -341,6 +341,11 @@ Type const* UserDefinedValueTypeDefinition::type() const
return TypeProvider::typeType(TypeProvider::userDefinedValueType(*this)); return TypeProvider::typeType(TypeProvider::userDefinedValueType(*this));
} }
TypeDeclarationAnnotation& UserDefinedValueTypeDefinition::annotation() const
{
return initAnnotation<TypeDeclarationAnnotation>();
}
Type const* StructDefinition::type() const Type const* StructDefinition::type() const
{ {
solAssert(annotation().recursive.has_value(), "Requested struct type before DeclarationTypeChecker."); solAssert(annotation().recursive.has_value(), "Requested struct type before DeclarationTypeChecker.");

View File

@ -750,6 +750,8 @@ public:
Type const* type() const override; Type const* type() const override;
TypeDeclarationAnnotation& annotation() const override;
TypeName const* underlyingType() const { return m_underlyingType.get(); } TypeName const* underlyingType() const { return m_underlyingType.get(); }
bool isVisibleViaContractTypeAccess() const override { return true; } bool isVisibleViaContractTypeAccess() const override { return true; }

View File

@ -2555,7 +2555,7 @@ bool UserDefinedValueType::operator==(Type const& _other) const
string UserDefinedValueType::toString(bool /* _short */) const string UserDefinedValueType::toString(bool /* _short */) const
{ {
return "user defined type " + definition().name(); return "user defined type " + *definition().annotation().canonicalName;
} }
vector<tuple<string, Type const*>> UserDefinedValueType::makeStackItems() const vector<tuple<string, Type const*>> UserDefinedValueType::makeStackItems() const

View File

@ -36,7 +36,7 @@ contract C {
// "outputs": // "outputs":
// [ // [
// { // {
// "internalType": "user defined type MyAddress", // "internalType": "user defined type C.MyAddress",
// "name": "", // "name": "",
// "type": "address" // "type": "address"
// } // }
@ -64,7 +64,7 @@ contract C {
// "outputs": // "outputs":
// [ // [
// { // {
// "internalType": "user defined type MyBytes32", // "internalType": "user defined type C.MyBytes32",
// "name": "", // "name": "",
// "type": "bytes32" // "type": "bytes32"
// } // }
@ -92,7 +92,7 @@ contract C {
// "outputs": // "outputs":
// [ // [
// { // {
// "internalType": "user defined type MyUInt8", // "internalType": "user defined type C.MyUInt8",
// "name": "", // "name": "",
// "type": "uint8" // "type": "uint8"
// } // }
@ -104,7 +104,7 @@ contract C {
// "inputs": // "inputs":
// [ // [
// { // {
// "internalType": "user defined type MyAddress", // "internalType": "user defined type C.MyAddress",
// "name": "a", // "name": "a",
// "type": "address" // "type": "address"
// } // }
@ -132,7 +132,7 @@ contract C {
// "inputs": // "inputs":
// [ // [
// { // {
// "internalType": "user defined type MyBytes32", // "internalType": "user defined type C.MyBytes32",
// "name": "a", // "name": "a",
// "type": "bytes32" // "type": "bytes32"
// } // }
@ -160,7 +160,7 @@ contract C {
// "inputs": // "inputs":
// [ // [
// { // {
// "internalType": "user defined type MyUInt8", // "internalType": "user defined type C.MyUInt8",
// "name": "a", // "name": "a",
// "type": "uint8" // "type": "uint8"
// } // }

View File

@ -269,7 +269,7 @@
"typeDescriptions": "typeDescriptions":
{ {
"typeIdentifier": "t_mapping$_t_userDefinedValueType$_MyAddress_$18_$_t_userDefinedValueType$_MyUInt_$20_$", "typeIdentifier": "t_mapping$_t_userDefinedValueType$_MyAddress_$18_$_t_userDefinedValueType$_MyUInt_$20_$",
"typeString": "mapping(user defined type MyAddress => user defined type MyUInt)" "typeString": "mapping(user defined type C.MyAddress => user defined type C.MyUInt)"
}, },
"typeName": "typeName":
{ {
@ -291,7 +291,7 @@
"typeDescriptions": "typeDescriptions":
{ {
"typeIdentifier": "t_userDefinedValueType$_MyAddress_$18", "typeIdentifier": "t_userDefinedValueType$_MyAddress_$18",
"typeString": "user defined type MyAddress" "typeString": "user defined type C.MyAddress"
} }
}, },
"nodeType": "Mapping", "nodeType": "Mapping",
@ -299,7 +299,7 @@
"typeDescriptions": "typeDescriptions":
{ {
"typeIdentifier": "t_mapping$_t_userDefinedValueType$_MyAddress_$18_$_t_userDefinedValueType$_MyUInt_$20_$", "typeIdentifier": "t_mapping$_t_userDefinedValueType$_MyAddress_$18_$_t_userDefinedValueType$_MyUInt_$20_$",
"typeString": "mapping(user defined type MyAddress => user defined type MyUInt)" "typeString": "mapping(user defined type C.MyAddress => user defined type C.MyUInt)"
}, },
"valueType": "valueType":
{ {
@ -318,7 +318,7 @@
"typeDescriptions": "typeDescriptions":
{ {
"typeIdentifier": "t_userDefinedValueType$_MyUInt_$20", "typeIdentifier": "t_userDefinedValueType$_MyUInt_$20",
"typeString": "user defined type MyUInt" "typeString": "user defined type C.MyUInt"
} }
} }
}, },

View File

@ -5,4 +5,4 @@ contract D
C.T x = L.T.wrap(uint(1)); C.T x = L.T.wrap(uint(1));
} }
// ---- // ----
// TypeError 7407: (86-103): Type user defined type T is not implicitly convertible to expected type user defined type T. // TypeError 7407: (86-103): Type user defined type L.T is not implicitly convertible to expected type user defined type C.T.