mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			26 lines
		
	
	
		
			807 B
		
	
	
	
		
			Solidity
		
	
	
	
	
	
			
		
		
	
	
			26 lines
		
	
	
		
			807 B
		
	
	
	
		
			Solidity
		
	
	
	
	
	
| pragma abicoder v2;
 | |
| 
 | |
| contract C {
 | |
| 	function f(uint[3][] calldata a) public {
 | |
| 		abi.encode(a);
 | |
| 	}
 | |
| 	function f(uint[][3] calldata a) public {
 | |
| 		abi.encode(a);
 | |
| 	}
 | |
| 	function f(uint[2][2] calldata a) public {
 | |
| 		abi.encode(a);
 | |
| 	}
 | |
| }
 | |
| // ----
 | |
| // f(uint256[3][]): 0x20, 1, 0x01 -> FAILURE
 | |
| // f(uint256[3][]): 0x20, 1, 0x01, 0x02 -> FAILURE
 | |
| // f(uint256[3][]): 0x20, 1, 0x01, 0x02, 0x03 ->
 | |
| // f(uint256[][3]): 0x20, 0x60, 0x60, 0x60, 3, 0x01 -> FAILURE
 | |
| // f(uint256[][3]): 0x20, 0x60, 0x60, 0x60, 3, 0x01, 0x02 -> FAILURE
 | |
| // f(uint256[][3]): 0x20, 0x60, 0x60, 0x60, 3, 0x01, 0x02, 0x03 ->
 | |
| // f(uint256[2][2]): 0x01 -> FAILURE
 | |
| // f(uint256[2][2]): 0x01, 0x02 -> FAILURE
 | |
| // f(uint256[2][2]): 0x01, 0x02, 0x03 -> FAILURE
 | |
| // f(uint256[2][2]): 0x01, 0x02, 0x03, 0x04 ->
 | |
| // f(uint256[2][2]): 0x01, 0x02, 0x03, 0x04, 0x05 ->
 |