Definition at line 59 of file uniconfroot.h.
Public Types | |
typedef WvCallback < void, const UniWatchInfoTree *, void * > | Visitor |
typedef WvCallback < bool, const UniWatchInfoTree *, const UniWatchInfoTree *, void * > | Comparator |
Public Member Functions | |
UniWatchInfoTree (UniWatchInfoTree *parent, const UniConfKey &key=UniConfKey::EMPTY) | |
bool | isessential () |
Returns true if the node should not be pruned. | |
UniWatchInfoTree * | parent () const |
Returns a pointer to the parent node, or NULL if there is none. | |
void | setparent (UniWatchInfoTree *parent) |
Reparents this node. | |
UniWatchInfoTree * | root () const |
Returns a pointer to the root node of the tree. | |
UniConfKey | fullkey (const UniWatchInfoTree *ancestor=NULL) const |
Returns full path of this node relative to an ancestor. | |
UniWatchInfoTree * | find (const UniConfKey &key) const |
Finds the sub-node with the specified key. | |
UniWatchInfoTree * | findchild (const UniConfKey &key) const |
Finds the direct child node with the specified key. | |
void | remove (const UniConfKey &key) |
Removes the node for the specified key from the tree and deletes it along with any of its children. | |
void | zap () |
Removes and deletes all children of this node. | |
void | visit (const Visitor &visitor, void *userdata, bool preorder=true, bool postorder=false) const |
Performs a traversal on this tree using the specified visitor function and traversal type(s). | |
bool | compare (const UniWatchInfoTree *other, const Comparator &comparator, void *userdata) |
Compares this tree with another using the specified comparator function. | |
const UniConfKey & | key () const |
Returns the key field. | |
bool | haschildren () const |
Returns true if the node has children. | |
Public Attributes | |
UniWatchInfoList | watches |
Protected Types | |
typedef WvScatterHash < UniHashTreeBase, UniConfKey, Accessor > | Container |
typedef UniHashTreeBaseVisitor | BaseVisitor |
typedef UniHashTreeBaseComparator | BaseComparator |
Protected Member Functions | |
void | _setparent (UniHashTreeBase *parent) |
UniHashTreeBase * | _root () const |
UniConfKey | _fullkey (const UniHashTreeBase *ancestor=NULL) const |
UniHashTreeBase * | _find (const UniConfKey &key) const |
UniHashTreeBase * | _findchild (const UniConfKey &key) const |
Static Protected Member Functions | |
static bool | _recursivecompare (const UniHashTreeBase *a, const UniHashTreeBase *b, const UniHashTreeBaseComparator &comparator, void *userdata) |
static void | _recursive_unsorted_visit (const UniHashTreeBase *a, const UniHashTreeBaseVisitor &visitor, void *userdata, bool preorder, bool postorder) |
Protected Attributes | |
UniConfKey | xkey |
UniHashTreeBase * | xparent |
Container * | xchildren |
Friends | |
class | Iter |
bool UniWatchInfoTree::isessential | ( | ) | [inline] |
Returns true if the node should not be pruned.
Definition at line 69 of file uniconfroot.h.
References UniHashTreeBase::haschildren(), and watches.
UniWatchInfoTree * UniConfTree< UniWatchInfoTree , UniHashTreeBase >::parent | ( | ) | const [inline, inherited] |
Returns a pointer to the parent node, or NULL if there is none.
Definition at line 41 of file uniconftree.h.
void UniConfTree< UniWatchInfoTree , UniHashTreeBase >::setparent | ( | UniWatchInfoTree * | parent | ) | [inline, inherited] |
UniWatchInfoTree * UniConfTree< UniWatchInfoTree , UniHashTreeBase >::root | ( | ) | const [inline, inherited] |
UniConfKey UniConfTree< UniWatchInfoTree , UniHashTreeBase >::fullkey | ( | const UniWatchInfoTree * | ancestor = NULL |
) | const [inline, inherited] |
Returns full path of this node relative to an ancestor.
If ancestor is NULL, returns the root.
Definition at line 56 of file uniconftree.h.
UniWatchInfoTree * UniConfTree< UniWatchInfoTree , UniHashTreeBase >::find | ( | const UniConfKey & | key | ) | const [inline, inherited] |
Finds the sub-node with the specified key.
If key.isempty(), returns this node.
Definition at line 63 of file uniconftree.h.
UniWatchInfoTree * UniConfTree< UniWatchInfoTree , UniHashTreeBase >::findchild | ( | const UniConfKey & | key | ) | const [inline, inherited] |
Finds the direct child node with the specified key.
If key.numsegments() == 1, then performs the same task as find(key), but a little faster. Otherwise returns NULL.
Definition at line 72 of file uniconftree.h.
void UniConfTree< UniWatchInfoTree , UniHashTreeBase >::remove | ( | const UniConfKey & | key | ) | [inline, inherited] |
Removes the node for the specified key from the tree and deletes it along with any of its children.
If the key is UniConfKey::EMPTY, deletes this object.
Definition at line 81 of file uniconftree.h.
void UniConfTree< UniWatchInfoTree , UniHashTreeBase >::zap | ( | ) | [inline, inherited] |
void UniConfTree< UniWatchInfoTree , UniHashTreeBase >::visit | ( | const Visitor & | visitor, | |
void * | userdata, | |||
bool | preorder = true , |
|||
bool | postorder = false | |||
) | const [inline, inherited] |
Performs a traversal on this tree using the specified visitor function and traversal type(s).
"visitor" is the tree visitor function "userdata" is userdata for the tree visitor function
Definition at line 109 of file uniconftree.h.
bool UniConfTree< UniWatchInfoTree , UniHashTreeBase >::compare | ( | const UniWatchInfoTree * | other, | |
const Comparator & | comparator, | |||
void * | userdata | |||
) | [inline, inherited] |
Compares this tree with another using the specified comparator function.
Comparison of a subtree ends when the comparator returns false. "comparator" is the value compare function "userdata" is userdata for the compare function Returns: true if the comparison function returned true each time
Definition at line 125 of file uniconftree.h.
const UniConfKey& UniHashTreeBase::key | ( | ) | const [inline, inherited] |
Returns the key field.
Definition at line 71 of file unihashtree.h.
References UniHashTreeBase::xkey.
Referenced by UniHashTreeBase::_fullkey(), UniHashTreeBase::_recursivecompare(), and UniHashTreeBase::Accessor::get_key().
bool UniHashTreeBase::haschildren | ( | ) | const [inherited] |
Returns true if the node has children.
Definition at line 114 of file unihashtree.cc.
References WvScatterHashBase::isempty(), and UniHashTreeBase::xchildren.
Referenced by UniTempGen::haschildren(), and isessential().
UniConfKey UniHashTreeBase::xkey [protected, inherited] |
the name of this entry
Definition at line 26 of file unihashtree.h.
Referenced by UniHashTreeBase::key().
UniHashTreeBase* UniHashTreeBase::xparent [protected, inherited] |
the parent of this subtree
Definition at line 27 of file unihashtree.h.
Referenced by UniHashTreeBase::_fullkey(), UniHashTreeBase::_root(), UniHashTreeBase::_setparent(), UniHashTreeBase::UniHashTreeBase(), and UniHashTreeBase::~UniHashTreeBase().
Container* UniHashTreeBase::xchildren [protected, inherited] |
the hash table of children
Definition at line 38 of file unihashtree.h.
Referenced by UniHashTreeBase::_findchild(), UniHashTreeBase::_recursive_unsorted_visit(), UniHashTreeBase::_recursivecompare(), UniHashTreeBase::haschildren(), UniHashTreeBase::UniHashTreeBase(), and UniHashTreeBase::~UniHashTreeBase().