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: 448383
 | |
| // 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
 |