From 624d2d396881749c69c50c75f11469693c4655fe Mon Sep 17 00:00:00 2001 From: nishant-sachdeva Date: Fri, 11 Mar 2022 14:13:42 +0530 Subject: [PATCH] Error messages from abi encodecall are giving more details about the types of the involved variables --- libsolidity/analysis/TypeChecker.cpp | 4 ++-- ...bi_encode_convert_address_to_address_payable.sol | 11 +++++++++++ ...nction_pointer_to_different_function_pointer.sol | 13 +++++++++++++ ...ncode_convert_function_to_different_function.sol | 13 +++++++++++++ ...bi_encode_convert_string_to_different_string.sol | 12 ++++++++++++ .../specialFunctions/encodeCall_fail_args.sol | 2 +- 6 files changed, 52 insertions(+), 3 deletions(-) create mode 100644 test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_address_to_address_payable.sol create mode 100644 test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_function_pointer_to_different_function_pointer.sol create mode 100644 test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_function_to_different_function.sol create mode 100644 test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_string_to_different_string.sol diff --git a/libsolidity/analysis/TypeChecker.cpp b/libsolidity/analysis/TypeChecker.cpp index 955c66f84..0ea9c6c08 100644 --- a/libsolidity/analysis/TypeChecker.cpp +++ b/libsolidity/analysis/TypeChecker.cpp @@ -2204,9 +2204,9 @@ void TypeChecker::typeCheckABIEncodeCallFunction(FunctionCall const& _functionCa "Cannot implicitly convert component at position " + to_string(i) + " from \"" + - argType.canonicalName() + + argType.toString() + "\" to \"" + - functionPointerType->parameterTypes()[i]->canonicalName() + + functionPointerType->parameterTypes()[i]->toString() + "\"" + (result.message().empty() ? "." : ": " + result.message()) ); diff --git a/test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_address_to_address_payable.sol b/test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_address_to_address_payable.sol new file mode 100644 index 000000000..a4c823a85 --- /dev/null +++ b/test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_address_to_address_payable.sol @@ -0,0 +1,11 @@ +interface I { + function f(address payable) external; +} + +contract C { + function main() external view { + abi.encodeCall(I.f, (address(0))); + } +} +// ---- +// TypeError 5407: (136-148): Cannot implicitly convert component at position 0 from "address" to "address payable". diff --git a/test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_function_pointer_to_different_function_pointer.sol b/test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_function_pointer_to_different_function_pointer.sol new file mode 100644 index 000000000..7c570e29e --- /dev/null +++ b/test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_function_pointer_to_different_function_pointer.sol @@ -0,0 +1,13 @@ +interface I { + function f(function (string calldata) external) external; +} + +contract C { + function g(string calldata) external {} + + function main() external view { + abi.encodeCall(I.f, (this.g)); + } +} +// ---- +// TypeError 5407: (201-209): Cannot implicitly convert component at position 0 from "function (string memory) external" to "function (string calldata) external". diff --git a/test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_function_to_different_function.sol b/test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_function_to_different_function.sol new file mode 100644 index 000000000..7a35bfa55 --- /dev/null +++ b/test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_function_to_different_function.sol @@ -0,0 +1,13 @@ +interface I { + function f(function (string calldata) external view returns (uint)) external; +} + +contract C { + function g(string memory) external {} + + function main() external view { + abi.encodeCall(I.f, (this.g)); + } +} +// ---- +// TypeError 5407: (219-227): Cannot implicitly convert component at position 0 from "function (string memory) external" to "function (string calldata) view external returns (uint256)". diff --git a/test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_string_to_different_string.sol b/test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_string_to_different_string.sol new file mode 100644 index 000000000..72efe4a07 --- /dev/null +++ b/test/libsolidity/syntaxTests/abiEncoder/abi_encode_convert_string_to_different_string.sol @@ -0,0 +1,12 @@ +interface I { + function f(string calldata) external; +} + +contract C { + string s; + function main() external view { + abi.encodeCall(I.f, (s)); + } +} +// ---- +// TypeError 5407: (150-153): Cannot implicitly convert component at position 0 from "string storage ref" to "string calldata". diff --git a/test/libsolidity/syntaxTests/specialFunctions/encodeCall_fail_args.sol b/test/libsolidity/syntaxTests/specialFunctions/encodeCall_fail_args.sol index a1c20f9bd..48372263f 100644 --- a/test/libsolidity/syntaxTests/specialFunctions/encodeCall_fail_args.sol +++ b/test/libsolidity/syntaxTests/specialFunctions/encodeCall_fail_args.sol @@ -24,4 +24,4 @@ contract C { // TypeError 7788: (382-408): Expected 1 instead of 0 components for the tuple parameter. // TypeError 6219: (489-511): Expected two arguments: a function pointer followed by a tuple. // TypeError 7515: (597-628): Expected a tuple with 2 components instead of a single non-tuple parameter. -// TypeError 5407: (621-627): Cannot implicitly convert component at position 0 from "uint8[2]" to "int256". +// TypeError 5407: (621-627): Cannot implicitly convert component at position 0 from "uint8[2] memory" to "int256".