summaryrefslogtreecommitdiffstats
path: root/src/usr/diag/prdf/common/util/UtilTree.H
diff options
context:
space:
mode:
Diffstat (limited to 'src/usr/diag/prdf/common/util/UtilTree.H')
-rwxr-xr-xsrc/usr/diag/prdf/common/util/UtilTree.H181
1 files changed, 181 insertions, 0 deletions
diff --git a/src/usr/diag/prdf/common/util/UtilTree.H b/src/usr/diag/prdf/common/util/UtilTree.H
new file mode 100755
index 000000000..b8c18e67e
--- /dev/null
+++ b/src/usr/diag/prdf/common/util/UtilTree.H
@@ -0,0 +1,181 @@
+/* IBM_PROLOG_BEGIN_TAG */
+/* This is an automatically generated prolog. */
+/* */
+/* $Source: src/usr/diag/prdf/common/util/UtilTree.H $ */
+/* */
+/* IBM CONFIDENTIAL */
+/* */
+/* COPYRIGHT International Business Machines Corp. 2004,2012 */
+/* */
+/* p1 */
+/* */
+/* Object Code Only (OCO) source materials */
+/* Licensed Internal Code Source Materials */
+/* IBM HostBoot Licensed Internal Code */
+/* */
+/* The source code for this program is not published or otherwise */
+/* divested of its trade secrets, irrespective of what has been */
+/* deposited with the U.S. Copyright Office. */
+/* */
+/* Origin: 30 */
+/* */
+/* IBM_PROLOG_END_TAG */
+
+#ifndef __UTIL_UTILTREE_H
+#define __UTIL_UTILTREE_H
+
+#include <stdint.h>
+#include <stddef.h>
+
+#include <functional>
+
+#include <iostream>
+
+namespace UtilTreeSTD
+{
+ template <class _A, class _B>
+ class unary_operator : public std::unary_function<_A,_B>
+ {
+ public:
+ virtual _B operator() (_A) const { return _B(); };
+ };
+
+ template <class _A, class _B, class _C>
+ class binary_operator : public std::binary_function<_A,_B,_C>
+ {
+ public:
+ virtual _C operator() (_A,_B) const { return _C(); };
+ };
+};
+
+class UtilTree
+{
+ public:
+ UtilTree();
+ UtilTree(const UtilTree &);
+ virtual ~UtilTree();
+
+ void insert(void *);
+ void remove(void *);
+ void * find(void *) const;
+ void * peek() const;
+ void empty();
+
+ // temp...
+ void printTree();
+
+ typedef UtilTreeSTD::binary_operator<void *, void *, int>
+ comparator;
+ typedef UtilTreeSTD::unary_operator<void *, void>
+ cleanup;
+ typedef UtilTreeSTD::unary_operator<void *, void *>
+ copier;
+
+ void setComparator(comparator * i) { comp = i; };
+ void setCleanup(cleanup * i) { clean = i; };
+ void setCopier(copier * i) { copy = i; };
+
+ protected:
+ class defaultComparator : public comparator
+ {
+ public:
+ virtual int operator()(void * _a, void * _b) const
+ { return (_a < _b ? -1 : (_a == _b ? 0 : 1)); };
+ };
+
+ class defaultCleanup : public cleanup
+ {
+ public:
+ virtual void operator()(void * _a) const { return; };
+ };
+
+ class defaultCopier : public copier
+ {
+ public:
+ virtual void * operator()(void * _a) const { return _a; };
+ };
+
+ class Node;
+ class Node
+ {
+ public:
+ Node * left;
+ Node * right;
+ Node * parent;
+ bool color; // false = black, true = red.
+ static const bool BLACK = false;
+ static const bool RED = true;
+ void * value;
+
+ // Null pointers, set to red.
+ Node(void * v) :
+ left(NULL), right(NULL), parent(NULL), color(true),
+ value(v) {};
+ };
+
+ Node * root;
+ comparator * comp;
+ cleanup * clean;
+ copier * copy;
+
+ private:
+ static defaultComparator defComparator;
+ static defaultCleanup defCleanup;
+ static defaultCopier defCopy;
+
+ void cleanTree(Node *);
+ Node * find(void *, Node *) const;
+ void insert(void *, Node *&);
+ void balance_i(Node *);
+
+ void copyNode(Node *, Node * const, Node *);
+
+ void printTree(int d, Node *t)
+ {
+ if (NULL == t) return;
+ printTree(d+1, t->left);
+ for (int i = 0; i < d; i++)
+ std::cout << "\t";
+ std::cout << (t->color ? "R" : "B") << *(int *)t->value << std::endl;
+ printTree(d+1, t->right);
+ };
+
+ public:
+ class iterator
+ {
+ public:
+ iterator() : _cur(NULL), _tree(NULL) {};
+ iterator(const UtilTree * const t)
+ : _cur(NULL), _tree(t) {};
+ iterator(Node * i, const UtilTree * const t)
+ : _cur(i), _tree(t) {};
+ iterator & operator++();
+ iterator & operator--();
+ void * operator*() { return _cur->value; };
+
+ bool operator==(const iterator& i) const
+ { return _cur == i._cur; };
+ bool operator!=(const iterator& i) const
+ { return _cur != i._cur; };
+
+ iterator & operator=(const iterator& i)
+ { _cur = i._cur; _tree = i._tree; return *this;};
+
+ private:
+ Node * _cur;
+ const UtilTree * _tree;
+ };
+
+ iterator end() const { return iterator(this); };
+ iterator begin() const;
+};
+
+#endif
+
+// Change Log *********************************************************
+//
+// Flag Reason Vers Date Coder Description
+// ---- -------- ---- -------- -------- -------------------------------
+// F494911 f310 03/04/05 iawillia Initial File Creation
+//
+// End Change Log *****************************************************
OpenPOWER on IntegriCloud