123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207 |
- #pragma once
- #include "Array.h"
- namespace Framework
- {
- template< class T >
- class TreeIterator;
- template< class T >
- class Tree : public virtual ReferenceCounter
- {
- private:
- T *value;
- RCArray< Tree > *subtrees;
- Tree *zParent;
- public:
- Tree()
- : ReferenceCounter()
- {
- value = 0;
- zParent = 0;
- subtrees = new RCArray< Tree >();
- }
- Tree( T *value )
- : ReferenceCounter()
- {
- zParent = 0;
- this->value = value;
- subtrees = new RCArray< Tree >();
- }
- ~Tree()
- {
- if( value )
- value->release();
- subtrees->release();
- }
- TreeIterator<T> getIterator()
- {
- return TreeIterator( this );
- }
- void leeren()
- {
- if( value )
- value->release();
- value = 0;
- subtrees->leeren();
- }
- void addSubtree( Tree *t )
- {
- t->zParent = this;
- subtrees->add( t );
- }
- void setValue( T *v )
- {
- if( value )
- value->release();
- value = v;
- }
- T *getValue()
- {
- return value ? dynamic_cast<T *>( value->getThis() ) : 0;
- }
- T *zValue()
- {
- return value;
- }
- Tree *getParent()
- {
- return zParent ? dynamic_cast<Tree *>( zParent->getThis() ) : 0;
- }
- Tree *zParent()
- {
- return zParent;
- }
- friend TreeIterator;
- };
- template< class T >
- class TreeIterator
- {
- private:
- Tree *current;
- int nextSub;
- public:
- TreeIterator( Tree *tree )
- {
- current = tree;
- nextSub = 0;
- }
- TreeIterator( const TreeIterator &it )
- {
- current = it.current;
- nextSub = it.nextSub;
- }
- TreeIterator< T > &operator=( TreeIterator< T > &r )
- {
- current = r.current;
- nextSub = it.nextSub;
- return *this;
- }
- bool hasNext()
- {
- if( current->subtrees->getEintragAnzahl() >= nextSub )
- return 1;
- Tree<T> *c = current;
- while( true )
- {
- Tree<T> *p = c->zParent();
- if( !p )
- {
- return 0;
- }
- for( auto i = p->subtrees->getIterator(); i; i++ )
- {
- if( i._ == c )
- {
- i++;
- if( i )
- return 1;
- else
- {
- c = p;
- break;
- }
- }
- }
- }
- }
- TreeIterator< T > next()
- {
- if( current->subtrees->getEintragAnzahl() >= nextSub )
- return TreeIterator( current->subtrees->z( nextSub++ ) );
- Tree<T> *c = current;
- while( true )
- {
- Tree<T> *p = c->zParent();
- if( !p )
- return TreeIterator<T>( 0 );
- for( auto i = p->subtrees->getIterator(); i; i++ )
- {
- if( i._ == c )
- {
- i++;
- if( i )
- return TreeIterator<T>( i._ );
- else
- {
- c = p;
- break;
- }
- }
- }
- }
- }
- operator bool()
- {
- return current != 0;
- }
- operator T *( )
- {
- return current->zValue();
- }
- TreeIterator< T > &operator++() //! prefix
- {
- TreeIterator< T > temp( *this );
- *this = next();
- return temp;
- }
- TreeIterator< T > &operator++( int ) //! postfix
- {
- *this = next();
- return *this;
- }
- T *operator->()
- {
- return current->zValue();
- }
- T val()
- {
- return current->zValue();
- }
- };
- }
|