-
-
Notifications
You must be signed in to change notification settings - Fork 113
/
Copy pathstorage_positions.cpp
47 lines (36 loc) · 982 Bytes
/
storage_positions.cpp
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
#include "storage_positions.h"
void StoragePositions::add(Position p) {
++positions[p];
}
void StoragePositions::remove(Position p) {
auto res = --positions[p];
CHECK(res >= 0);
if (res == 0)
positions.erase(p);
}
bool StoragePositions::empty() const {
return positions.empty();
}
bool StoragePositions::contains(Position p) const {
return positions.count(p);
}
vector<Position> StoragePositions::asVector() const {
return getKeys(positions);
}
SERIALIZE_DEF(StoragePositions, positions)
const Position& StoragePositions::Iter::operator* () const {
return iter->first;
}
bool StoragePositions::Iter::operator != (const Iter& other) const {
return iter != other.iter;
}
const StoragePositions::Iter& StoragePositions::Iter::operator++ () {
++iter;
return *this;
}
StoragePositions::Iter StoragePositions::begin() const {
return Iter{positions.begin()};
}
StoragePositions::Iter StoragePositions::end() const {
return Iter{positions.end()};
}