thrift/contrib/thrift_dump.cpp
David Reiss 28f298dd5d Memory-based transport rewrite.
The old implementations of the memory-based transports (TBufferedTransport,
TFramedTransport, and TMemoryBuffer) shared very little code and all worked
a bit differently.  This change unifies them all as subclasses of a single
base (TBufferBase) which handles the fast-path operations (when requests
can be satisfied by the buffer) with inline methods (that will eventually
be made nonvirtual in the template branch) and calls out to pure-virutal
methods to handle full/empty buffers.  All of the buffer-management is now
done in terms of "base and bound" pointers rather than "pos" integers.

These classes were moved to TBufferTransports.{h,cpp}.  The .h is included
in TTransportUtils for backwards compatibility.

Also added a "TShortReadTransport" to assist testing transports.


git-svn-id: https://svn.apache.org/repos/asf/incubator/thrift/trunk@665676 13f79535-47bb-0310-9956-ffa450edef68
2008-05-01 06:17:36 +00:00

78 lines
1.9 KiB
C++

// Copyright (c) 2006- Facebook
// Distributed under the Thrift Software License
//
// See accompanying file LICENSE or visit the Thrift site at:
// http://developers.facebook.com/thrift/
#include <cstdlib>
#include <iostream>
#include <transport/TBufferTransports.h>
#include <transport/TFDTransport.h>
#include <protocol/TBinaryProtocol.h>
#include <protocol/TDebugProtocol.h>
#include <protocol/TProtocolTap.h>
using namespace std;
using boost::shared_ptr;
using namespace facebook::thrift::transport;
using namespace facebook::thrift::protocol;
void usage() {
fprintf(stderr,
"usage: thrift_dump {-b|-f|-s} < input > ouput\n"
" -b TBufferedTransport messages\n"
" -f TFramedTransport messages\n"
" -s Raw structures\n");
exit(EXIT_FAILURE);
}
int main(int argc, char *argv[]) {
if (argc != 2) {
usage();
}
shared_ptr<TTransport> stdin_trans(new TFDTransport(STDIN_FILENO));
shared_ptr<TTransport> itrans;
if (argv[1] == std::string("-b") || argv[1] == std::string("-s")) {
itrans.reset(new TBufferedTransport(stdin_trans));
} else if (argv[1] == std::string("-f")) {
itrans.reset(new TFramedTransport(stdin_trans));
} else {
usage();
}
shared_ptr<TProtocol> iprot(new TBinaryProtocol(itrans));
shared_ptr<TProtocol> oprot(
new TDebugProtocol(
shared_ptr<TTransport>(new TBufferedTransport(
shared_ptr<TTransport>(new TFDTransport(STDOUT_FILENO))))));
TProtocolTap tap(iprot, oprot);
try {
if (argv[1] == std::string("-s")) {
for (;;) {
tap.skip(T_STRUCT);
}
} else {
std::string name;
TMessageType messageType;
int32_t seqid;
for (;;) {
tap.readMessageBegin(name, messageType, seqid);
tap.skip(T_STRUCT);
tap.readMessageEnd();
}
}
} catch (TProtocolException exn) {
cout << "Protocol Exception: " << exn.what() << endl;
} catch (...) {
}
cout << endl;
return 0;
}