Logo Search packages:      
Sourcecode: qt4-x11 version File versions

q3garray.h

/****************************************************************************
**
** Copyright (C) 1992-2007 Trolltech ASA. All rights reserved.
**
** This file is part of the Qt3Support module of the Qt Toolkit.
**
** This file may be used under the terms of the GNU General Public
** License version 2.0 as published by the Free Software Foundation
** and appearing in the file LICENSE.GPL included in the packaging of
** this file.  Please review the following information to ensure GNU
** General Public Licensing requirements will be met:
** http://www.trolltech.com/products/qt/opensource.html
**
** If you are unsure which license is appropriate for your use, please
** review the following information:
** http://www.trolltech.com/products/qt/licensing.html or contact the
** sales department at sales@trolltech.com.
**
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
**
****************************************************************************/

#ifndef Q3GARRAY_H
#define Q3GARRAY_H

#include <Qt3Support/q3shared.h>

QT_BEGIN_HEADER

QT_MODULE(Qt3SupportLight)

00033 class Q_COMPAT_EXPORT Q3GArray                              // generic array
{
    friend class QBuffer;
public:
    // do not use this, even though this is public
    struct array_data : public Q3Shared { // shared array
      array_data():data(0),len(0)
#ifdef QT_QGARRAY_SPEED_OPTIM
                ,maxl(0)
#endif
          {}
      char *data;                   // actual array data
      uint  len;
#ifdef QT_QGARRAY_SPEED_OPTIM
      uint maxl;
#endif
    };
    Q3GArray();
    enum Optimization { MemOptim, SpeedOptim };
protected:
    Q3GArray(int, int);             // dummy; does not alloc
    Q3GArray(int size);             // allocate 'size' bytes
    Q3GArray(const Q3GArray &a);          // shallow copy
    virtual ~Q3GArray();

00058     Q3GArray    &operator=(const Q3GArray &a) { return assign(a); }

00060     virtual void detach()     { duplicate(*this); }

    // ### Qt 4.0: maybe provide two versions of data(), at(), etc.
00063     char       *data()   const      { return shd->data; }
00064     uint    nrefs()      const      { return shd->count; }
00065     uint    size()       const      { return shd->len; }
    bool    isEqual(const Q3GArray &a) const;

    bool    resize(uint newsize, Optimization optim);
    bool    resize(uint newsize);

    bool    fill(const char *d, int len, uint sz);

    Q3GArray    &assign(const Q3GArray &a);
    Q3GArray    &assign(const char *d, uint len);
    Q3GArray    &duplicate(const Q3GArray &a);
    Q3GArray    &duplicate(const char *d, uint len);
    void    store(const char *d, uint len);

00079     array_data *sharedBlock() const       { return shd; }
00080     void    setSharedBlock(array_data *p) { shd=(array_data*)p; }

    Q3GArray    &setRawData(const char *d, uint len);
    void    resetRawData(const char *d, uint len);

    int           find(const char *d, uint index, uint sz) const;
    int           contains(const char *d, uint sz) const;

    void    sort(uint sz);
    int           bsearch(const char *d, uint sz) const;

    char       *at(uint index) const;

    bool    setExpand(uint index, const char *d, uint sz);

protected:
    virtual array_data *newData();
    virtual void deleteData(array_data *p);

private:
    static void msg_index(uint);
    array_data *shd;
};


00105 inline char *Q3GArray::at(uint index) const
{
#if defined(QT_CHECK_RANGE)
    if (index >= size()) {
      msg_index(index);
      index = 0;
    }
#endif
    return &shd->data[index];
}

QT_END_HEADER

#endif // Q3GARRAY_H

Generated by  Doxygen 1.6.0   Back to index