#include "TQIODeviceTransport.h"
-#include <transport/TBufferTransports.h>
-
#include <QAbstractSocket>
+#include <QIODevice>
-#include <iostream>
+#include <transport/TBufferTransports.h>
+using boost::shared_ptr;
+
namespace apache { namespace thrift { namespace transport {
- using boost::shared_ptr;
- TQIODeviceTransport::TQIODeviceTransport(shared_ptr<QIODevice> dev)
- : dev_(dev)
- {
+TQIODeviceTransport::TQIODeviceTransport(shared_ptr<QIODevice> dev)
+ : dev_(dev)
+{
+}
+
+TQIODeviceTransport::~TQIODeviceTransport()
+{
+ dev_->close();
+}
+
+void TQIODeviceTransport::open()
+{
+ if (!isOpen()) {
+ throw TTransportException(TTransportException::NOT_OPEN,
+ "open(): underlying QIODevice isn't open");
}
-
- TQIODeviceTransport::~TQIODeviceTransport()
- {
- dev_->close();
- }
-
- void TQIODeviceTransport::open()
- {
- if (!isOpen()) {
- throw TTransportException(TTransportException::NOT_OPEN,
- "open(): underlying QIODevice isn't open");
- }
- }
-
- bool TQIODeviceTransport::isOpen()
- {
- return dev_->isOpen();
- }
-
- bool TQIODeviceTransport::peek()
- {
- return dev_->bytesAvailable() > 0;
- }
-
- void TQIODeviceTransport::close()
- {
- dev_->close();
- }
-
- uint32_t TQIODeviceTransport::readAll(uint8_t* buf, uint32_t len) {
- uint32_t requestLen = len;
- while (len) {
- uint32_t readSize;
- try {
- readSize = read(buf, len);
- } catch (...) {
- if (len != requestLen) {
- // something read already
- return requestLen - len;
- }
- // error but nothing read yet
- throw;
- }
- if (readSize == 0) {
- // dev_->waitForReadyRead(50);
- } else {
- buf += readSize;
- len -= readSize;
+}
+
+bool TQIODeviceTransport::isOpen()
+{
+ return dev_->isOpen();
+}
+
+bool TQIODeviceTransport::peek()
+{
+ return dev_->bytesAvailable() > 0;
+}
+
+void TQIODeviceTransport::close()
+{
+ dev_->close();
+}
+
+uint32_t TQIODeviceTransport::readAll(uint8_t* buf, uint32_t len)
+{
+ uint32_t requestLen = len;
+ while (len) {
+ uint32_t readSize;
+ try {
+ readSize = read(buf, len);
+ } catch (...) {
+ if (len != requestLen) {
+ // something read already
+ return requestLen - len;
}
+ // error but nothing read yet
+ throw;
+ }
+ if (readSize == 0) {
+ dev_->waitForReadyRead(50);
+ } else {
+ buf += readSize;
+ len -= readSize;
}
- return requestLen;
}
+ return requestLen;
+}
- uint32_t TQIODeviceTransport::read(uint8_t* buf, uint32_t len)
- {
- uint32_t actualSize;
- qint64 readSize;
+uint32_t TQIODeviceTransport::read(uint8_t* buf, uint32_t len)
+{
+ uint32_t actualSize;
+ qint64 readSize;
- if (!dev_->isOpen()) {
- throw TTransportException(TTransportException::NOT_OPEN,
- "read(): underlying QIODevice is not open");
- }
+ if (!dev_->isOpen()) {
+ throw TTransportException(TTransportException::NOT_OPEN,
+ "read(): underlying QIODevice is not open");
+ }
- actualSize = (uint32_t)std::min((qint64)len, dev_->bytesAvailable());
- readSize = dev_->read(reinterpret_cast<char *>(buf), len);
+ actualSize = (uint32_t)std::min((qint64)len, dev_->bytesAvailable());
+ readSize = dev_->read(reinterpret_cast<char *>(buf), actualSize);
- if (readSize < 0) {
- QAbstractSocket* socket;
- if ((socket = qobject_cast<QAbstractSocket* >(dev_.get()))) {
- throw TTransportException(TTransportException::UNKNOWN,
- "Failed to read() from QAbstractSocket",
- socket->error());
- }
+ if (readSize < 0) {
+ QAbstractSocket* socket;
+ if ((socket = qobject_cast<QAbstractSocket* >(dev_.get()))) {
throw TTransportException(TTransportException::UNKNOWN,
- "Failed to read from from QIODevice");
+ "Failed to read() from QAbstractSocket",
+ socket->error());
}
-
- return (uint32_t)readSize;
+ throw TTransportException(TTransportException::UNKNOWN,
+ "Failed to read from from QIODevice");
}
- void TQIODeviceTransport::write(const uint8_t* buf, uint32_t len)
- {
- while (len) {
- uint32_t written = write_partial(buf, len);
- len -= written;
- // dev_->waitForBytesWritten(50);
- }
- }
+ return (uint32_t)readSize;
+}
- uint32_t TQIODeviceTransport::write_partial(const uint8_t* buf, uint32_t len)
- {
- qint64 written;
+void TQIODeviceTransport::write(const uint8_t* buf, uint32_t len)
+{
+ while (len) {
+ uint32_t written = write_partial(buf, len);
+ len -= written;
+ dev_->waitForBytesWritten(50);
+ }
+}
- if (!dev_->isOpen()) {
- throw TTransportException(TTransportException::NOT_OPEN,
- "write_partial(): underlying QIODevice is not open");
- }
+uint32_t TQIODeviceTransport::write_partial(const uint8_t* buf, uint32_t len)
+{
+ qint64 written;
- written = dev_->write(reinterpret_cast<const char*>(buf), len);
- if (written < 0) {
- QAbstractSocket* socket;
- if ((socket = qobject_cast<QAbstractSocket*>(dev_.get()))) {
- throw TTransportException(TTransportException::UNKNOWN,
- "write_partial(): failed to write to QAbstractSocket", socket->error());
- }
+ if (!dev_->isOpen()) {
+ throw TTransportException(TTransportException::NOT_OPEN,
+ "write_partial(): underlying QIODevice is not open");
+ }
+ written = dev_->write(reinterpret_cast<const char*>(buf), len);
+ if (written < 0) {
+ QAbstractSocket* socket;
+ if ((socket = qobject_cast<QAbstractSocket*>(dev_.get()))) {
throw TTransportException(TTransportException::UNKNOWN,
- "write_partial(): failed to write to underlying QIODevice");
+ "write_partial(): failed to write to QAbstractSocket", socket->error());
}
- return (uint32_t)written;
+ throw TTransportException(TTransportException::UNKNOWN,
+ "write_partial(): failed to write to underlying QIODevice");
}
- void TQIODeviceTransport::flush()
- {
- if (!dev_->isOpen()) {
- throw TTransportException(TTransportException::NOT_OPEN,
- "flush(): underlying QIODevice is not open");
- }
-
- QAbstractSocket* socket;
+ return (uint32_t)written;
+}
- if ((socket = qobject_cast<QAbstractSocket*>(dev_.get()))) {
- socket->flush();
- } else {
- dev_->waitForBytesWritten(1);
- }
+void TQIODeviceTransport::flush()
+{
+ if (!dev_->isOpen()) {
+ throw TTransportException(TTransportException::NOT_OPEN,
+ "flush(): underlying QIODevice is not open");
}
- uint8_t* TQIODeviceTransport::borrow(uint8_t* buf, uint32_t* len)
- {
- return NULL;
- }
+ QAbstractSocket* socket;
- void TQIODeviceTransport::consume(uint32_t len)
- {
- throw TTransportException(TTransportException::UNKNOWN);
+ if ((socket = qobject_cast<QAbstractSocket*>(dev_.get()))) {
+ socket->flush();
+ } else {
+ dev_->waitForBytesWritten(1);
}
+}
+
+uint8_t* TQIODeviceTransport::borrow(uint8_t* buf, uint32_t* len)
+{
+ return NULL;
+}
+
+void TQIODeviceTransport::consume(uint32_t len)
+{
+ throw TTransportException(TTransportException::UNKNOWN);
+}
+
}}} // apache::thrift::transport
#ifndef _THRIFT_ASYNC_TQIODEVICE_TRANSPORT_H_
#define _THRIFT_ASYNC_TQIODEVICE_TRANSPORT_H_ 1
-#include <QIODevice>
-
#include <boost/shared_ptr.hpp>
#include <transport/TVirtualTransport.h>
-namespace apache { namespace thrift { namespace protocol {
-class TProtocol;
-}}} // apache::thrift::protocol
+class QIODevice;
namespace apache { namespace thrift { namespace transport {
- class TQIODeviceTransport : public apache::thrift::transport::TVirtualTransport<TQIODeviceTransport> {
- public:
- explicit TQIODeviceTransport(boost::shared_ptr<QIODevice> dev);
- ~TQIODeviceTransport();
-
- void open();
-
- bool isOpen();
-
- bool peek();
-
- void close();
-
- uint32_t readAll(uint8_t *buf, uint32_t len);
+/**
+ * Transport that operates on a QIODevice (socket, file, etc).
+ */
+class TQIODeviceTransport : public apache::thrift::transport::TVirtualTransport<TQIODeviceTransport> {
+ public:
+ explicit TQIODeviceTransport(boost::shared_ptr<QIODevice> dev);
+ virtual ~TQIODeviceTransport();
- uint32_t read(uint8_t* buf, uint32_t len);
+ void open();
+ bool isOpen();
+ bool peek();
+ void close();
- void write(const uint8_t* buf, uint32_t len);
+ uint32_t readAll(uint8_t *buf, uint32_t len);
+ uint32_t read(uint8_t* buf, uint32_t len);
- uint32_t write_partial(const uint8_t* buf, uint32_t len);
+ void write(const uint8_t* buf, uint32_t len);
+ uint32_t write_partial(const uint8_t* buf, uint32_t len);
- void flush();
+ void flush();
- uint8_t* borrow(uint8_t* buf, uint32_t* len);
- void consume(uint32_t len);
+ uint8_t* borrow(uint8_t* buf, uint32_t* len);
+ void consume(uint32_t len);
- private:
- boost::shared_ptr<QIODevice> dev_;
- };
+ private:
+ TQIODeviceTransport(const TQIODeviceTransport&);
+ TQIODeviceTransport& operator=(const TQIODeviceTransport&);
+
+ boost::shared_ptr<QIODevice> dev_;
+};
}}} // apache::thrift::transport
#endif // #ifndef _THRIFT_ASYNC_TQIODEVICE_TRANSPORT_H_