mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			23 lines
		
	
	
		
			516 B
		
	
	
	
		
			Solidity
		
	
	
	
	
	
			
		
		
	
	
			23 lines
		
	
	
		
			516 B
		
	
	
	
		
			Solidity
		
	
	
	
	
	
| contract C
 | |
| {
 | |
| 	function f(uint x, bool b) public pure {
 | |
| 		require(x < 100);
 | |
| 		while (x < 10) {
 | |
| 			if (b)
 | |
| 				x = x + 1;
 | |
| 			else
 | |
| 				x = 0;
 | |
| 		}
 | |
| 		// CHC proves it safe because
 | |
| 		// 1- if it doesn't go in the loop in the first place, x >= 10
 | |
| 		// 2- if it goes in the loop and b == true, x increases until >= 10
 | |
| 		// 3- if it goes in the loop and b == false, it's an infinite loop, therefore
 | |
| 		//    the assertion and the error are unreachable.
 | |
| 		assert(x > 0);
 | |
| 	}
 | |
| }
 | |
| // ====
 | |
| // SMTEngine: all
 | |
| // SMTSolvers: z3
 | |
| // ----
 |