/****************************************************************************
** $Id: qqueue.h,v 2.3.2.2 1998/08/27 08:14:01 hanord Exp $
**
** Definition of QQueue template/macro class
**
** Created : 920917
**
** Copyright (C) 1992-1998 Troll Tech AS. All rights reserved.
**
** This file is part of Troll Tech's internal development tree for Qt.
**
** This header text will be replaced by an appropriate text by the
** mkdist script which generates external distributions.
**
** If you are using the Qt Professional Edition or the Qt Free Edition,
** please notify Troll Tech at <info@troll.no> if you see this text.
**
** To Troll Tech developers: This header was generated by the script
** fixcopyright-int. It has the same number of text lines as the free
** and professional editions to avoid line number inconsistency.
**
*****************************************************************************/
#ifndef QQUEUE_H
#define QQUEUE_H
#ifndef QT_H
#include "qglist.h"
#endif // QT_H
#if defined(USE_MACROCLASS)
#include "qgeneric.h"
#if !defined(name2)
#define name2(a,b) name2_xx(a,b)
#define name2_xx(a,b) a##b
#endif
#if defined(DEFAULT_MACROCLASS)
#define QQueuedeclare QQueueMdeclare
#define QQueue QQueueM
#endif
#define QQueueM(type) name2(QQueueM_,type)
#define QQueueMdeclare(type) \
class Q_EXPORTM QQueueM(type) : private QGList \
{ \
public: \
QQueueM(type)() {} \
QQueueM(type)( const QQueueM(type) &q ) : QGList(q) {} \
~QQueueM(type)() { clear(); } \
QQueueM(type)& operator=(const QQueueM(type) &q) \
{ return (QQueueM(type)&)QGList::operator=(q); } \
bool autoDelete() const { return QCollection::autoDelete(); } \
void setAutoDelete( bool del ) { QCollection::setAutoDelete(del); } \
uint count() const { return QGList::count(); } \
bool isEmpty() const { return QGList::count() == 0; } \
void enqueue( const type *d ) { QGList::append(GCI(d)); } \
type *dequeue() { return (type *)QGList::takeFirst();}\
bool remove() { return QGList::removeFirst(); } \
void clear() { QGList::clear(); } \
type *head() const { return (type *)QGList::cfirst(); } \
operator type *() const { return (type *)QGList::cfirst(); } \
type *current() const { return (type *)QGList::cfirst(); } \
private: \
void deleteItem( GCI d ) { if ( del_item ) delete (type *)d; } \
}
#endif // USE_MACROCLASS
#if defined(USE_TEMPLATECLASS)
#if defined(DEFAULT_TEMPLATECLASS)
#undef QQueue
#define QQueue QQueueT
#endif
template<class type> class Q_EXPORT QQueueT : private QGList
{
public:
QQueueT() {}
QQueueT( const QQueueT<type> &q ) : QGList(q) {}
~QQueueT() { clear(); }
QQueueT<type>& operator=(const QQueueT<type> &q)
{ return (QQueueT<type>&)QGList::operator=(q); }
bool autoDelete() const { return QCollection::autoDelete(); }
void setAutoDelete( bool del ) { QCollection::setAutoDelete(del); }
uint count() const { return QGList::count(); }
bool isEmpty() const { return QGList::count() == 0; }
void enqueue( const type *d ) { QGList::append(GCI(d)); }
type *dequeue() { return (type *)QGList::takeFirst();}
bool remove() { return QGList::removeFirst(); }
void clear() { QGList::clear(); }
type *head() const { return (type *)QGList::cfirst(); }
operator type *() const { return (type *)QGList::cfirst(); }
type *current() const { return (type *)QGList::cfirst(); }
private:
void deleteItem( GCI d ) { if ( del_item ) delete (type *)d; }
};
#endif // USE_TEMPLATECLASS
#endif // QQUEUE_H
| Copyright © 1998 Troll Tech | Trademarks | Qt version 1.41
|