1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
|
/****************************************************************************
** $Id$
**
** Definition of QGVector class
**
** Created : 930907
**
** Copyright (C) 1992-2000 Trolltech AS. All rights reserved.
**
** This file is part of the tools module of the Qt GUI Toolkit.
**
** This file may be distributed under the terms of the Q Public License
** as defined by Trolltech AS of Norway and appearing in the file
** LICENSE.QPL included in the packaging of this file.
**
** This file may be distributed and/or modified under the terms of the
** GNU General Public License version 2 as published by the Free Software
** Foundation and appearing in the file LICENSE.GPL included in the
** packaging of this file.
**
** Licensees holding valid Qt Enterprise Edition or Qt Professional Edition
** licenses may use this file in accordance with the Qt Commercial License
** Agreement provided with the Software.
**
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
**
** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for
** information about Qt Commercial License Agreements.
** See http://www.trolltech.com/qpl/ for QPL licensing information.
** See http://www.trolltech.com/gpl/ for GPL licensing information.
**
** Contact info@trolltech.com if any conditions of this licensing are
** not clear to you.
**
**********************************************************************/
#ifndef QGVECTOR_H
#define QGVECTOR_H
#ifndef QT_H
#include "qcollection.h"
#endif // QT_H
class Q_EXPORT QGVector : public QCollection // generic vector
{
friend class QGList; // needed by QGList::toVector
public:
#ifndef QT_NO_DATASTREAM
QDataStream &read( QDataStream & ); // read vector from stream
QDataStream &write( QDataStream & ) const; // write vector to stream
#endif
virtual int compareItems( Item, Item );
protected:
QGVector(); // create empty vector
QGVector( uint size ); // create vector with nullptrs
QGVector( const QGVector &v ); // make copy of other vector
~QGVector();
QGVector &operator=( const QGVector &v ); // assign from other vector
Item *data() const { return vec; }
uint size() const { return len; }
uint count() const { return numItems; }
bool insert( uint index, Item ); // insert item at index
bool remove( uint index ); // remove item
Item take( uint index ); // take out item
void clear(); // clear vector
bool resize( uint newsize ); // resize vector
bool fill( Item, int flen ); // resize and fill vector
void sort(); // sort vector
int bsearch( Item ) const; // binary search (when sorted)
int findRef( Item, uint index ) const; // find exact item in vector
int find( Item, uint index ) const; // find equal item in vector
uint containsRef( Item ) const; // get number of exact matches
uint contains( Item ) const; // get number of equal matches
Item at( uint index ) const // return indexed item
{
#if defined(CHECK_RANGE)
if ( index >= len )
warningIndexRange( index );
#endif
return vec[index];
}
bool insertExpand( uint index, Item ); // insert, expand if necessary
void toList( QGList * ) const; // put items in list
#ifndef QT_NO_DATASTREAM
virtual QDataStream &read( QDataStream &, Item & );
virtual QDataStream &write( QDataStream &, Item ) const;
#endif
private:
Item *vec;
uint len;
uint numItems;
static void warningIndexRange( uint );
};
/*****************************************************************************
QGVector stream functions
*****************************************************************************/
#ifndef QT_NO_DATASTREAM
Q_EXPORT QDataStream &operator>>( QDataStream &, QGVector & );
Q_EXPORT QDataStream &operator<<( QDataStream &, const QGVector & );
#endif
#endif // QGVECTOR_H
|