-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathAddressSet.h
66 lines (52 loc) · 1.56 KB
/
AddressSet.h
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
/* Copyright (c) 2014 Steven Flintham
*
* All rights reserved.
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the 'Software'),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, provided that the above copyright notice(s) and this
* permission notice appear in all copies of the Software and that both the
* above copyright notice(s) and this permission notice appear in supporting
* documentation.
*
* THE SOFTWARE IS PROVIDED 'AS IS'. USE ENTIRELY AT YOUR OWN RISK.
*/
#ifndef ADDRESSSET_H
#define ADDRESSSET_H
#include <set>
#include <stdint.h>
#include <string>
class AddressRange;
class AddressSet
{
private:
// This might not be the perfect representation, but it's simple and clean,
// so let's stick with it unless profiling shows this is a problem.
typedef std::set<uint16_t> Container;
public:
AddressSet()
{
}
void insert(uint16_t address);
void insert(const AddressRange &range);
typedef Container::const_iterator const_iterator;
const_iterator begin() const
{
return set_.begin();
}
const_iterator end() const
{
return set_.end();
}
Container::size_type size() const
{
return set_.size();
}
std::string dump(int indent) const;
private:
std::set<uint16_t> set_;
};
#endif