Orb/Doxygen/qtools/qasciidict.h
changeset 0 42188c7ea2d9
equal deleted inserted replaced
-1:000000000000 0:42188c7ea2d9
       
     1 /****************************************************************************
       
     2 ** 
       
     3 **
       
     4 ** Definition of QAsciiDict template class
       
     5 **
       
     6 ** Created : 920821
       
     7 **
       
     8 ** Copyright (C) 1992-2000 Trolltech AS.  All rights reserved.
       
     9 **
       
    10 ** This file is part of the tools module of the Qt GUI Toolkit.
       
    11 **
       
    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.
       
    15 **
       
    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.
       
    20 **
       
    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.
       
    24 **
       
    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.
       
    27 **
       
    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.
       
    32 **
       
    33 ** Contact info@trolltech.com if any conditions of this licensing are
       
    34 ** not clear to you.
       
    35 **
       
    36 **********************************************************************/
       
    37 
       
    38 #ifndef QASCIIDICT_H
       
    39 #define QASCIIDICT_H
       
    40 
       
    41 #ifndef QT_H
       
    42 #include "qgdict.h"
       
    43 #endif // QT_H
       
    44 
       
    45 
       
    46 template<class type> class Q_EXPORT QAsciiDict : public QGDict
       
    47 {
       
    48 public:
       
    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; }
       
    58 
       
    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); }
       
    69 
       
    70     void  clear()			{ QGDict::clear(); }
       
    71     void  resize( uint n )		{ QGDict::resize(n); }
       
    72     void  statistics() const		{ QGDict::statistics(); }
       
    73 private:
       
    74     void  deleteItem( Item d );
       
    75 };
       
    76 
       
    77 #if defined(Q_DELETING_VOID_UNDEFINED)
       
    78 template<> inline void QAsciiDict<void>::deleteItem( Item )
       
    79 {
       
    80 }
       
    81 #endif
       
    82 
       
    83 template<class type> inline void QAsciiDict<type>::deleteItem( QCollection::Item d )
       
    84 {
       
    85     if ( del_item ) delete (type *)d;
       
    86 }
       
    87 
       
    88 
       
    89 template<class type> class Q_EXPORT QAsciiDictIterator : public QGDictIterator
       
    90 {
       
    91 public:
       
    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);}
       
   104 };
       
   105 
       
   106 
       
   107 #endif // QASCIIDICT_H