mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			30 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Solidity
		
	
	
	
	
	
			
		
		
	
	
			30 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Solidity
		
	
	
	
	
	
| contract C {
 | |
| 	function f(uint n, uint m) public {
 | |
| 		function() internal returns (uint)[] memory arr = new function() internal returns (uint)[](n);
 | |
| 		arr[m]();
 | |
| 	}
 | |
| 	function f2(uint n, uint m, uint a, uint b) public {
 | |
| 		function() internal returns (uint)[][] memory arr = new function() internal returns (uint)[][](n);
 | |
| 		for (uint i = 0; i < n; ++i)
 | |
| 			arr[i] = new function() internal returns (uint)[](m);
 | |
| 		arr[a][b]();
 | |
| 	}
 | |
| 	function g(uint n, uint m) public {
 | |
| 		function() external returns (uint)[] memory arr = new function() external returns (uint)[](n);
 | |
| 		arr[m]();
 | |
| 	}
 | |
| 	function g2(uint n, uint m, uint a, uint b) public {
 | |
| 		function() external returns (uint)[][] memory arr = new function() external returns (uint)[][](n);
 | |
| 		for (uint i = 0; i < n; ++i)
 | |
| 			arr[i] = new function() external returns (uint)[](m);
 | |
| 		arr[a][b]();
 | |
| 	}
 | |
| }
 | |
| // ====
 | |
| // compileViaYul: also
 | |
| // ----
 | |
| // f(uint256,uint256): 1823621, 12323 -> FAILURE
 | |
| // f2(uint256,uint256,uint256,uint256): 18723921, 1823621, 123, 12323 -> FAILURE
 | |
| // g(uint256,uint256): 1823621, 12323 -> FAILURE
 | |
| // g2(uint256,uint256,uint256,uint256): 18723921, 1823621, 123, 12323 -> FAILURE
 |