Optimized IR: /// @use-src 0:"name_simplifier/input.sol" object "C_59" { code { { /// @src 0:346:625 "contract C {..." let _1 := memoryguard(0x80) mstore(64, _1) if callvalue() { revert(0, 0) } let _2 := datasize("C_59_deployed") codecopy(_1, dataoffset("C_59_deployed"), _2) return(_1, _2) } } /// @use-src 0:"name_simplifier/input.sol" object "C_59_deployed" { code { { /// @src 0:346:625 "contract C {..." let _1 := memoryguard(0x80) let _2 := 4 if iszero(lt(calldatasize(), _2)) { let _3 := 0 if eq(0xf8eddcc6, shr(224, calldataload(_3))) { if callvalue() { revert(_3, _3) } let _4 := 32 if slt(add(calldatasize(), not(3)), _4) { revert(_3, _3) } let offset := calldataload(_2) let _5 := 0xffffffffffffffff if gt(offset, _5) { revert(_3, _3) } if iszero(slt(add(offset, 35), calldatasize())) { revert(_3, _3) } let _6 := calldataload(add(_2, offset)) let _7 := 36 if gt(_6, _5) { mstore(_3, shl(224, 0x4e487b71)) mstore(_2, 0x41) revert(_3, _7) } let _8 := shl(5, _6) let _9 := not(31) let newFreePtr := add(_1, and(add(_8, 63), _9)) if or(gt(newFreePtr, _5), lt(newFreePtr, _1)) { mstore(_3, shl(224, 0x4e487b71)) mstore(_2, 0x41) revert(_3, _7) } let _10 := 64 mstore(_10, newFreePtr) let dst := _1 mstore(_1, _6) dst := add(_1, _4) let dst_1 := dst let srcEnd := add(add(offset, _8), _7) if gt(srcEnd, calldatasize()) { revert(_3, _3) } let src := add(offset, _7) for { } lt(src, srcEnd) { src := add(src, _4) } { if slt(sub(calldatasize(), src), _4) { revert(_3, _3) } let memPtr := mload(_10) let newFreePtr_1 := add(memPtr, _4) if or(gt(newFreePtr_1, _5), lt(newFreePtr_1, memPtr)) { mstore(_3, shl(224, 0x4e487b71)) mstore(_2, 0x41) revert(_3, _7) } mstore(_10, newFreePtr_1) mstore(memPtr, calldataload(src)) mstore(dst, memPtr) dst := add(dst, _4) } if iszero(mload(_1)) { mstore(_3, shl(224, 0x4e487b71)) mstore(_2, 0x32) revert(_3, _7) } sstore(_3, mload(/** @src 0:469:474 "_s[0]" */ mload(dst_1))) /// @src 0:346:625 "contract C {..." if iszero(lt(/** @src 0:492:493 "1" */ 0x01, /** @src 0:346:625 "contract C {..." */ mload(_1))) { mstore(_3, shl(224, 0x4e487b71)) mstore(_2, 0x32) revert(_3, _7) } let _11 := mload(/** @src 0:489:494 "_s[1]" */ mload(/** @src 0:346:625 "contract C {..." */ add(_1, _10))) sstore(0x02, _11) let memPtr_1 := mload(_10) let newFreePtr_2 := add(memPtr_1, 160) if or(gt(newFreePtr_2, _5), lt(newFreePtr_2, memPtr_1)) { mstore(_3, shl(224, 0x4e487b71)) mstore(_2, 0x41) revert(_3, _7) } mstore(_10, newFreePtr_2) mstore(memPtr_1, 100) mstore(add(memPtr_1, _4), "longstringlongstringlongstringlo") mstore(add(memPtr_1, _10), "ngstringlongstringlongstringlong") let _12 := 96 mstore(add(memPtr_1, _12), "stringlongstringlongstringlongst") mstore(add(memPtr_1, 128), "ring") let memPos := mload(_10) mstore(memPos, _11) mstore(add(memPos, _4), _10) let length := mload(memPtr_1) mstore(add(memPos, _10), length) let i := _3 for { } lt(i, length) { i := add(i, _4) } { mstore(add(add(memPos, i), _12), mload(add(add(memPtr_1, i), _4))) } mstore(add(add(memPos, length), _12), _3) return(memPos, add(sub(add(memPos, and(add(length, 31), _9)), memPos), _12)) } } revert(0, 0) } } data ".metadata" hex"" } }