1
/****************************************************************************
3
** Copyright (C) 1992-2005 Trolltech AS. All rights reserved.
5
** This file is part of the Qt 3 compatibility classes of the Qt Toolkit.
7
** This file may be distributed under the terms of the Q Public License
8
** as defined by Trolltech AS of Norway and appearing in the file
9
** LICENSE.QPL included in the packaging of this file.
11
** This file may be distributed and/or modified under the terms of the
12
** GNU General Public License version 2 as published by the Free Software
13
** Foundation and appearing in the file LICENSE.GPL included in the
14
** packaging of this file.
16
** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for
17
** information about Qt Commercial License Agreements.
18
** See http://www.trolltech.com/qpl/ for QPL licensing information.
19
** See http://www.trolltech.com/gpl/ for GPL licensing information.
21
** Contact info@trolltech.com if any conditions of this licensing are
24
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
25
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
27
****************************************************************************/
32
#include "Qt3Support/q3gdict.h"
37
: public Q3PtrCollection
43
Q3PtrDict(int size=17) : Q3GDict(size,PtrKey,0,0) {}
44
Q3PtrDict( const Q3PtrDict<type> &d ) : Q3GDict(d) {}
45
~Q3PtrDict() { clear(); }
46
Q3PtrDict<type> &operator=(const Q3PtrDict<type> &d)
47
{ return (Q3PtrDict<type>&)Q3GDict::operator=(d); }
48
uint count() const { return Q3GDict::count(); }
49
uint size() const { return Q3GDict::size(); }
50
bool isEmpty() const { return Q3GDict::count() == 0; }
51
void insert( void *k, const type *d )
52
{ Q3GDict::look_ptr(k,(Item)d,1); }
53
void replace( void *k, const type *d )
54
{ Q3GDict::look_ptr(k,(Item)d,2); }
55
bool remove( void *k ) { return Q3GDict::remove_ptr(k); }
56
type *take( void *k ) { return (type*)Q3GDict::take_ptr(k); }
57
type *find( void *k ) const
58
{ return (type *)((Q3GDict*)this)->Q3GDict::look_ptr(k,0,0); }
59
type *operator[]( void *k ) const
60
{ return (type *)((Q3GDict*)this)->Q3GDict::look_ptr(k,0,0); }
61
void clear() { Q3GDict::clear(); }
62
void resize( uint n ) { Q3GDict::resize(n); }
63
void statistics() const { Q3GDict::statistics(); }
67
virtual QDataStream& read( QDataStream &, Q3PtrCollection::Item & );
68
virtual QDataStream& write( QDataStream &, Q3PtrCollection::Item ) const;
72
void deleteItem( Item d );
75
#if !defined(Q_BROKEN_TEMPLATE_SPECIALIZATION)
76
template<> inline void Q3PtrDict<void>::deleteItem( Q3PtrCollection::Item )
82
inline void Q3PtrDict<type>::deleteItem( Q3PtrCollection::Item d )
84
if ( del_item ) delete (type *)d;
88
class Q3PtrDictIterator : public Q3GDictIterator
91
Q3PtrDictIterator(const Q3PtrDict<type> &d) :Q3GDictIterator((Q3GDict &)d) {}
92
~Q3PtrDictIterator() {}
93
uint count() const { return dict->count(); }
94
bool isEmpty() const { return dict->count() == 0; }
95
type *toFirst() { return (type *)Q3GDictIterator::toFirst(); }
96
operator type *() const { return (type *)Q3GDictIterator::get(); }
97
type *current() const { return (type *)Q3GDictIterator::get(); }
98
void *currentKey() const { return Q3GDictIterator::getKeyPtr(); }
99
type *operator()() { return (type *)Q3GDictIterator::operator()(); }
100
type *operator++() { return (type *)Q3GDictIterator::operator++(); }
101
type *operator+=(uint j) { return (type *)Q3GDictIterator::operator+=(j);}
104
#endif // Q3PTRDICT_H