mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Merge pull request #10910 from ethereum/calldataLValueSol2Yul
[Sol->Yul] Fixing setLValue for calldata types.
This commit is contained in:
commit
711671236a
@ -2918,10 +2918,7 @@ void IRGeneratorForStatements::setLValue(Expression const& _expression, IRLValue
|
|||||||
solAssert(!m_currentLValue, "");
|
solAssert(!m_currentLValue, "");
|
||||||
|
|
||||||
if (_expression.annotation().willBeWrittenTo)
|
if (_expression.annotation().willBeWrittenTo)
|
||||||
{
|
|
||||||
m_currentLValue.emplace(std::move(_lvalue));
|
m_currentLValue.emplace(std::move(_lvalue));
|
||||||
solAssert(!_lvalue.type.dataStoredIn(DataLocation::CallData), "");
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
// Only define the expression, if it will not be written to.
|
// Only define the expression, if it will not be written to.
|
||||||
define(_expression, readFromLValue(_lvalue));
|
define(_expression, readFromLValue(_lvalue));
|
||||||
|
@ -0,0 +1,10 @@
|
|||||||
|
contract C {
|
||||||
|
function f(uint256[] calldata x, uint256[] calldata y, uint256 i) external returns (uint256) {
|
||||||
|
x = y;
|
||||||
|
return x[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// ====
|
||||||
|
// compileViaYul: also
|
||||||
|
// ----
|
||||||
|
// f(uint256[], uint256[], uint256): 0x60, 0xA0, 1, 1, 0, 2, 1, 2 -> 2
|
Loading…
Reference in New Issue
Block a user