123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
/**************************************************************************** ** $Id: qasyncio.h,v 1.1 2003/12/04 08:17:52 falbujer Exp $ ** ** Definition of asynchronous I/O classes ** ** Created : 970617 ** ** Copyright (C) 1992-2000 Trolltech AS. All rights reserved. ** ** This file is part of the kernel 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 QASYNCIO_H #define QASYNCIO_H #ifndef QT_H #include "qobject.h" #include "qsignal.h" #include "qtimer.h" #endif // QT_H #ifndef QT_NO_ASYNC_IO class QIODevice; class Q_EXPORT QAsyncIO { public: virtual ~QAsyncIO(); void connect(QObject*, const char *member); protected: void ready(); private: QSignal signal; }; class Q_EXPORT QDataSink : public QAsyncIO { public: // Call this to know how much I can take. virtual int readyToReceive()=0; virtual void receive(const uchar*, int count)=0; virtual void eof()=0; void maybeReady(); }; class Q_EXPORT QDataSource : public QAsyncIO { public: virtual int readyToSend()=0; // returns -1 when never any more ready virtual void sendTo(QDataSink*, int count)=0; void maybeReady(); virtual bool rewindable() const; virtual void enableRewind(bool); virtual void rewind(); }; class Q_EXPORT QIODeviceSource : public QDataSource { const int buf_size; uchar *buffer; QIODevice* iod; bool rew; public: QIODeviceSource(QIODevice*, int bufsize=4096); ~QIODeviceSource(); int readyToSend(); void sendTo(QDataSink* sink, int n); bool rewindable() const; void enableRewind(bool on); void rewind(); }; class Q_EXPORT QDataPump : public QObject { Q_OBJECT int interval; QTimer timer; QDataSource* source; QDataSink* sink; public: QDataPump(QDataSource*, QDataSink*); private slots: void kickStart(); void tryToPump(); }; #endif // QT_NO_ASYNC_IO #endif
About Koders | Resources | Downloads | Support | Black Duck | Submit Project | Terms of Service | DMCA | Privacy Policy | Site Map| Contact Us
©2010 Koders is a trademark of Black Duck Software, Inc. Black Duck, Know Your Code and the Black Duck logo are registered trademarks of Black Duck Software, Inc. in the United States and other jurisdictions. All other trademarks are the property of their respective holders.