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
Q3Dict(int size = 17, bool caseSensitive = true)
44
: Q3GDict(size, StringKey, caseSensitive, false) { }
45
Q3Dict(const Q3Dict<type> &d) : Q3GDict(d) { }
46
~Q3Dict() { clear(); }
47
Q3Dict<type> &operator=(const Q3Dict<type> &d)
48
{ return (Q3Dict<type>&)Q3GDict::operator=(d); }
49
uint count() const { return Q3GDict::count(); }
50
uint size() const { return Q3GDict::size(); }
51
bool isEmpty() const { return Q3GDict::count() == 0; }
53
void insert(const QString &k, const type *d)
54
{ Q3GDict::look_string(k,(Item)d,1); }
55
void replace(const QString &k, const type *d)
56
{ Q3GDict::look_string(k,(Item)d,2); }
57
bool remove(const QString &k) { return Q3GDict::remove_string(k); }
58
type *take(const QString &k) { return (type *)Q3GDict::take_string(k); }
59
type *find(const QString &k) const
60
{ return (type *)((Q3GDict*)this)->Q3GDict::look_string(k,0,0); }
61
type *operator[](const QString &k) const
62
{ return (type *)((Q3GDict*)this)->Q3GDict::look_string(k,0,0); }
64
void clear() { Q3GDict::clear(); }
65
void resize(uint n) { Q3GDict::resize(n); }
66
void statistics() const { Q3GDict::statistics(); }
70
virtual QDataStream& read(QDataStream &, Q3PtrCollection::Item &);
71
virtual QDataStream& write(QDataStream &, Q3PtrCollection::Item) const;
75
void deleteItem(Item d);
78
#if !defined(Q_BROKEN_TEMPLATE_SPECIALIZATION)
79
template<> inline void Q3Dict<void>::deleteItem(Item)
84
template<class type> inline void Q3Dict<type>::deleteItem(Q3PtrCollection::Item d)
86
if (del_item) delete (type *)d;
90
class Q3DictIterator : public Q3GDictIterator
93
Q3DictIterator(const Q3Dict<type> &d) : Q3GDictIterator((Q3GDict &)d) { }
95
uint count() const { return dict->count(); }
96
bool isEmpty() const { return dict->count() == 0; }
97
type *toFirst() { return (type *)Q3GDictIterator::toFirst(); }
98
operator type *() const { return (type *)Q3GDictIterator::get(); }
99
type *operator*() { return (type *)Q3GDictIterator::get(); }
100
type *current() const { return (type *)Q3GDictIterator::get(); }
101
QString currentKey() const{ return Q3GDictIterator::getKeyString(); }
102
type *operator()() { return (type *)Q3GDictIterator::operator()(); }
103
type *operator++() { return (type *)Q3GDictIterator::operator++(); }
104
type *operator+=(uint j) { return (type *)Q3GDictIterator::operator+=(j); }