source: trunk/include/qasyncio.h@ 127

Last change on this file since 127 was 2, checked in by dmik, 20 years ago

Imported xplatform parts of the official release 3.3.1 from Trolltech

  • Property svn:keywords set to Id
File size: 3.1 KB
Line 
1/****************************************************************************
2** $Id: qasyncio.h 2 2005-11-16 15:49:26Z dmik $
3**
4** Definition of asynchronous I/O classes
5**
6** Created : 970617
7**
8** Copyright (C) 1992-2000 Trolltech AS. All rights reserved.
9**
10** This file is part of the kernel 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 QASYNCIO_H
39#define QASYNCIO_H
40
41#ifndef QT_H
42#include "qobject.h"
43#include "qsignal.h"
44#include "qtimer.h"
45#endif // QT_H
46
47#ifndef QT_NO_ASYNC_IO
48
49class QIODevice;
50
51class Q_EXPORT QAsyncIO {
52public:
53 virtual ~QAsyncIO();
54 void connect(QObject*, const char *member);
55
56protected:
57 void ready();
58
59private:
60 QSignal signal;
61};
62
63class Q_EXPORT QDataSink : public QAsyncIO {
64public:
65 // Call this to know how much I can take.
66 virtual int readyToReceive()=0;
67 virtual void receive(const uchar*, int count)=0;
68 virtual void eof()=0;
69 void maybeReady();
70};
71
72class Q_EXPORT QDataSource : public QAsyncIO {
73public:
74 virtual int readyToSend()=0; // returns -1 when never any more ready
75 virtual void sendTo(QDataSink*, int count)=0;
76 void maybeReady();
77
78 virtual bool rewindable() const;
79 virtual void enableRewind(bool);
80 virtual void rewind();
81};
82
83class Q_EXPORT QIODeviceSource : public QDataSource {
84 const int buf_size;
85 uchar *buffer;
86 QIODevice* iod;
87 bool rew;
88
89public:
90 QIODeviceSource(QIODevice*, int bufsize=4096);
91 ~QIODeviceSource();
92
93 int readyToSend();
94 void sendTo(QDataSink* sink, int n);
95 bool rewindable() const;
96 void enableRewind(bool on);
97 void rewind();
98};
99
100class Q_EXPORT QDataPump : public QObject {
101 Q_OBJECT
102 int interval;
103 QTimer timer;
104 QDataSource* source;
105 QDataSink* sink;
106
107public:
108 QDataPump(QDataSource*, QDataSink*);
109
110private slots:
111 void kickStart();
112 void tryToPump();
113};
114
115#endif // QT_NO_ASYNC_IO
116
117#endif
Note: See TracBrowser for help on using the repository browser.