mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
40 lines
1.4 KiB
Solidity
40 lines
1.4 KiB
Solidity
// This tests skipping the extcodesize check.
|
|
|
|
interface I {
|
|
function a() external pure;
|
|
function b() external;
|
|
function c() external payable;
|
|
function x() external returns (uint);
|
|
function y() external returns (string memory);
|
|
}
|
|
contract C {
|
|
I i = I(address(0xcafecafe));
|
|
constructor() payable {}
|
|
function f(uint c) external returns (uint) {
|
|
if (c == 0) i.a();
|
|
else if (c == 1) i.b();
|
|
else if (c == 2) i.c();
|
|
else if (c == 3) i.c{value: 1}();
|
|
else if (c == 4) i.x();
|
|
else if (c == 5) i.y();
|
|
return 1 + c;
|
|
}
|
|
}
|
|
|
|
// ====
|
|
// EVMVersion: >=byzantium
|
|
// compileViaYul: also
|
|
// revertStrings: debug
|
|
// ----
|
|
// constructor(), 1 ether ->
|
|
// gas irOptimized: 452673
|
|
// gas legacy: 834272
|
|
// gas legacyOptimized: 510004
|
|
// f(uint256): 0 -> FAILURE, hex"08c379a0", 0x20, 37, "Target contract does not contain", " code"
|
|
// f(uint256): 1 -> FAILURE, hex"08c379a0", 0x20, 37, "Target contract does not contain", " code"
|
|
// f(uint256): 2 -> FAILURE, hex"08c379a0", 0x20, 37, "Target contract does not contain", " code"
|
|
// f(uint256): 3 -> FAILURE, hex"08c379a0", 0x20, 37, "Target contract does not contain", " code"
|
|
// f(uint256): 4 -> FAILURE, hex"08c379a0", 0x20, 37, "Target contract does not contain", " code"
|
|
// f(uint256): 5 -> FAILURE, hex"08c379a0", 0x20, 37, "Target contract does not contain", " code"
|
|
// f(uint256): 6 -> 7
|