mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			39 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Solidity
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Solidity
		
	
	
	
	
	
| pragma experimental SMTChecker;
 | |
| 
 | |
| contract C {
 | |
| 	function f() public pure {
 | |
| 		bytes memory x = new bytes(0);
 | |
| 		assert(x.length == 0);
 | |
| 	}
 | |
| 	function g() public pure {
 | |
| 		bytes memory x = new bytes(3);
 | |
| 		assert(x.length == 3);
 | |
| 		assert(x[0] == 0);
 | |
| 		assert(x[1] == 0);
 | |
| 		assert(x[2] == 0);
 | |
| 	}
 | |
| 	function h() public pure {
 | |
| 		bytes memory x = new bytes(3);
 | |
| 		assert(x.length == 3);
 | |
| 		x[0] = 0x12;
 | |
| 		x[1] = 0x34;
 | |
| 		assert(x[0] == 0x12);
 | |
| 		assert(x[1] == 0x34);
 | |
| 		// This should be an out-of-bounds assertion.
 | |
| 		x[5] = 0xff;
 | |
| 		assert(x[5] == 0xff);
 | |
| 	}
 | |
| 	function h(uint size) public pure {
 | |
| 		bytes memory x = new bytes(size);
 | |
| 		assert(x.length == size);
 | |
| 		require(size >= 2);
 | |
| 		x[0] = 0x12;
 | |
| 		x[1] = 0x34;
 | |
| 		assert(x[0] == 0x12);
 | |
| 		assert(x[1] == 0x34);
 | |
| 	}
 | |
| }
 | |
| // ----
 | |
| // Warning 6368: (501-505): CHC: Out of bounds access happens here.\nCounterexample:\n\nx = [18, 52, 0]\n\nTransaction trace:\nC.constructor()\nC.h()
 | |
| // Warning 6368: (523-527): CHC: Out of bounds access happens here.\nCounterexample:\n\nx = [18, 52, 0]\n\nTransaction trace:\nC.constructor()\nC.h()
 |