forked from Uniswap/v3-core
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTickBitmapEchidnaTest.sol
47 lines (41 loc) · 1.71 KB
/
TickBitmapEchidnaTest.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
// SPDX-License-Identifier: UNLICENSED
pragma solidity =0.7.6;
import '../libraries/TickBitmap.sol';
contract TickBitmapEchidnaTest {
using TickBitmap for mapping(int16 => uint256);
mapping(int16 => uint256) private bitmap;
// returns whether the given tick is initialized
function isInitialized(int24 tick) private view returns (bool) {
(int24 next, bool initialized) = bitmap.nextInitializedTickWithinOneWord(tick, 1, true);
return next == tick ? initialized : false;
}
function flipTick(int24 tick) external {
bool before = isInitialized(tick);
bitmap.flipTick(tick, 1);
assert(isInitialized(tick) == !before);
}
function checkNextInitializedTickWithinOneWordInvariants(int24 tick, bool lte) external view {
(int24 next, bool initialized) = bitmap.nextInitializedTickWithinOneWord(tick, 1, lte);
if (lte) {
// type(int24).min + 256
require(tick >= -8388352);
assert(next <= tick);
assert(tick - next < 256);
// all the ticks between the input tick and the next tick should be uninitialized
for (int24 i = tick; i > next; i--) {
assert(!isInitialized(i));
}
assert(isInitialized(next) == initialized);
} else {
// type(int24).max - 256
require(tick < 8388351);
assert(next > tick);
assert(next - tick <= 256);
// all the ticks between the input tick and the next tick should be uninitialized
for (int24 i = tick + 1; i < next; i++) {
assert(!isInitialized(i));
}
assert(isInitialized(next) == initialized);
}
}
}