-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathline.hpp
73 lines (62 loc) · 2.02 KB
/
line.hpp
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
67
68
69
70
71
72
73
// Ixte - a temporal structure editor for musical composition and analysis
// Copyright (C) 2014 Raphael Sousa Santos, http://www.raphaelss.com
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
#ifndef LINE_HPP_IXTE_INCLUDED
#define LINE_HPP_IXTE_INCLUDED
#include <set>
#include <algorithm>
namespace ixte {
class line {
public:
typedef std::set<double>::const_iterator const_iterator;
bool add(double x);
bool remove(double x);
bool empty() const;
bool contains(double x) const;
double largest() const;
const_iterator cbegin() const;
const_iterator cend() const;
const_iterator lower_bound(double x = 0) const;
const_iterator upper_bound(double x) const;
std::pair<const_iterator,const_iterator> range(double min, double max) const;
template <class Iter>
Iter batch_add_mod(Iter begin, Iter end) {
return std::remove_if(begin, end, [this](double x) {
return !this->add(x);
});
}
template <class Iter >
Iter batch_remove_mod(Iter begin, Iter end) {
return std::remove_if(begin, end, [this](double x) {
return !this->remove(x);
});
}
template <class Iter>
void batch_add(Iter begin, Iter end) {
std::for_each(begin, end, [this](double x) {
this->add(x);
});
}
template <class Iter >
void batch_remove(Iter begin, Iter end) {
std::for_each(begin, end, [this](double x) {
this->remove(x);
});
}
private:
std::set<double> _set;
};
}
#endif