libktorrent  2.2.0
streamsocket.h
1 /***************************************************************************
2  * Copyright (C) 2011 by Joris Guisson *
3  * joris.guisson@gmail.com *
4  * *
5  * This program is free software; you can redistribute it and/or modify *
6  * it under the terms of the GNU General Public License as published by *
7  * the Free Software Foundation; either version 2 of the License, or *
8  * (at your option) any later version. *
9  * *
10  * This program is distributed in the hope that it will be useful, *
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13  * GNU General Public License for more details. *
14  * *
15  * You should have received a copy of the GNU General Public License *
16  * along with this program; if not, write to the *
17  * Free Software Foundation, Inc., *
18  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
19  ***************************************************************************/
20 
21 
22 #ifndef NET_STREAMSOCKET_H
23 #define NET_STREAMSOCKET_H
24 
25 #include <QByteArray>
26 #include <net/trafficshapedsocket.h>
27 
28 
29 namespace net
30 {
32  {
33  public:
34  virtual ~StreamSocketListener() {}
35 
39  virtual void connectFinished(bool succeeded) = 0;
40 
44  virtual void dataSent() = 0;
45  };
51  {
52  public:
53  StreamSocket(bool tcp, int ip_version, StreamSocketListener* listener);
54  ~StreamSocket() override;
55 
56  bool bytesReadyToWrite() const override;
57  bt::Uint32 write(bt::Uint32 max, bt::TimeStamp now) override;
58 
63  void addData(const QByteArray & data);
64 
65  private:
66  StreamSocketListener* listener;
67  QByteArray buffer;
68  };
69 
70 }
71 
72 #endif // NET_STREAMSOCKET_H
net::StreamSocketListener
Definition: streamsocket.h:32
net::StreamSocket
Definition: streamsocket.h:51
net::StreamSocketListener::dataSent
virtual void dataSent()=0
net::StreamSocket::addData
void addData(const QByteArray &data)
net::StreamSocketListener::connectFinished
virtual void connectFinished(bool succeeded)=0
net::StreamSocket::bytesReadyToWrite
bool bytesReadyToWrite() const override
See if the socket has something ready to write.
net::TrafficShapedSocket
Definition: trafficshapedsocket.h:52