mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			38 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Solidity
		
	
	
	
	
	
			
		
		
	
	
			38 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Solidity
		
	
	
	
	
	
contract C {
 | 
						|
    function f(int a, int b) public pure returns (int x) {
 | 
						|
        x = a % b;
 | 
						|
    }
 | 
						|
    function g(int8 a, int8 b) public pure returns (int8 x) {
 | 
						|
        x = a % b;
 | 
						|
    }
 | 
						|
}
 | 
						|
// ====
 | 
						|
// compileViaYul: also
 | 
						|
// ----
 | 
						|
// f(int256,int256): 10, 3 -> 1
 | 
						|
// f(int256,int256): 10, 2 -> 0
 | 
						|
// f(int256,int256): 11, 2 -> 1
 | 
						|
// f(int256,int256): -10, 3 -> -1
 | 
						|
// f(int256,int256): 10, -3 -> 1
 | 
						|
// f(int256,int256): -10, -3 -> -1
 | 
						|
// f(int256,int256): 2, 2 -> 0
 | 
						|
// f(int256,int256): 1, 0 -> FAILURE, hex"4e487b71", 0x12
 | 
						|
// f(int256,int256): -1, 0 -> FAILURE, hex"4e487b71", 0x12
 | 
						|
// f(int256,int256): 0, 0 -> FAILURE, hex"4e487b71", 0x12
 | 
						|
// f(int256,int256): 0, 1 -> 0
 | 
						|
// f(int256,int256): 0, -1 -> 0
 | 
						|
// g(int8,int8): 10, 3 -> 1
 | 
						|
// g(int8,int8): 10, 2 -> 0
 | 
						|
// g(int8,int8): 11, 2 -> 1
 | 
						|
// g(int8,int8): -10, 3 -> -1
 | 
						|
// g(int8,int8): 10, -3 -> 1
 | 
						|
// g(int8,int8): -10, -3 -> -1
 | 
						|
// g(int8,int8): 2, 2 -> 0
 | 
						|
// g(int8,int8): 1, 0 -> FAILURE, hex"4e487b71", 0x12
 | 
						|
// g(int8,int8): -1, 0 -> FAILURE, hex"4e487b71", 0x12
 | 
						|
// g(int8,int8): 0, 0 -> FAILURE, hex"4e487b71", 0x12
 | 
						|
// g(int8,int8): 0, 1 -> 0
 | 
						|
// g(int8,int8): 0, -1 -> 0
 | 
						|
// g(int8,int8): -128, -128 -> 0
 | 
						|
// g(int8,int8): -128, 127 -> -1
 |