mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Merge pull request #4147 from ethereum/hash-non-bytes-arg
Split warning for multi arguments for hash functions
This commit is contained in:
commit
365ad05838
@ -1762,22 +1762,24 @@ bool TypeChecker::visit(FunctionCall const& _functionCall)
|
|||||||
|
|
||||||
if (functionType->takesSinglePackedBytesParameter())
|
if (functionType->takesSinglePackedBytesParameter())
|
||||||
{
|
{
|
||||||
string generalMessage =
|
if (
|
||||||
"This function only accepts a single \"bytes\" argument. Please use "
|
(arguments.size() > 1) ||
|
||||||
"\"abi.encodePacked(...)\" or a similar function to encode the data.";
|
(arguments.size() == 1 && !type(*arguments.front())->isImplicitlyConvertibleTo(ArrayType(DataLocation::Memory)))
|
||||||
|
)
|
||||||
if (arguments.size() > 1)
|
|
||||||
{
|
|
||||||
if (v050)
|
|
||||||
m_errorReporter.typeError(_functionCall.location(), generalMessage);
|
|
||||||
else
|
|
||||||
m_errorReporter.warning(_functionCall.location(), generalMessage);
|
|
||||||
}
|
|
||||||
else if (arguments.size() == 1 && !type(*arguments.front())->isImplicitlyConvertibleTo(ArrayType(DataLocation::Memory)))
|
|
||||||
{
|
{
|
||||||
string msg =
|
string msg =
|
||||||
generalMessage +
|
"This function only accepts a single \"bytes\" argument. Please use "
|
||||||
" The provided argument of type " +
|
"\"abi.encodePacked(...)\" or a similar function to encode the data.";
|
||||||
|
if (v050)
|
||||||
|
m_errorReporter.typeError(_functionCall.location(), msg);
|
||||||
|
else
|
||||||
|
m_errorReporter.warning(_functionCall.location(), msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (arguments.size() == 1 && !type(*arguments.front())->isImplicitlyConvertibleTo(ArrayType(DataLocation::Memory)))
|
||||||
|
{
|
||||||
|
string msg =
|
||||||
|
"The provided argument of type " +
|
||||||
type(*arguments.front())->toString() +
|
type(*arguments.front())->toString() +
|
||||||
" is not implicitly convertible to expected type bytes memory.";
|
" is not implicitly convertible to expected type bytes memory.";
|
||||||
if (v050)
|
if (v050)
|
||||||
|
@ -5,7 +5,8 @@ contract C {
|
|||||||
uint constant d = 2 + a;
|
uint constant d = 2 + a;
|
||||||
}
|
}
|
||||||
// ----
|
// ----
|
||||||
// Warning: (98-110): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type uint256 is not implicitly convertible to expected type bytes memory.
|
// Warning: (98-110): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// Warning: (98-110): The provided argument of type uint256 is not implicitly convertible to expected type bytes memory.
|
||||||
// TypeError: (17-40): The value of the constant a has a cyclic dependency via c.
|
// TypeError: (17-40): The value of the constant a has a cyclic dependency via c.
|
||||||
// TypeError: (71-111): The value of the constant c has a cyclic dependency via d.
|
// TypeError: (71-111): The value of the constant c has a cyclic dependency via d.
|
||||||
// TypeError: (117-140): The value of the constant d has a cyclic dependency via a.
|
// TypeError: (117-140): The value of the constant d has a cyclic dependency via a.
|
||||||
|
@ -5,4 +5,5 @@ contract C {
|
|||||||
uint constant d = 2 + b;
|
uint constant d = 2 + b;
|
||||||
}
|
}
|
||||||
// ----
|
// ----
|
||||||
// Warning: (98-110): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type uint256 is not implicitly convertible to expected type bytes memory.
|
// Warning: (98-110): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// Warning: (98-110): The provided argument of type uint256 is not implicitly convertible to expected type bytes memory.
|
||||||
|
@ -10,5 +10,6 @@ contract test {
|
|||||||
}
|
}
|
||||||
// ----
|
// ----
|
||||||
// TypeError: (88-102): "sha3" has been deprecated in favour of "keccak256"
|
// TypeError: (88-102): "sha3" has been deprecated in favour of "keccak256"
|
||||||
// TypeError: (88-102): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type uint8 is not implicitly convertible to expected type bytes memory.
|
// TypeError: (88-102): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// TypeError: (88-102): The provided argument of type uint8 is not implicitly convertible to expected type bytes memory.
|
||||||
// TypeError: (137-147): "suicide" has been deprecated in favour of "selfdestruct"
|
// TypeError: (137-147): "suicide" has been deprecated in favour of "selfdestruct"
|
||||||
|
@ -7,6 +7,9 @@ contract C {
|
|||||||
function g(bytes32) pure internal {}
|
function g(bytes32) pure internal {}
|
||||||
}
|
}
|
||||||
// ----
|
// ----
|
||||||
// Warning: (54-72): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type uint256 is not implicitly convertible to expected type bytes memory.
|
// Warning: (54-72): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
// Warning: (85-100): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type uint256 is not implicitly convertible to expected type bytes memory.
|
// Warning: (54-72): The provided argument of type uint256 is not implicitly convertible to expected type bytes memory.
|
||||||
// Warning: (113-131): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type uint256 is not implicitly convertible to expected type bytes memory.
|
// Warning: (85-100): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// Warning: (85-100): The provided argument of type uint256 is not implicitly convertible to expected type bytes memory.
|
||||||
|
// Warning: (113-131): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// Warning: (113-131): The provided argument of type uint256 is not implicitly convertible to expected type bytes memory.
|
||||||
|
@ -18,12 +18,16 @@ contract C {
|
|||||||
|
|
||||||
// ----
|
// ----
|
||||||
// Warning: (87-88): The type of "int_const 1" was inferred as uint8. This is probably not desired. Use an explicit type to silence this warning.
|
// Warning: (87-88): The type of "int_const 1" was inferred as uint8. This is probably not desired. Use an explicit type to silence this warning.
|
||||||
// Warning: (77-89): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
// Warning: (77-89): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// Warning: (77-89): The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
||||||
// Warning: (161-168): "sha3" has been deprecated in favour of "keccak256"
|
// Warning: (161-168): "sha3" has been deprecated in favour of "keccak256"
|
||||||
// Warning: (166-167): The type of "int_const 1" was inferred as uint8. This is probably not desired. Use an explicit type to silence this warning.
|
// Warning: (166-167): The type of "int_const 1" was inferred as uint8. This is probably not desired. Use an explicit type to silence this warning.
|
||||||
// Warning: (161-168): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
// Warning: (161-168): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// Warning: (161-168): The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
||||||
// Warning: (247-248): The type of "int_const 1" was inferred as uint8. This is probably not desired. Use an explicit type to silence this warning.
|
// Warning: (247-248): The type of "int_const 1" was inferred as uint8. This is probably not desired. Use an explicit type to silence this warning.
|
||||||
// Warning: (240-249): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
// Warning: (240-249): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// Warning: (240-249): The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
||||||
// Warning: (331-332): The type of "int_const 1" was inferred as uint8. This is probably not desired. Use an explicit type to silence this warning.
|
// Warning: (331-332): The type of "int_const 1" was inferred as uint8. This is probably not desired. Use an explicit type to silence this warning.
|
||||||
// Warning: (321-333): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
// Warning: (321-333): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// Warning: (321-333): The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
||||||
// Warning: (420-421): The type of "int_const 1" was inferred as uint8. This is probably not desired. Use an explicit type to silence this warning.
|
// Warning: (420-421): The type of "int_const 1" was inferred as uint8. This is probably not desired. Use an explicit type to silence this warning.
|
||||||
|
@ -19,12 +19,16 @@ contract C {
|
|||||||
|
|
||||||
// ----
|
// ----
|
||||||
// TypeError: (117-118): Cannot perform packed encoding for a literal. Please convert it to an explicit type first.
|
// TypeError: (117-118): Cannot perform packed encoding for a literal. Please convert it to an explicit type first.
|
||||||
// TypeError: (107-119): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
// TypeError: (107-119): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// TypeError: (107-119): The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
||||||
// TypeError: (191-198): "sha3" has been deprecated in favour of "keccak256"
|
// TypeError: (191-198): "sha3" has been deprecated in favour of "keccak256"
|
||||||
// TypeError: (196-197): Cannot perform packed encoding for a literal. Please convert it to an explicit type first.
|
// TypeError: (196-197): Cannot perform packed encoding for a literal. Please convert it to an explicit type first.
|
||||||
// TypeError: (191-198): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
// TypeError: (191-198): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// TypeError: (191-198): The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
||||||
// TypeError: (277-278): Cannot perform packed encoding for a literal. Please convert it to an explicit type first.
|
// TypeError: (277-278): Cannot perform packed encoding for a literal. Please convert it to an explicit type first.
|
||||||
// TypeError: (270-279): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
// TypeError: (270-279): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// TypeError: (270-279): The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
||||||
// TypeError: (361-362): Cannot perform packed encoding for a literal. Please convert it to an explicit type first.
|
// TypeError: (361-362): Cannot perform packed encoding for a literal. Please convert it to an explicit type first.
|
||||||
// TypeError: (351-363): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
// TypeError: (351-363): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// TypeError: (351-363): The provided argument of type int_const 1 is not implicitly convertible to expected type bytes memory.
|
||||||
// TypeError: (450-451): Cannot perform packed encoding for a literal. Please convert it to an explicit type first.
|
// TypeError: (450-451): Cannot perform packed encoding for a literal. Please convert it to an explicit type first.
|
||||||
|
@ -19,8 +19,12 @@ contract C {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// ----
|
// ----
|
||||||
// Warning: (77-96): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type uint8 is not implicitly convertible to expected type bytes memory.
|
// Warning: (77-96): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// Warning: (77-96): The provided argument of type uint8 is not implicitly convertible to expected type bytes memory.
|
||||||
// Warning: (168-182): "sha3" has been deprecated in favour of "keccak256"
|
// Warning: (168-182): "sha3" has been deprecated in favour of "keccak256"
|
||||||
// Warning: (168-182): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type uint8 is not implicitly convertible to expected type bytes memory.
|
// Warning: (168-182): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
// Warning: (254-270): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type uint8 is not implicitly convertible to expected type bytes memory.
|
// Warning: (168-182): The provided argument of type uint8 is not implicitly convertible to expected type bytes memory.
|
||||||
// Warning: (342-361): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data. The provided argument of type uint8 is not implicitly convertible to expected type bytes memory.
|
// Warning: (254-270): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// Warning: (254-270): The provided argument of type uint8 is not implicitly convertible to expected type bytes memory.
|
||||||
|
// Warning: (342-361): This function only accepts a single "bytes" argument. Please use "abi.encodePacked(...)" or a similar function to encode the data.
|
||||||
|
// Warning: (342-361): The provided argument of type uint8 is not implicitly convertible to expected type bytes memory.
|
||||||
|
Loading…
Reference in New Issue
Block a user