1 /****************************************************************************
4 ** Definition of QAsciiDict template class
8 ** Copyright (C) 1992-2000 Trolltech AS. All rights reserved.
10 ** This file is part of the tools module of the Qt GUI Toolkit.
12 ** This file may be distributed under the terms of the Q Public License
13 ** as defined by Trolltech AS of Norway and appearing in the file
14 ** LICENSE.QPL included in the packaging of this file.
16 ** This file may be distributed and/or modified under the terms of the
17 ** GNU General Public License version 2 as published by the Free Software
18 ** Foundation and appearing in the file LICENSE.GPL included in the
19 ** packaging of this file.
21 ** Licensees holding valid Qt Enterprise Edition or Qt Professional Edition
22 ** licenses may use this file in accordance with the Qt Commercial License
23 ** Agreement provided with the Software.
25 ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
26 ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
28 ** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for
29 ** information about Qt Commercial License Agreements.
30 ** See http://www.trolltech.com/qpl/ for QPL licensing information.
31 ** See http://www.trolltech.com/gpl/ for GPL licensing information.
33 ** Contact info@trolltech.com if any conditions of this licensing are
36 **********************************************************************/
46 template<class type> class Q_EXPORT QAsciiDict : public QGDict
49 QAsciiDict(int size=17, bool caseSensitive=TRUE, bool copyKeys=TRUE )
50 : QGDict(size,AsciiKey,caseSensitive,copyKeys) {}
51 QAsciiDict( const QAsciiDict<type> &d ) : QGDict(d) {}
52 ~QAsciiDict() { clear(); }
53 QAsciiDict<type> &operator=(const QAsciiDict<type> &d)
54 { return (QAsciiDict<type>&)QGDict::operator=(d); }
55 uint count() const { return QGDict::count(); }
56 uint size() const { return QGDict::size(); }
57 bool isEmpty() const { return QGDict::count() == 0; }
59 void insert( const char *k, const type *d )
60 { QGDict::look_ascii(k,(Item)d,1); }
61 void replace( const char *k, const type *d )
62 { QGDict::look_ascii(k,(Item)d,2); }
63 bool remove( const char *k ) { return QGDict::remove_ascii(k); }
64 type *take( const char *k ) { return (type *)QGDict::take_ascii(k); }
65 type *find( const char *k ) const
66 { return (type *)((QGDict*)this)->QGDict::look_ascii(k,0,0); }
67 type *operator[]( const char *k ) const
68 { return (type *)((QGDict*)this)->QGDict::look_ascii(k,0,0); }
70 void clear() { QGDict::clear(); }
71 void resize( uint n ) { QGDict::resize(n); }
72 void statistics() const { QGDict::statistics(); }
74 void deleteItem( Item d );
77 #if defined(Q_DELETING_VOID_UNDEFINED)
78 template<> inline void QAsciiDict<void>::deleteItem( Item )
83 template<class type> inline void QAsciiDict<type>::deleteItem( QCollection::Item d )
85 if ( del_item ) delete (type *)d;
89 template<class type> class Q_EXPORT QAsciiDictIterator : public QGDictIterator
92 QAsciiDictIterator(const QAsciiDict<type> &d)
93 : QGDictIterator((QGDict &)d) {}
94 ~QAsciiDictIterator() {}
95 uint count() const { return dict->count(); }
96 bool isEmpty() const { return dict->count() == 0; }
97 type *toFirst() { return (type *)QGDictIterator::toFirst(); }
98 operator type *() const { return (type *)QGDictIterator::get(); }
99 type *current() const { return (type *)QGDictIterator::get(); }
100 const char *currentKey() const { return QGDictIterator::getKeyAscii(); }
101 type *operator()() { return (type *)QGDictIterator::operator()(); }
102 type *operator++() { return (type *)QGDictIterator::operator++(); }
103 type *operator+=(uint j) { return (type *)QGDictIterator::operator+=(j);}
107 #endif // QASCIIDICT_H