From 98fe0e7056e6697396249531785d3899f94d79be Mon Sep 17 00:00:00 2001 From: David Robillard Date: Sat, 10 Jun 2006 01:52:02 +0000 Subject: More juggling git-svn-id: http://svn.drobilla.net/lad/grauph@15 a436a847-0d15-0410-975c-d299462d15a1 --- src/engine/Tree.h | 155 ------------------------------------------------------ 1 file changed, 155 deletions(-) delete mode 100644 src/engine/Tree.h (limited to 'src/engine/Tree.h') diff --git a/src/engine/Tree.h b/src/engine/Tree.h deleted file mode 100644 index 033d48b7..00000000 --- a/src/engine/Tree.h +++ /dev/null @@ -1,155 +0,0 @@ -/* This file is part of Om. Copyright (C) 2006 Dave Robillard. - * - * Om 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. - * - * Om 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., - * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA - */ - -#ifndef NODETREE_H -#define NODETREE_H - -#include -#include -#include "MaidObject.h" -using std::string; - -template class Tree; - - -/** A node in a Tree. - */ -template -class TreeNode : public MaidObject -{ -public: - TreeNode(const string& key) - : m_parent(NULL), m_left_child(NULL), m_right_child(NULL), - m_key(key), m_node(NULL) {} - - TreeNode(const string& key, T n) - : m_parent(NULL), m_left_child(NULL), m_right_child(NULL), - m_key(key), m_node(n) {} - - ~TreeNode() { - assert(m_parent == NULL || m_parent->left_child() != this); - assert(m_parent == NULL || m_parent->right_child() != this); - assert(m_left_child == NULL || m_left_child->parent() != this); - assert(m_right_child == NULL || m_right_child->parent() != this); - m_parent = m_left_child = m_right_child = NULL; - } - - string key() const { return m_key; } - void key(const string& key) { m_key = key; } - TreeNode* parent() const { return m_parent; } - void parent(TreeNode* n) { m_parent = n; } - TreeNode* left_child() const { return m_left_child; } - void left_child(TreeNode* n) { m_left_child = n; } - TreeNode* right_child() const { return m_right_child; } - void right_child(TreeNode* n) { m_right_child = n; } - - bool is_leaf() { return (m_left_child == NULL && m_right_child == NULL); } - bool is_left_child() { return (m_parent != NULL && m_parent->left_child() == this); } - bool is_right_child() { return (m_parent != NULL && m_parent->right_child() == this); } - - T node() { return m_node; } - - friend class Tree; - -protected: - // Prevent copies (undefined) - TreeNode(const TreeNode&); - TreeNode& operator=(const TreeNode&); - - TreeNode* m_parent; - TreeNode* m_left_child; - TreeNode* m_right_child; - string m_key; - T m_node; -}; - - -/** The tree all objects are stored in. - * - * Textbook naive (unbalanced) Binary Search Tree. Slightly different - * from a usual BST implementation in that the "Node" classes (TreeNode) are - * exposed to the user. This is so QueuedEvent's can create the TreeNode in - * another thread, and the realtime jack thread can insert them (without having - * to allocating a TreeNode which is a no-no). - * - * It's also a more annoying implementation because there's no leaf type (since - * a leaf object would have to be deleted on insert). - * - * Tree::iterator is not realtime safe, but the insert/remove/find methods - * of Tree do not use them. - */ -template -class Tree -{ -public: - Tree() : m_root(0), m_size(0) {} - ~Tree(); - - void insert(TreeNode* const n); - TreeNode* remove(const string& key); - T find(const string& key) const; - TreeNode* find_treenode(const string& key) const; - - size_t size() const { return m_size; } - - /** NON realtime safe iterator for a Tree. */ - class iterator - { - public: - iterator(const Tree* tree, size_t size); - ~iterator(); - - T operator*() const; - iterator& operator++(); - bool operator!=(const iterator& iter) const; - - friend class Tree; - - iterator(const iterator& copy); - iterator& operator=(const iterator& copy); - - private: - int m_depth; - size_t m_size; - TreeNode** m_stack; - const Tree* m_tree; - }; - - iterator begin() const; - iterator end() const; - -private: - // Prevent copies (undefined) - Tree(const Tree&); - Tree& operator=(const Tree&); - - void m_set_all_traversed_recursive(TreeNode* root, bool b); - - TreeNode* m_find_smallest(TreeNode* root); - TreeNode* m_find_largest(TreeNode* root); - - TreeNode* m_root; - size_t m_size; -}; - - -/* This needs to be done so the templates are defined and can get instantiated - * automatically by the compilter. - */ -//#include "TreeImplementation.h" - - -#endif // NODETREE_H -- cgit v1.2.1