diff options
author | Constantin Jucovschi <cj@ubuntu.localdomain> | 2009-04-24 07:20:22 -0400 |
---|---|---|
committer | Constantin Jucovschi <cj@ubuntu.localdomain> | 2009-04-24 07:20:22 -0400 |
commit | 8f27e65bddd7d4b8515ce620fb485fdd78fcdf89 (patch) | |
tree | bd328a4dd4f92d32202241b5e3a7f36177792c5f /reladminif/dbobjectiterator.hh | |
download | rasdaman-upstream-8f27e65bddd7d4b8515ce620fb485fdd78fcdf89.tar.gz rasdaman-upstream-8f27e65bddd7d4b8515ce620fb485fdd78fcdf89.tar.xz rasdaman-upstream-8f27e65bddd7d4b8515ce620fb485fdd78fcdf89.zip |
Initial commitv8.0
Diffstat (limited to 'reladminif/dbobjectiterator.hh')
-rw-r--r-- | reladminif/dbobjectiterator.hh | 104 |
1 files changed, 104 insertions, 0 deletions
diff --git a/reladminif/dbobjectiterator.hh b/reladminif/dbobjectiterator.hh new file mode 100644 index 0000000..4f04370 --- /dev/null +++ b/reladminif/dbobjectiterator.hh @@ -0,0 +1,104 @@ +/* +* This file is part of rasdaman community. +* +* Rasdaman community 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 3 of the License, or +* (at your option) any later version. +* +* Rasdaman community 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 more details. +* +* You should have received a copy of the GNU General Public License +* along with rasdaman community. If not, see <http://www.gnu.org/licenses/>. +* +* Copyright 2003, 2004, 2005, 2006, 2007, 2008, 2009 Peter Baumann / +rasdaman GmbH. +* +* For more information please see <http://www.rasdaman.org> +* or contact Peter Baumann via <baumann@rasdaman.com>. +*/ +#ifndef _DBOBJECTITERATOR_HH_ +#define _DBOBJECTITERATOR_HH_ + +template <class T> class DBObjectIterator; +template <class T> class DBRef; +class ObjectBroker; + +#include "lists.h" +//@ManMemo: Module: {\bf reladminif}. +/*@Doc: + +this object gets a set of oids. when an oid is accessed the iterator returns a DBRef to the oid. + +*/ + + +template<class T> +class DBObjectIterator + { + public: + DBObjectIterator(const OIdSet& oidlist); + /*@Doc: + constructs a new Iterator. the OIdSet will be deleted by the DBOBjectIterator. + there may be oids of objects with other classes present. you should be carefull + when using this feature - as in mddtypes/mddbasetypes/mdddim/domtypes + */ + + DBObjectIterator(const DBObjectIterator<T>& it); + /*@Doc: + */ + + ~DBObjectIterator(); + /*@Doc: + deletes the OIdSet passed to it in the constructor + */ + + void reset(); + /*@Doc: + resets the iterator to the beginning + */ + + bool not_done() const; + /*@Doc: + checks if there are more elements + */ + + void advance(); + /*@Doc: + advances the iterator one entry + */ + + DBRef<T> get_element() const; + /*@Doc: + returns an dbref<object> + */ + + private: + OIdSet::iterator myIter; + /*@Doc: + internal pointer where the iterator is + */ + + OIdSet* mySet; + /*@Doc: + the actual list which is used to lookup objects by the objectbroker + */ + + unsigned int counter; + /*@Doc: + holds the actual position in set + */ + }; + +#ifdef EARLY_TEMPLATE +#ifdef __EXECUTABLE__ +#include "dbobjectiterator.cc" +#endif +#endif + +#endif + + |