mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
110 lines
3.7 KiB
Plaintext
110 lines
3.7 KiB
Plaintext
|
|
||
|
======= viair_subobjects/input.sol:C =======
|
||
|
Binary:
|
||
|
60806040523415600f5760006000fd5b600a80601e600039806000f350fe608060405260006000fd
|
||
|
Binary of the runtime part:
|
||
|
|
||
|
Optimized IR:
|
||
|
/*******************************************************
|
||
|
* WARNING *
|
||
|
* Solidity to Yul compilation is still EXPERIMENTAL *
|
||
|
* It can result in LOSS OF FUNDS or worse *
|
||
|
* !USE AT YOUR OWN RISK! *
|
||
|
*******************************************************/
|
||
|
|
||
|
object "C_2" {
|
||
|
code {
|
||
|
{
|
||
|
mstore(64, 128)
|
||
|
if callvalue() { revert(0, 0) }
|
||
|
let _1 := datasize("C_2_deployed")
|
||
|
codecopy(0, dataoffset("C_2_deployed"), _1)
|
||
|
return(0, _1)
|
||
|
}
|
||
|
}
|
||
|
object "C_2_deployed" {
|
||
|
code {
|
||
|
{
|
||
|
mstore(64, 128)
|
||
|
revert(0, 0)
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
======= viair_subobjects/input.sol:D =======
|
||
|
Binary:
|
||
|
608060405234156100105760006000fd5b60d380610020600039806000f350fe6080604052600436101515610074576000803560e01c6326121ff0141561007257341561002a578081fd5b806003193601121561003a578081fd5b6028806080016080811067ffffffffffffffff8211171561005757fe5b50806100ab60803980608083f05050806100708261007e565bf35b505b60006000fd6100a9565b6000604051905081810181811067ffffffffffffffff8211171561009e57fe5b80604052505b919050565bfe60806040523415600f5760006000fd5b600a80601e600039806000f350fe608060405260006000fd
|
||
|
Binary of the runtime part:
|
||
|
|
||
|
Optimized IR:
|
||
|
/*******************************************************
|
||
|
* WARNING *
|
||
|
* Solidity to Yul compilation is still EXPERIMENTAL *
|
||
|
* It can result in LOSS OF FUNDS or worse *
|
||
|
* !USE AT YOUR OWN RISK! *
|
||
|
*******************************************************/
|
||
|
|
||
|
object "D_13" {
|
||
|
code {
|
||
|
{
|
||
|
mstore(64, 128)
|
||
|
if callvalue() { revert(0, 0) }
|
||
|
let _1 := datasize("D_13_deployed")
|
||
|
codecopy(0, dataoffset("D_13_deployed"), _1)
|
||
|
return(0, _1)
|
||
|
}
|
||
|
}
|
||
|
object "D_13_deployed" {
|
||
|
code {
|
||
|
{
|
||
|
mstore(64, 128)
|
||
|
if iszero(lt(calldatasize(), 4))
|
||
|
{
|
||
|
let _1 := 0
|
||
|
if eq(0x26121ff0, shr(224, calldataload(_1)))
|
||
|
{
|
||
|
if callvalue() { revert(_1, _1) }
|
||
|
if slt(add(calldatasize(), not(3)), _1) { revert(_1, _1) }
|
||
|
let _2 := datasize("C_2")
|
||
|
let _3 := add(128, _2)
|
||
|
if or(gt(_3, 0xffffffffffffffff), lt(_3, 128)) { invalid() }
|
||
|
datacopy(128, dataoffset("C_2"), _2)
|
||
|
pop(create(_1, 128, _2))
|
||
|
return(allocateMemory(_1), _1)
|
||
|
}
|
||
|
}
|
||
|
revert(0, 0)
|
||
|
}
|
||
|
function allocateMemory(size) -> memPtr
|
||
|
{
|
||
|
memPtr := mload(64)
|
||
|
let newFreePtr := add(memPtr, size)
|
||
|
if or(gt(newFreePtr, 0xffffffffffffffff), lt(newFreePtr, memPtr)) { invalid() }
|
||
|
mstore(64, newFreePtr)
|
||
|
}
|
||
|
}
|
||
|
object "C_2" {
|
||
|
code {
|
||
|
{
|
||
|
mstore(64, 128)
|
||
|
if callvalue() { revert(0, 0) }
|
||
|
let _1 := datasize("C_2_deployed")
|
||
|
codecopy(0, dataoffset("C_2_deployed"), _1)
|
||
|
return(0, _1)
|
||
|
}
|
||
|
}
|
||
|
object "C_2_deployed" {
|
||
|
code {
|
||
|
{
|
||
|
mstore(64, 128)
|
||
|
revert(0, 0)
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|