mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
109 lines
3.0 KiB
Plaintext
109 lines
3.0 KiB
Plaintext
|
IR:
|
||
|
/*******************************************************
|
||
|
* WARNING *
|
||
|
* Solidity to Yul compilation is still EXPERIMENTAL *
|
||
|
* It can result in LOSS OF FUNDS or worse *
|
||
|
* !USE AT YOUR OWN RISK! *
|
||
|
*******************************************************/
|
||
|
|
||
|
|
||
|
object "test_11" {
|
||
|
code {
|
||
|
mstore(64, 128)
|
||
|
if callvalue() { revert(0, 0) }
|
||
|
|
||
|
constructor_test_11()
|
||
|
|
||
|
codecopy(0, dataoffset("test_11_deployed"), datasize("test_11_deployed"))
|
||
|
|
||
|
return(0, datasize("test_11_deployed"))
|
||
|
|
||
|
function constructor_test_11() {
|
||
|
|
||
|
}
|
||
|
|
||
|
}
|
||
|
object "test_11_deployed" {
|
||
|
code {
|
||
|
mstore(64, 128)
|
||
|
|
||
|
if iszero(lt(calldatasize(), 4))
|
||
|
{
|
||
|
let selector := shift_right_224_unsigned(calldataload(0))
|
||
|
switch selector
|
||
|
|
||
|
case 0x26121ff0
|
||
|
{
|
||
|
// f()
|
||
|
if callvalue() { revert(0, 0) }
|
||
|
abi_decode_tuple_(4, calldatasize())
|
||
|
let ret_0 := fun_f_10()
|
||
|
let memPos := allocateMemory(0)
|
||
|
let memEnd := abi_encode_tuple_t_bool__to_t_bool__fromStack(memPos , ret_0)
|
||
|
return(memPos, sub(memEnd, memPos))
|
||
|
}
|
||
|
|
||
|
default {}
|
||
|
}
|
||
|
if iszero(calldatasize()) { }
|
||
|
revert(0, 0)
|
||
|
|
||
|
function abi_decode_tuple_(headStart, dataEnd) {
|
||
|
if slt(sub(dataEnd, headStart), 0) { revert(0, 0) }
|
||
|
|
||
|
}
|
||
|
|
||
|
function abi_encode_t_bool_to_t_bool_fromStack(value, pos) {
|
||
|
mstore(pos, cleanup_t_bool(value))
|
||
|
}
|
||
|
|
||
|
function abi_encode_tuple_t_bool__to_t_bool__fromStack(headStart , value0) -> tail {
|
||
|
tail := add(headStart, 32)
|
||
|
|
||
|
abi_encode_t_bool_to_t_bool_fromStack(value0, add(headStart, 0))
|
||
|
|
||
|
}
|
||
|
|
||
|
function allocateMemory(size) -> memPtr {
|
||
|
memPtr := mload(64)
|
||
|
let newFreePtr := add(memPtr, size)
|
||
|
// protect against overflow
|
||
|
if or(gt(newFreePtr, 0xffffffffffffffff), lt(newFreePtr, memPtr)) { panic_error() }
|
||
|
mstore(64, newFreePtr)
|
||
|
}
|
||
|
|
||
|
function cleanup_t_bool(value) -> cleaned {
|
||
|
cleaned := iszero(iszero(value))
|
||
|
}
|
||
|
|
||
|
function fun_f_10() -> vloc__5 {
|
||
|
let zero_value_for_type_t_bool_1 := zero_value_for_split_t_bool()
|
||
|
vloc__5 := zero_value_for_type_t_bool_1
|
||
|
|
||
|
let expr_7 := 0x01
|
||
|
vloc__5 := expr_7
|
||
|
leave
|
||
|
|
||
|
}
|
||
|
|
||
|
function panic_error() {
|
||
|
invalid()
|
||
|
}
|
||
|
|
||
|
function shift_right_224_unsigned(value) -> newValue {
|
||
|
newValue :=
|
||
|
|
||
|
shr(224, value)
|
||
|
|
||
|
}
|
||
|
|
||
|
function zero_value_for_split_t_bool() -> ret {
|
||
|
ret := 0
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
}
|