summaryrefslogtreecommitdiffstats
path: root/raul/PathTable.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/PathTable.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/PathTable.hpp')
-rw-r--r--raul/PathTable.hpp45
1 files changed, 45 insertions, 0 deletions
diff --git a/raul/PathTable.hpp b/raul/PathTable.hpp
new file mode 100644
index 0000000..6754b14
--- /dev/null
+++ b/raul/PathTable.hpp
@@ -0,0 +1,45 @@
+/* This file is part of Raul.
+ * Copyright (C) 2007 Dave Robillard <http://drobilla.net>
+ *
+ * Raul is free software; you can redistribute it and/or modify it under the
+ * terms of the GNU General Public License as published by the Free Software
+ * Foundation; either version 2 of the License, or (at your option) any later
+ * version.
+ *
+ * Raul 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 General Public License for details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#ifndef RAUL_PATH_TABLE_HPP
+#define RAUL_PATH_TABLE_HPP
+
+#include <raul/Path.hpp>
+#include <raul/Table.hpp>
+
+namespace Raul {
+
+template <typename T>
+class PathTable : public Table<Path, T> {
+public:
+ /** Find all descendants of a Path key in the Table.
+ * It is guaranteed that (parent, parent+1, parent+2, ..., ret-1) are all
+ * descendants of parent. The return value is never a descendent of
+ * parent, and may be end().
+ */
+ typename Table<Path, T>::const_iterator find_descendants_end(
+ typename Table<Path, T>::const_iterator parent) const
+ {
+ return find_range_end(parent, &Path::descendant_comparator);
+ }
+};
+
+
+} // namespace Raul
+
+#endif // RAUL_PATH_TABLE_HPP
+