mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			58 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Solidity
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Solidity
		
	
	
	
	
	
| contract C {
 | |
|     uint256[1024] s;
 | |
|     function g() public returns (uint256) {
 | |
|         // try to prevent inlining
 | |
|         return f() + f() + f() + f() + f();
 | |
|     }
 | |
|     function f() public returns (uint256 x) {
 | |
|         x = 42;
 | |
|         uint256 x0 = s[0];
 | |
|         uint256 x1 = s[1];
 | |
|         uint256 x2 = s[2];
 | |
|         uint256 x3 = s[3];
 | |
|         uint256 x4 = s[4];
 | |
|         uint256 x5 = s[5];
 | |
|         uint256 x6 = s[6];
 | |
|         uint256 x7 = s[7];
 | |
|         uint256 x8 = s[8];
 | |
|         uint256 x9 = s[9];
 | |
|         uint256 x10 = s[10];
 | |
|         uint256 x11 = s[11];
 | |
|         uint256 x12 = s[12];
 | |
|         uint256 x13 = s[13];
 | |
|         uint256 x14 = s[14];
 | |
|         uint256 x15 = s[15];
 | |
|         uint256 x16 = s[16];
 | |
|         uint256 x17 = s[17];
 | |
|         uint256 x18 = s[18];
 | |
|         s[1000] = x0 + 2;
 | |
|         s[118] = x18;
 | |
|         s[117] = x17;
 | |
|         s[116] = x16;
 | |
|         s[115] = x15;
 | |
|         s[114] = x14;
 | |
|         s[113] = x13;
 | |
|         s[112] = x12;
 | |
|         s[111] = x11;
 | |
|         s[110] = x10;
 | |
|         s[109] = x9;
 | |
|         s[108] = x8;
 | |
|         s[107] = x7;
 | |
|         s[106] = x6;
 | |
|         s[105] = x5;
 | |
|         s[104] = x4;
 | |
|         s[103] = x3;
 | |
|         s[102] = x2;
 | |
|         s[101] = x1;
 | |
|         s[100] = x0;
 | |
|     }
 | |
|     function test() public view returns(uint256) {
 | |
|         return s[1000];
 | |
|     }
 | |
| }
 | |
| // ====
 | |
| // compileViaYul: true
 | |
| // ----
 | |
| // f() -> 0x2a
 | |
| // test() -> 2
 |