aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/analysis
diff options
context:
space:
mode:
authorMartin Diz <gitlab@martindiz.com.ar>2018-10-04 23:31:52 +0800
committerMartin Diz <gitlab@martindiz.com.ar>2018-10-10 22:53:53 +0800
commitef25454a048bee9049c6076421d08732aeacb8bb (patch)
tree6d332b3126a8bfa6cd500eaa858e0dd45c00d7cb /libsolidity/analysis
parentdd4acda73a38ff83ab520e05b552012c324998d5 (diff)
downloaddexon-solidity-ef25454a048bee9049c6076421d08732aeacb8bb.tar
dexon-solidity-ef25454a048bee9049c6076421d08732aeacb8bb.tar.gz
dexon-solidity-ef25454a048bee9049c6076421d08732aeacb8bb.tar.bz2
dexon-solidity-ef25454a048bee9049c6076421d08732aeacb8bb.tar.lz
dexon-solidity-ef25454a048bee9049c6076421d08732aeacb8bb.tar.xz
dexon-solidity-ef25454a048bee9049c6076421d08732aeacb8bb.tar.zst
dexon-solidity-ef25454a048bee9049c6076421d08732aeacb8bb.zip
Improved error message for lookup in function types.
Diffstat (limited to 'libsolidity/analysis')
-rw-r--r--libsolidity/analysis/TypeChecker.cpp21
1 files changed, 19 insertions, 2 deletions
diff --git a/libsolidity/analysis/TypeChecker.cpp b/libsolidity/analysis/TypeChecker.cpp
index 39ea494d..5ffdda57 100644
--- a/libsolidity/analysis/TypeChecker.cpp
+++ b/libsolidity/analysis/TypeChecker.cpp
@@ -2141,8 +2141,25 @@ bool TypeChecker::visit(MemberAccess const& _memberAccess)
);
}
string errorMsg = "Member \"" + memberName + "\" not found or not visible "
- "after argument-dependent lookup in " + exprType->toString() +
- (memberName == "value" ? " - did you forget the \"payable\" modifier?" : ".");
+ "after argument-dependent lookup in " + exprType->toString() + ".";
+ if (memberName == "value")
+ {
+ errorMsg.pop_back();
+ errorMsg += " - did you forget the \"payable\" modifier?";
+ }
+ else if (exprType->category() == Type::Category::Function)
+ {
+ if (auto const& funType = dynamic_pointer_cast<FunctionType const>(exprType))
+ {
+ auto const& t = funType->returnParameterTypes();
+ if (t.size() == 1)
+ if (
+ t.front()->category() == Type::Category::Contract ||
+ t.front()->category() == Type::Category::Struct
+ )
+ errorMsg += " Did you intend to call the function?";
+ }
+ }
if (exprType->category() == Type::Category::Contract)
for (auto const& addressMember: AddressType::addressPayable().nativeMembers(nullptr))
if (addressMember.name == memberName)