mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Merge pull request #2565 from ethereum/literal-string-error
Include types in explicit conversion error message
This commit is contained in:
commit
b61f744dd9
@ -4,6 +4,7 @@ Features:
|
|||||||
* Inline Assembly: Show useful error message if trying to access calldata variables.
|
* Inline Assembly: Show useful error message if trying to access calldata variables.
|
||||||
* Inline Assembly: Support variable declaration without initial value (defaults to 0).
|
* Inline Assembly: Support variable declaration without initial value (defaults to 0).
|
||||||
* Type Checker: Disallow value transfers to contracts without a payable fallback function.
|
* Type Checker: Disallow value transfers to contracts without a payable fallback function.
|
||||||
|
* Type Checker: Include types in explicit conversion error message.
|
||||||
* Type Checker: Raise proper error for arrays too large for ABI encoding.
|
* Type Checker: Raise proper error for arrays too large for ABI encoding.
|
||||||
|
|
||||||
Bugfixes:
|
Bugfixes:
|
||||||
|
@ -1364,7 +1364,14 @@ bool TypeChecker::visit(FunctionCall const& _functionCall)
|
|||||||
// (data location cannot yet be specified for type conversions)
|
// (data location cannot yet be specified for type conversions)
|
||||||
resultType = ReferenceType::copyForLocationIfReference(argRefType->location(), resultType);
|
resultType = ReferenceType::copyForLocationIfReference(argRefType->location(), resultType);
|
||||||
if (!argType->isExplicitlyConvertibleTo(*resultType))
|
if (!argType->isExplicitlyConvertibleTo(*resultType))
|
||||||
m_errorReporter.typeError(_functionCall.location(), "Explicit type conversion not allowed.");
|
m_errorReporter.typeError(
|
||||||
|
_functionCall.location(),
|
||||||
|
"Explicit type conversion not allowed from \"" +
|
||||||
|
argType->toString() +
|
||||||
|
"\" to \"" +
|
||||||
|
resultType->toString() +
|
||||||
|
"\"."
|
||||||
|
);
|
||||||
}
|
}
|
||||||
_functionCall.annotation().type = resultType;
|
_functionCall.annotation().type = resultType;
|
||||||
_functionCall.annotation().isPure = isPure;
|
_functionCall.annotation().isPure = isPure;
|
||||||
|
@ -6322,6 +6322,43 @@ BOOST_AUTO_TEST_CASE(too_large_arrays_for_calldata)
|
|||||||
CHECK_ERROR(text, TypeError, "Array is too large to be encoded as calldata.");
|
CHECK_ERROR(text, TypeError, "Array is too large to be encoded as calldata.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(explicit_literal_to_storage_string)
|
||||||
|
{
|
||||||
|
char const* text = R"(
|
||||||
|
contract C {
|
||||||
|
function f() {
|
||||||
|
string memory x = "abc";
|
||||||
|
x;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)";
|
||||||
|
CHECK_SUCCESS_NO_WARNINGS(text);
|
||||||
|
text = R"(
|
||||||
|
contract C {
|
||||||
|
function f() {
|
||||||
|
string storage x = "abc";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)";
|
||||||
|
CHECK_ERROR(text, TypeError, "Type literal_string \"abc\" is not implicitly convertible to expected type string storage pointer.");
|
||||||
|
text = R"(
|
||||||
|
contract C {
|
||||||
|
function f() {
|
||||||
|
string x = "abc";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)";
|
||||||
|
CHECK_ERROR(text, TypeError, "Type literal_string \"abc\" is not implicitly convertible to expected type string storage pointer.");
|
||||||
|
text = R"(
|
||||||
|
contract C {
|
||||||
|
function f() {
|
||||||
|
string("abc");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)";
|
||||||
|
CHECK_ERROR(text, TypeError, "Explicit type conversion not allowed from \"literal_string \"abc\"\" to \"string storage pointer\"");
|
||||||
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_SUITE_END()
|
BOOST_AUTO_TEST_SUITE_END()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user