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
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);
|
|
}
|
|
}
|
|
// ====
|
|
// SMTEngine: all
|
|
// ----
|
|
// Warning 6368: (468-472): CHC: Out of bounds access happens here.\nCounterexample:\n\nx = [18, 52, 0]\n\nTransaction trace:\nC.constructor()\nC.h()
|
|
// Warning 6368: (490-494): CHC: Out of bounds access happens here.\nCounterexample:\n\nx = [18, 52, 0]\n\nTransaction trace:\nC.constructor()\nC.h()
|