summaryrefslogtreecommitdiffstats
path: root/raul/Table.hpp
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2007-07-26 11:29:31 +0000
committerDavid Robillard <d@drobilla.net>2007-07-26 11:29:31 +0000
commit47fb95d6086c2c67086316a25b4c0858783d3c2b (patch)
tree4ac9934f1f38b0b6ed42f41b2bd9d7cdbc90c2f8 /raul/Table.hpp
parent25b9a123b60f769506a829542d05f38b1e95d51b (diff)
downloadraul-47fb95d6086c2c67086316a25b4c0858783d3c2b.tar.gz
raul-47fb95d6086c2c67086316a25b4c0858783d3c2b.tar.bz2
raul-47fb95d6086c2c67086316a25b4c0858783d3c2b.zip
Added PathTable, simple pretty wrapper around Table which provides super fast
"find all descendants". I couldn't deal with the 'one big table' or 'parents own/lookup children' decision, so I came up with this thing instead. It's pretty cool I guess. git-svn-id: http://svn.drobilla.net/lad/raul@635 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'raul/Table.hpp')
-rw-r--r--raul/Table.hpp8
1 files changed, 6 insertions, 2 deletions
diff --git a/raul/Table.hpp b/raul/Table.hpp
index d30b23e..e4d4fa5 100644
--- a/raul/Table.hpp
+++ b/raul/Table.hpp
@@ -75,12 +75,16 @@ public:
void erase(const K& key);
void erase(iterator i);
- void erase(iterator begin, iterator end);
- void erase(size_t begin, size_t end);
+ void erase(iterator start, iterator end);
+ void erase(size_t start, size_t end);
const_iterator find(const K& key) const;
iterator find(const K& key);
+ const_iterator find_range_end(const_iterator left, bool (*comp)(const K&,const K&)) const;
+ const_iterator find_in_range(const K& key, const_iterator start, const_iterator end,
+ bool (*comp)(const K&,const K&)) const;
+
T& operator[](const K& key);
const_iterator begin() const { return const_iterator(*this, 0); }