/**************************************************************************** ** ** Definition of TQPtrList template/macro class ** ** Copyright (C) 2010 Timothy Pearson and (C) 1992-2008 Trolltech ASA. ** ** This file is part of the tools module of the TQt GUI Toolkit. ** ** This file may be used under the terms of the GNU General ** Public License versions 2.0 or 3.0 as published by the Free ** Software Foundation and appearing in the files LICENSE.GPL2 ** and LICENSE.GPL3 included in the packaging of this file. ** Alternatively you may (at your option) use any later version ** of the GNU General Public License if such license has been ** publicly approved by Trolltech ASA (or its successors, if any) ** and the KDE Free TQt Foundation. ** ** Please review the following information to ensure GNU General ** Public Licensing requirements will be met: ** http://trolltech.com/products/qt/licenses/licensing/opensource/. ** If you are unsure which license is appropriate for your use, please ** review the following information: ** http://trolltech.com/products/qt/licenses/licensing/licensingoverview ** or contact the sales department at sales@trolltech.com. ** ** This file may be used under the terms of the Q Public License as ** defined by Trolltech ASA and appearing in the file LICENSE.TQPL ** included in the packaging of this file. Licensees holding valid TQt ** Commercial licenses may use this file in accordance with the TQt ** Commercial License Agreement provided with the Software. ** ** This file is provided "AS IS" with NO WARRANTY OF ANY KIND, ** INCLUDING THE WARRANTIES OF DESIGN, MERCHANTABILITY AND FITNESS FOR ** A PARTICULAR PURPOSE. Trolltech reserves all rights not granted ** herein. ** **********************************************************************/ #ifndef TQPTRLIST_H #define TQPTRLIST_H #ifndef TQT_H #include "tqglist.h" #endif // TQT_H template class TQPtrListStdIterator : public TQGListStdIterator { public: inline TQPtrListStdIterator( TQLNode* n ): TQGListStdIterator(n) {} type *operator*() { return node ? (type *)node->getData() : 0; } inline TQPtrListStdIterator operator++() { node = next(); return *this; } inline TQPtrListStdIterator operator++(int) { TQLNode* n = node; node = next(); return TQPtrListStdIterator( n ); } inline bool operator==( const TQPtrListStdIterator& it ) const { return node == it.node; } inline bool operator!=( const TQPtrListStdIterator& it ) const { return node != it.node; } }; template class TQPtrList #ifdef TQ_TQDOC : public TQPtrCollection #else : public TQGList #endif { public: TQPtrList() {} TQPtrList( const TQPtrList &l ) : TQGList(l) {} ~TQPtrList() { clear(); } TQPtrList &operator=(const TQPtrList &l) { return (TQPtrList&)TQGList::operator=(l); } bool operator==( const TQPtrList &list ) const { return TQGList::operator==( list ); } bool operator!=( const TQPtrList &list ) const { return !TQGList::operator==( list ); } uint count() const { return TQGList::count(); } bool isEmpty() const { return TQGList::count() == 0; } bool insert( uint i, const type *d){ return TQGList::insertAt(i,(TQPtrCollection::Item)d); } void inSort( const type *d ) { TQGList::inSort((TQPtrCollection::Item)d); } void prepend( const type *d ) { TQGList::insertAt(0,(TQPtrCollection::Item)d); } void append( const type *d ) { TQGList::append((TQPtrCollection::Item)d); } bool remove( uint i ) { return TQGList::removeAt(i); } bool remove() { return TQGList::remove((TQPtrCollection::Item)0); } bool remove( const type *d ) { return TQGList::remove((TQPtrCollection::Item)d); } bool removeRef( const type *d ) { return TQGList::removeRef((TQPtrCollection::Item)d); } void removeNode( TQLNode *n ) { TQGList::removeNode(n); } bool removeFirst() { return TQGList::removeFirst(); } bool removeLast() { return TQGList::removeLast(); } type *take( uint i ) { return (type *)TQGList::takeAt(i); } type *take() { return (type *)TQGList::take(); } type *takeNode( TQLNode *n ) { return (type *)TQGList::takeNode(n); } void clear() { TQGList::clear(); } void sort() { TQGList::sort(); } int find( const type *d ) { return TQGList::find((TQPtrCollection::Item)d); } int findNext( const type *d ) { return TQGList::find((TQPtrCollection::Item)d,FALSE); } int findRef( const type *d ) { return TQGList::findRef((TQPtrCollection::Item)d); } int findNextRef( const type *d ){ return TQGList::findRef((TQPtrCollection::Item)d,FALSE);} uint contains( const type *d ) const { return TQGList::contains((TQPtrCollection::Item)d); } uint containsRef( const type *d ) const { return TQGList::containsRef((TQPtrCollection::Item)d); } bool replace( uint i, const type *d ) { return TQGList::replaceAt( i, (TQPtrCollection::Item)d ); } type *at( uint i ) { return (type *)TQGList::at(i); } type *tqat( uint i ) { return (type *)TQGList::at(i); } int at() const { return TQGList::at(); } int tqat() const { return TQGList::at(); } type *current() const { return (type *)TQGList::get(); } TQLNode *currentNode() const { return TQGList::currentNode(); } type *getFirst() const { return (type *)TQGList::cfirst(); } type *getLast() const { return (type *)TQGList::clast(); } type *first() { return (type *)TQGList::first(); } type *last() { return (type *)TQGList::last(); } type *next() { return (type *)TQGList::next(); } type *prev() { return (type *)TQGList::prev(); } void toVector( TQGVector *vec )const{ TQGList::toVector(vec); } // standard iterators typedef TQPtrListStdIterator Iterator; typedef TQPtrListStdIterator ConstIterator; inline Iterator begin() { return TQGList::begin(); } inline ConstIterator begin() const { return TQGList::begin(); } inline ConstIterator constBegin() const { return TQGList::begin(); } inline Iterator end() { return TQGList::end(); } inline ConstIterator end() const { return TQGList::end(); } inline ConstIterator constEnd() const { return TQGList::end(); } inline Iterator erase( Iterator it ) { return TQGList::erase( it ); } // stl syntax compatibility typedef Iterator iterator; typedef ConstIterator const_iterator; #ifdef TQ_TQDOC protected: virtual int compareItems( TQPtrCollection::Item, TQPtrCollection::Item ); virtual TQDataStream& read( TQDataStream&, TQPtrCollection::Item& ); virtual TQDataStream& write( TQDataStream&, TQPtrCollection::Item ) const; #endif private: void deleteItem( Item d ); }; #if !defined(TQ_BROKEN_TEMPLATE_SPECIALIZATION) template<> inline void TQPtrList::deleteItem( TQPtrCollection::Item ) { } #endif template inline void TQPtrList::deleteItem( TQPtrCollection::Item d ) { if ( del_item ) delete (type *)d; } template class TQPtrListIterator : public TQGListIterator { public: TQPtrListIterator(const TQPtrList &l) :TQGListIterator((TQGList &)l) {} ~TQPtrListIterator() {} uint count() const { return list->count(); } bool isEmpty() const { return list->count() == 0; } bool atFirst() const { return TQGListIterator::atFirst(); } bool atLast() const { return TQGListIterator::atLast(); } type *toFirst() { return (type *)TQGListIterator::toFirst(); } type *toLast() { return (type *)TQGListIterator::toLast(); } operator type *() const { return (type *)TQGListIterator::get(); } type *operator*() { return (type *)TQGListIterator::get(); } // No good, since TQPtrList (ie. TQStrList fails... // // MSVC++ gives warning // Sunpro C++ 4.1 gives error // type *operator->() { return (type *)TQGListIterator::get(); } type *current() const { return (type *)TQGListIterator::get(); } type *operator()() { return (type *)TQGListIterator::operator()();} type *operator++() { return (type *)TQGListIterator::operator++(); } type *operator+=(uint j) { return (type *)TQGListIterator::operator+=(j);} type *operator--() { return (type *)TQGListIterator::operator--(); } type *operator-=(uint j) { return (type *)TQGListIterator::operator-=(j);} TQPtrListIterator& operator=(const TQPtrListIterator&it) { TQGListIterator::operator=(it); return *this; } }; #ifndef TQT_NO_COMPAT #define TQList TQPtrList #define TQListIterator TQPtrListIterator #endif #define TQ_DEFINED_TQPTRLIST #include "tqwinexport.h" #endif // TQPTRLIST_H