NodeComponentList.hpp

Go to the documentation of this file.
00001 /*
00002 SagaEngine library
00003 Copyright (c) 2002-2006 Skalden Studio AS
00004 
00005 This software is provided 'as-is', without any express or implied 
00006 warranty. In no event will the authors be held liable for any 
00007 damages arising from the use of this software.
00008 
00009 Permission is granted to distribute the library under the terms of the 
00010 Q Public License version 1.0. Be sure to read and understand the license
00011 before using the library. It should be included here, or you may read it
00012 at http://www.trolltech.com/products/qt/licenses/licensing/qpl
00013 
00014 The original version of this library can be located at:
00015 http://www.sagaengine.com/
00016 
00017 Rune Myrland
00018 rune@skalden.com
00019 */
00020 
00021 
00022 #ifndef NodeComponentList_hpp
00023 #define NodeComponentList_hpp
00024 
00025 #include "comp/comp.hpp"
00026 #include "comp/schema/CompSchema.hpp"
00027 #include "comp/node/comp_node.hpp"
00028 
00029 namespace se_core {
00030 
00031     class _SeCoreExport NodeComponentList {
00032         friend class NodeComponentListIterator;
00033 
00034     public:
00035         typedef CompSchema::VoidList::iterator_type iterator_type;
00036 
00037         class _SeCoreExport Iterator {
00038         public:
00039             Iterator();
00040             Iterator(NodeComponentList& mgo);
00041             void init(NodeComponentList& mgo);
00042             void init(short firstNode);
00043 
00044             inline bool hasNext() {
00045                 return it_ != CompSchema::VoidList::end();
00046             }
00047 
00048             inline NodeComponent& next() {
00049                 return *static_cast<NodeComponent*>(CompSchema::voidList.next(it_));
00050             }
00051 
00052         private:
00053             CompSchema::VoidList::iterator_type it_;
00054         };
00055 
00056 
00057         class _SeCoreExport TreeIterator {
00058         public:
00059             TreeIterator();
00060             TreeIterator(NodeComponentList& mgo);
00061             void init(NodeComponentList& mgo);
00062 
00063             bool hasNext();
00064             NodeComponent& next();
00065 
00066         private:
00067             static const int MAX_STACK_DEPTH = 10;
00068             NodeComponentList::Iterator itStack_[ MAX_STACK_DEPTH ];
00069             short stackPointer_;
00070         };
00071 
00072 
00073         NodeComponentList();
00074         virtual ~NodeComponentList();
00075         virtual void add(NodeComponent& value);
00076         void add(NodeComponentList& msc);
00077         virtual void remove(NodeComponent& value);
00078         void initIterator(CompSchema::VoidList::iterator_type& iterator) const;
00079         inline CompSchema::VoidList::iterator_type iterator() const { return firstNode_; }
00080         bool contains(NodeComponent& value) const;
00081         bool contains(NodeComponentList& msc) const;
00082         bool sharesAny(NodeComponentList& msc) const;
00083         bool isEmpty() const;
00084         void destroyMembersAndClear();
00085         void clear();
00086         int size() const;
00087 
00088     protected:
00089         CompSchema::VoidList::iterator_type firstNode_;
00090     };
00091 }
00092 
00093 #endif

Home Page | SagaEngine trunk (updated nightly) reference generated Sun Dec 2 20:06:10 2007 by Doxygen version 1.3.9.1.

SourceForge.net Logo