mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Do not set to ref for explicit conversion and add assertion for array
type conversion. Also, add some test cases for #4901 and #4948.
This commit is contained in:
parent
5f4a2d2cad
commit
f3cbdadec7
@ -1733,8 +1733,23 @@ bool TypeChecker::visit(FunctionCall const& _functionCall)
|
||||
DataLocation dataLoc = DataLocation::Memory;
|
||||
if (auto argRefType = dynamic_cast<ReferenceType const*>(argType.get()))
|
||||
dataLoc = argRefType->location();
|
||||
resultType = ReferenceType::copyForLocationIfReference(dataLoc, resultType);
|
||||
if (!argType->isExplicitlyConvertibleTo(*resultType))
|
||||
if (auto type = dynamic_cast<ReferenceType const*>(resultType.get()))
|
||||
resultType = type->copyForLocation(dataLoc, type->isPointer());
|
||||
if (argType->isExplicitlyConvertibleTo(*resultType))
|
||||
{
|
||||
if (auto argArrayType = dynamic_cast<ArrayType const*>(argType.get()))
|
||||
{
|
||||
auto resultArrayType = dynamic_cast<ArrayType const*>(resultType.get());
|
||||
solAssert(!!resultArrayType, "");
|
||||
solAssert(
|
||||
argArrayType->location() != DataLocation::Storage ||
|
||||
((resultArrayType->isPointer() || (argArrayType->isByteArray() && resultArrayType->isByteArray())) &&
|
||||
resultArrayType->location() == DataLocation::Storage),
|
||||
"Invalid explicit conversion to storage type."
|
||||
);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if (resultType->category() == Type::Category::Contract && argType->category() == Type::Category::Address)
|
||||
{
|
||||
|
@ -0,0 +1,9 @@
|
||||
contract C {
|
||||
bytes a;
|
||||
bytes b;
|
||||
function f() public view {
|
||||
bytes storage c = a;
|
||||
bytes memory d = b;
|
||||
d = bytes(c);
|
||||
}
|
||||
}
|
@ -0,0 +1,9 @@
|
||||
contract C {
|
||||
string a;
|
||||
string b;
|
||||
function f() public view {
|
||||
string storage c = a;
|
||||
string memory d = b;
|
||||
d = string(c);
|
||||
}
|
||||
}
|
@ -0,0 +1,10 @@
|
||||
contract C {
|
||||
int[10] x;
|
||||
function f() public view {
|
||||
int[](x);
|
||||
int(x);
|
||||
}
|
||||
}
|
||||
// ----
|
||||
// TypeError: (55-63): Explicit type conversion not allowed from "int256[10] storage ref" to "int256[] storage pointer".
|
||||
// TypeError: (67-73): Explicit type conversion not allowed from "int256[10] storage ref" to "int256".
|
@ -0,0 +1,7 @@
|
||||
contract C {
|
||||
int[10] x;
|
||||
int[] y;
|
||||
function f() public {
|
||||
y = x;
|
||||
}
|
||||
}
|
@ -0,0 +1,10 @@
|
||||
contract C {
|
||||
uint[] a;
|
||||
uint[] b;
|
||||
function f() public view {
|
||||
uint[] storage c = a;
|
||||
uint[] storage d = b;
|
||||
d = uint[](c);
|
||||
}
|
||||
}
|
||||
// ----
|
@ -0,0 +1,10 @@
|
||||
contract C {
|
||||
uint[] a;
|
||||
uint[] b;
|
||||
function f() public view {
|
||||
uint[] storage c = a;
|
||||
uint[] memory d = b;
|
||||
d = uint[](c);
|
||||
}
|
||||
}
|
||||
// ----
|
@ -0,0 +1,12 @@
|
||||
contract C {
|
||||
int[] x;
|
||||
function f() public {
|
||||
int[] storage a = x;
|
||||
int[] memory b;
|
||||
a = b;
|
||||
a = int[](b);
|
||||
}
|
||||
}
|
||||
// ----
|
||||
// TypeError: (93-94): Type int256[] memory is not implicitly convertible to expected type int256[] storage pointer.
|
||||
// TypeError: (102-110): Type int256[] memory is not implicitly convertible to expected type int256[] storage pointer.
|
Loading…
Reference in New Issue
Block a user