auser-poolparty 1.3.0 → 1.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/VERSION.yml +1 -1
- data/examples/monitored_cloud.rb +1 -1
- data/examples/thrift/thrift_example.rb +1 -1
- data/lib/proto/command_interface_handler.rb +1 -1
- data/vendor/gems/thrift/CHANGES +35 -0
- data/vendor/gems/thrift/CONTRIBUTORS +77 -0
- data/vendor/gems/thrift/DISCLAIMER +6 -0
- data/vendor/gems/thrift/LICENSE +202 -0
- data/vendor/gems/thrift/Makefile.am +28 -0
- data/vendor/gems/thrift/NEWS +79 -0
- data/vendor/gems/thrift/NOTICE +26 -0
- data/vendor/gems/thrift/README +137 -0
- data/vendor/gems/thrift/aclocal/ax_boost_base.m4 +198 -0
- data/vendor/gems/thrift/aclocal/ax_javac_and_java.m4 +107 -0
- data/vendor/gems/thrift/aclocal/ax_lib_event.m4 +194 -0
- data/vendor/gems/thrift/aclocal/ax_lib_zlib.m4 +173 -0
- data/vendor/gems/thrift/aclocal/ax_signed_right_shift.m4 +127 -0
- data/vendor/gems/thrift/aclocal/ax_thrift_internal.m4 +39 -0
- data/vendor/gems/thrift/bootstrap.sh +35 -0
- data/vendor/gems/thrift/cleanup.sh +58 -0
- data/vendor/gems/thrift/compiler/cpp/Makefile.am +136 -0
- data/vendor/gems/thrift/compiler/cpp/README +39 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_cocoa_generator.cc +2331 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_cpp_generator.cc +3003 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_csharp_generator.cc +1700 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_erl_generator.cc +932 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_generator.cc +173 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_generator.h +321 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_hs_generator.cc +1445 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_html_generator.cc +637 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_java_generator.cc +3069 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_ocaml_generator.cc +1673 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_oop_generator.h +77 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_perl_generator.cc +1812 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_php_generator.cc +2281 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_py_generator.cc +2310 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_rb_generator.cc +1114 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_st_generator.cc +1071 -0
- data/vendor/gems/thrift/compiler/cpp/src/generate/t_xsd_generator.cc +354 -0
- data/vendor/gems/thrift/compiler/cpp/src/globals.h +117 -0
- data/vendor/gems/thrift/compiler/cpp/src/main.cc +1207 -0
- data/vendor/gems/thrift/compiler/cpp/src/main.h +103 -0
- data/vendor/gems/thrift/compiler/cpp/src/md5.c +381 -0
- data/vendor/gems/thrift/compiler/cpp/src/md5.h +91 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_base_type.h +137 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_const.h +59 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_const_value.h +121 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_container.h +56 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_doc.h +51 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_enum.h +59 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_enum_value.h +64 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_field.h +150 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_function.h +93 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_list.h +56 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_map.h +64 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_program.h +223 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_scope.h +86 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_service.h +68 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_set.h +55 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_struct.h +127 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_type.h +176 -0
- data/vendor/gems/thrift/compiler/cpp/src/parse/t_typedef.h +70 -0
- data/vendor/gems/thrift/compiler/cpp/src/platform.h +36 -0
- data/vendor/gems/thrift/compiler/cpp/src/thriftl.ll +303 -0
- data/vendor/gems/thrift/compiler/cpp/src/thrifty.yy +1140 -0
- data/vendor/gems/thrift/configure.ac +255 -0
- data/vendor/gems/thrift/contrib/fb303/LICENSE +16 -0
- data/vendor/gems/thrift/contrib/fb303/Makefile.am +31 -0
- data/vendor/gems/thrift/contrib/fb303/README +37 -0
- data/vendor/gems/thrift/contrib/fb303/acinclude.m4 +258 -0
- data/vendor/gems/thrift/contrib/fb303/aclocal/ax_boost_base.m4 +198 -0
- data/vendor/gems/thrift/contrib/fb303/bootstrap.sh +26 -0
- data/vendor/gems/thrift/contrib/fb303/configure.ac +115 -0
- data/vendor/gems/thrift/contrib/fb303/cpp/FacebookBase.cpp +124 -0
- data/vendor/gems/thrift/contrib/fb303/cpp/FacebookBase.h +103 -0
- data/vendor/gems/thrift/contrib/fb303/cpp/Makefile.am +84 -0
- data/vendor/gems/thrift/contrib/fb303/cpp/ServiceTracker.cpp +481 -0
- data/vendor/gems/thrift/contrib/fb303/cpp/ServiceTracker.h +215 -0
- data/vendor/gems/thrift/contrib/fb303/global_footer.mk +21 -0
- data/vendor/gems/thrift/contrib/fb303/global_header.mk +38 -0
- data/vendor/gems/thrift/contrib/fb303/if/fb303.thrift +112 -0
- data/vendor/gems/thrift/contrib/fb303/java/FacebookBase.java +103 -0
- data/vendor/gems/thrift/contrib/fb303/java/build.xml +84 -0
- data/vendor/gems/thrift/contrib/fb303/php/FacebookBase.php +89 -0
- data/vendor/gems/thrift/contrib/fb303/py/Makefile.am +44 -0
- data/vendor/gems/thrift/contrib/fb303/py/fb303/FacebookBase.py +82 -0
- data/vendor/gems/thrift/contrib/fb303/py/fb303_scripts/__init__.py +20 -0
- data/vendor/gems/thrift/contrib/fb303/py/fb303_scripts/fb303_simple_mgmt.py +195 -0
- data/vendor/gems/thrift/contrib/fb303/py/setup.py +27 -0
- data/vendor/gems/thrift/contrib/thrift.el +126 -0
- data/vendor/gems/thrift/contrib/thrift.spec +206 -0
- data/vendor/gems/thrift/contrib/thrift.vim +91 -0
- data/vendor/gems/thrift/contrib/thrift_dump.cpp +91 -0
- data/vendor/gems/thrift/doc/lgpl-2.1.txt +504 -0
- data/vendor/gems/thrift/doc/otp-base-license.txt +20 -0
- data/vendor/gems/thrift/doc/thrift.bnf +96 -0
- data/vendor/gems/thrift/doc/thrift.tex +1057 -0
- data/vendor/gems/thrift/lib/Makefile.am +55 -0
- data/vendor/gems/thrift/lib/cocoa/README +21 -0
- data/vendor/gems/thrift/lib/cocoa/src/TApplicationException.h +44 -0
- data/vendor/gems/thrift/lib/cocoa/src/TApplicationException.m +130 -0
- data/vendor/gems/thrift/lib/cocoa/src/TException.h +34 -0
- data/vendor/gems/thrift/lib/cocoa/src/TException.m +64 -0
- data/vendor/gems/thrift/lib/cocoa/src/TProcessor.h +29 -0
- data/vendor/gems/thrift/lib/cocoa/src/TProcessorFactory.h +27 -0
- data/vendor/gems/thrift/lib/cocoa/src/TSharedProcessorFactory.h +27 -0
- data/vendor/gems/thrift/lib/cocoa/src/TSharedProcessorFactory.m +51 -0
- data/vendor/gems/thrift/lib/cocoa/src/protocol/TBinaryProtocol.h +51 -0
- data/vendor/gems/thrift/lib/cocoa/src/protocol/TBinaryProtocol.m +477 -0
- data/vendor/gems/thrift/lib/cocoa/src/protocol/TProtocol.h +148 -0
- data/vendor/gems/thrift/lib/cocoa/src/protocol/TProtocolException.h +25 -0
- data/vendor/gems/thrift/lib/cocoa/src/protocol/TProtocolException.m +23 -0
- data/vendor/gems/thrift/lib/cocoa/src/protocol/TProtocolFactory.h +29 -0
- data/vendor/gems/thrift/lib/cocoa/src/protocol/TProtocolUtil.h +29 -0
- data/vendor/gems/thrift/lib/cocoa/src/protocol/TProtocolUtil.m +104 -0
- data/vendor/gems/thrift/lib/cocoa/src/server/TSocketServer.h +50 -0
- data/vendor/gems/thrift/lib/cocoa/src/server/TSocketServer.m +153 -0
- data/vendor/gems/thrift/lib/cocoa/src/transport/THTTPClient.h +42 -0
- data/vendor/gems/thrift/lib/cocoa/src/transport/THTTPClient.m +159 -0
- data/vendor/gems/thrift/lib/cocoa/src/transport/TNSFileHandleTransport.h +35 -0
- data/vendor/gems/thrift/lib/cocoa/src/transport/TNSFileHandleTransport.m +91 -0
- data/vendor/gems/thrift/lib/cocoa/src/transport/TNSStreamTransport.h +38 -0
- data/vendor/gems/thrift/lib/cocoa/src/transport/TNSStreamTransport.m +89 -0
- data/vendor/gems/thrift/lib/cocoa/src/transport/TSocketClient.h +32 -0
- data/vendor/gems/thrift/lib/cocoa/src/transport/TSocketClient.m +58 -0
- data/vendor/gems/thrift/lib/cocoa/src/transport/TTransport.h +36 -0
- data/vendor/gems/thrift/lib/cocoa/src/transport/TTransportException.h +30 -0
- data/vendor/gems/thrift/lib/cocoa/src/transport/TTransportException.m +43 -0
- data/vendor/gems/thrift/lib/cpp/Makefile.am +158 -0
- data/vendor/gems/thrift/lib/cpp/README +67 -0
- data/vendor/gems/thrift/lib/cpp/src/TLogging.h +163 -0
- data/vendor/gems/thrift/lib/cpp/src/TProcessor.h +53 -0
- data/vendor/gems/thrift/lib/cpp/src/TReflectionLocal.h +96 -0
- data/vendor/gems/thrift/lib/cpp/src/Thrift.cpp +148 -0
- data/vendor/gems/thrift/lib/cpp/src/Thrift.h +191 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Exception.h +60 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/FunctionRunner.h +77 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Monitor.cpp +137 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Monitor.h +84 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Mutex.cpp +160 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Mutex.h +114 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/PosixThreadFactory.cpp +314 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/PosixThreadFactory.h +130 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Thread.h +125 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/ThreadManager.cpp +493 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/ThreadManager.h +169 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/TimerManager.cpp +284 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/TimerManager.h +122 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Util.cpp +55 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/Util.h +100 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/test/Tests.cpp +155 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/test/ThreadFactoryTests.h +354 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/test/ThreadManagerTests.h +379 -0
- data/vendor/gems/thrift/lib/cpp/src/concurrency/test/TimerManagerTests.h +155 -0
- data/vendor/gems/thrift/lib/cpp/src/processor/PeekProcessor.cpp +122 -0
- data/vendor/gems/thrift/lib/cpp/src/processor/PeekProcessor.h +77 -0
- data/vendor/gems/thrift/lib/cpp/src/processor/StatsProcessor.h +264 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TBase64Utils.cpp +79 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TBase64Utils.h +42 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TBinaryProtocol.cpp +394 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TBinaryProtocol.h +254 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TCompactProtocol.cpp +736 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TCompactProtocol.h +279 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TDebugProtocol.cpp +346 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TDebugProtocol.h +225 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TDenseProtocol.cpp +762 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TDenseProtocol.h +253 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TJSONProtocol.cpp +998 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TJSONProtocol.h +340 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TOneWayProtocol.h +304 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TProtocol.h +438 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TProtocolException.h +104 -0
- data/vendor/gems/thrift/lib/cpp/src/protocol/TProtocolTap.h +187 -0
- data/vendor/gems/thrift/lib/cpp/src/server/TNonblockingServer.cpp +750 -0
- data/vendor/gems/thrift/lib/cpp/src/server/TNonblockingServer.h +435 -0
- data/vendor/gems/thrift/lib/cpp/src/server/TServer.cpp +38 -0
- data/vendor/gems/thrift/lib/cpp/src/server/TServer.h +213 -0
- data/vendor/gems/thrift/lib/cpp/src/server/TSimpleServer.cpp +118 -0
- data/vendor/gems/thrift/lib/cpp/src/server/TSimpleServer.h +70 -0
- data/vendor/gems/thrift/lib/cpp/src/server/TThreadPoolServer.cpp +217 -0
- data/vendor/gems/thrift/lib/cpp/src/server/TThreadPoolServer.h +79 -0
- data/vendor/gems/thrift/lib/cpp/src/server/TThreadedServer.cpp +243 -0
- data/vendor/gems/thrift/lib/cpp/src/server/TThreadedServer.h +74 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TBufferTransports.cpp +370 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TBufferTransports.h +667 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TFDTransport.cpp +77 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TFDTransport.h +73 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TFileTransport.cpp +953 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TFileTransport.h +442 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/THttpClient.cpp +348 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/THttpClient.h +111 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TServerSocket.cpp +368 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TServerSocket.h +76 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TServerTransport.h +92 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TShortReadTransport.h +96 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TSimpleFileTransport.cpp +54 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TSimpleFileTransport.h +41 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TSocket.cpp +591 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TSocket.h +242 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TSocketPool.cpp +235 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TSocketPool.h +191 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TTransport.h +224 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TTransportException.cpp +31 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TTransportException.h +117 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TTransportUtils.cpp +178 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TTransportUtils.h +287 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TZlibTransport.cpp +299 -0
- data/vendor/gems/thrift/lib/cpp/src/transport/TZlibTransport.h +219 -0
- data/vendor/gems/thrift/lib/cpp/thrift-nb.pc.in +30 -0
- data/vendor/gems/thrift/lib/cpp/thrift-z.pc.in +30 -0
- data/vendor/gems/thrift/lib/cpp/thrift.pc.in +29 -0
- data/vendor/gems/thrift/lib/csharp/Makefile.am +70 -0
- data/vendor/gems/thrift/lib/csharp/README +26 -0
- data/vendor/gems/thrift/lib/csharp/ThriftMSBuildTask/Properties/AssemblyInfo.cs +55 -0
- data/vendor/gems/thrift/lib/csharp/ThriftMSBuildTask/ThriftBuild.cs +242 -0
- data/vendor/gems/thrift/lib/csharp/ThriftMSBuildTask/ThriftMSBuildTask.csproj +62 -0
- data/vendor/gems/thrift/lib/csharp/src/Collections/THashSet.cs +142 -0
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TBase.cs +34 -0
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TBinaryProtocol.cs +392 -0
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TField.cs +58 -0
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TList.cs +50 -0
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TMap.cs +58 -0
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TMessage.cs +58 -0
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TMessageType.cs +31 -0
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TProtocol.cs +87 -0
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TProtocolException.cs +61 -0
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TProtocolFactory.cs +29 -0
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TProtocolUtil.cs +94 -0
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TSet.cs +50 -0
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TStruct.cs +42 -0
- data/vendor/gems/thrift/lib/csharp/src/Protocol/TType.cs +40 -0
- data/vendor/gems/thrift/lib/csharp/src/Server/TServer.cs +135 -0
- data/vendor/gems/thrift/lib/csharp/src/Server/TSimpleServer.cs +148 -0
- data/vendor/gems/thrift/lib/csharp/src/Server/TThreadPoolServer.cs +186 -0
- data/vendor/gems/thrift/lib/csharp/src/Server/TThreadedServer.cs +234 -0
- data/vendor/gems/thrift/lib/csharp/src/TApplicationException.cs +131 -0
- data/vendor/gems/thrift/lib/csharp/src/TProcessor.cs +29 -0
- data/vendor/gems/thrift/lib/csharp/src/Thrift.csproj +73 -0
- data/vendor/gems/thrift/lib/csharp/src/Thrift.sln +35 -0
- data/vendor/gems/thrift/lib/csharp/src/Transport/TBufferedTransport.cs +100 -0
- data/vendor/gems/thrift/lib/csharp/src/Transport/TServerSocket.cs +157 -0
- data/vendor/gems/thrift/lib/csharp/src/Transport/TServerTransport.cs +39 -0
- data/vendor/gems/thrift/lib/csharp/src/Transport/TSocket.cs +144 -0
- data/vendor/gems/thrift/lib/csharp/src/Transport/TStreamTransport.cs +103 -0
- data/vendor/gems/thrift/lib/csharp/src/Transport/TTransport.cs +66 -0
- data/vendor/gems/thrift/lib/csharp/src/Transport/TTransportException.cs +64 -0
- data/vendor/gems/thrift/lib/csharp/src/Transport/TTransportFactory.cs +38 -0
- data/vendor/gems/thrift/lib/erl/Makefile +37 -0
- data/vendor/gems/thrift/lib/erl/README +56 -0
- data/vendor/gems/thrift/lib/erl/build/beamver +59 -0
- data/vendor/gems/thrift/lib/erl/build/buildtargets.mk +15 -0
- data/vendor/gems/thrift/lib/erl/build/colors.mk +24 -0
- data/vendor/gems/thrift/lib/erl/build/docs.mk +12 -0
- data/vendor/gems/thrift/lib/erl/build/mime.types +98 -0
- data/vendor/gems/thrift/lib/erl/build/otp.mk +146 -0
- data/vendor/gems/thrift/lib/erl/build/otp_subdir.mk +85 -0
- data/vendor/gems/thrift/lib/erl/build/raw_test.mk +29 -0
- data/vendor/gems/thrift/lib/erl/include/thrift_constants.hrl +54 -0
- data/vendor/gems/thrift/lib/erl/include/thrift_protocol.hrl +31 -0
- data/vendor/gems/thrift/lib/erl/src/Makefile +116 -0
- data/vendor/gems/thrift/lib/erl/src/test_handler.erl +26 -0
- data/vendor/gems/thrift/lib/erl/src/test_service.erl +29 -0
- data/vendor/gems/thrift/lib/erl/src/thrift.app.src +44 -0
- data/vendor/gems/thrift/lib/erl/src/thrift.appup.src +1 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_base64_transport.erl +64 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_binary_protocol.erl +325 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_buffered_transport.erl +180 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_client.erl +384 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_disk_log_transport.erl +118 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_file_transport.erl +87 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_framed_transport.erl +208 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_http_transport.erl +199 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_memory_buffer.erl +164 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_processor.erl +188 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_protocol.erl +356 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_server.erl +183 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_service.erl +25 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_socket_server.erl +249 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_socket_transport.erl +119 -0
- data/vendor/gems/thrift/lib/erl/src/thrift_transport.erl +57 -0
- data/vendor/gems/thrift/lib/erl/vsn.mk +1 -0
- data/vendor/gems/thrift/lib/hs/README +82 -0
- data/vendor/gems/thrift/lib/hs/Setup.lhs +23 -0
- data/vendor/gems/thrift/lib/hs/TODO +2 -0
- data/vendor/gems/thrift/lib/hs/Thrift.cabal +20 -0
- data/vendor/gems/thrift/lib/hs/src/Thrift.hs +111 -0
- data/vendor/gems/thrift/lib/hs/src/Thrift/Protocol.hs +191 -0
- data/vendor/gems/thrift/lib/hs/src/Thrift/Protocol/Binary.hs +147 -0
- data/vendor/gems/thrift/lib/hs/src/Thrift/Server.hs +65 -0
- data/vendor/gems/thrift/lib/hs/src/Thrift/Transport.hs +60 -0
- data/vendor/gems/thrift/lib/hs/src/Thrift/Transport/Handle.hs +58 -0
- data/vendor/gems/thrift/lib/java/Makefile.am +38 -0
- data/vendor/gems/thrift/lib/java/README +43 -0
- data/vendor/gems/thrift/lib/java/build.xml +195 -0
- data/vendor/gems/thrift/lib/java/ivy.xml +8 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/IntRangeSet.java +171 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TApplicationException.java +123 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TBase.java +66 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TBaseHelper.java +102 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TByteArrayOutputStream.java +46 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TDeserializer.java +94 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TException.java +45 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TFieldRequirementType.java +30 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TProcessor.java +32 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TProcessorFactory.java +39 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/TSerializer.java +110 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/meta_data/FieldMetaData.java +69 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/meta_data/FieldValueMetaData.java +42 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/meta_data/ListMetaData.java +29 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/meta_data/MapMetaData.java +31 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/meta_data/SetMetaData.java +29 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/meta_data/StructMetaData.java +31 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TBase64Utils.java +128 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TBinaryProtocol.java +331 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TCompactProtocol.java +741 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TField.java +48 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TJSONProtocol.java +927 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TList.java +38 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TMap.java +40 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TMessage.java +48 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TMessageType.java +31 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TProtocol.java +146 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TProtocolException.java +81 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TProtocolFactory.java +30 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TProtocolUtil.java +158 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TSet.java +42 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TSimpleJSONProtocol.java +384 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TStruct.java +36 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/protocol/TType.java +40 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/server/THsHaServer.java +304 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/server/TNonblockingServer.java +772 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/server/TServer.java +126 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/server/TSimpleServer.java +145 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/server/TThreadPoolServer.java +271 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TFramedTransport.java +126 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/THttpClient.java +157 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TIOStreamTransport.java +159 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TMemoryBuffer.java +98 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TNonblockingServerSocket.java +160 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TNonblockingServerTransport.java +31 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TNonblockingSocket.java +213 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TNonblockingTransport.java +31 -0
- data/vendor/gems/thrift/lib/java/src/org/apache/thrift/transport/TServerSocket.java +145 -0
- metadata +348 -37
- data/vendor/gems/trollop/FAQ.txt +0 -35
- data/vendor/gems/trollop/History.txt +0 -84
- data/vendor/gems/trollop/Manifest.txt +0 -7
- data/vendor/gems/trollop/README.txt +0 -38
- data/vendor/gems/trollop/Rakefile +0 -36
- data/vendor/gems/trollop/lib/trollop.rb +0 -695
- data/vendor/gems/trollop/release-script.txt +0 -13
- data/vendor/gems/trollop/test/test_trollop.rb +0 -957
- data/vendor/gems/trollop/www/index.html +0 -167
|
@@ -0,0 +1,279 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Licensed to the Apache Software Foundation (ASF) under one
|
|
3
|
+
* or more contributor license agreements. See the NOTICE file
|
|
4
|
+
* distributed with this work for additional information
|
|
5
|
+
* regarding copyright ownership. The ASF licenses this file
|
|
6
|
+
* to you under the Apache License, Version 2.0 (the
|
|
7
|
+
* "License"); you may not use this file except in compliance
|
|
8
|
+
* with the License. You may obtain a copy of the License at
|
|
9
|
+
*
|
|
10
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
11
|
+
*
|
|
12
|
+
* Unless required by applicable law or agreed to in writing,
|
|
13
|
+
* software distributed under the License is distributed on an
|
|
14
|
+
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
15
|
+
* KIND, either express or implied. See the License for the
|
|
16
|
+
* specific language governing permissions and limitations
|
|
17
|
+
* under the License.
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
#ifndef _THRIFT_PROTOCOL_TCOMPACTPROTOCOL_H_
|
|
21
|
+
#define _THRIFT_PROTOCOL_TCOMPACTPROTOCOL_H_ 1
|
|
22
|
+
|
|
23
|
+
#include "TProtocol.h"
|
|
24
|
+
|
|
25
|
+
#include <stack>
|
|
26
|
+
#include <boost/shared_ptr.hpp>
|
|
27
|
+
|
|
28
|
+
namespace apache { namespace thrift { namespace protocol {
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* C++ Implementation of the Compact Protocol as described in THRIFT-110
|
|
32
|
+
*/
|
|
33
|
+
class TCompactProtocol : public TProtocol {
|
|
34
|
+
|
|
35
|
+
protected:
|
|
36
|
+
static const int8_t PROTOCOL_ID = 0x82;
|
|
37
|
+
static const int8_t VERSION_N = 1;
|
|
38
|
+
static const int8_t VERSION_MASK = 0x1f; // 0001 1111
|
|
39
|
+
static const int8_t TYPE_MASK = 0xE0; // 1110 0000
|
|
40
|
+
static const int32_t TYPE_SHIFT_AMOUNT = 5;
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* (Writing) If we encounter a boolean field begin, save the TField here
|
|
44
|
+
* so it can have the value incorporated.
|
|
45
|
+
*/
|
|
46
|
+
struct {
|
|
47
|
+
const char* name;
|
|
48
|
+
TType fieldType;
|
|
49
|
+
int16_t fieldId;
|
|
50
|
+
} booleanField_;
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* (Reading) If we read a field header, and it's a boolean field, save
|
|
54
|
+
* the boolean value here so that readBool can use it.
|
|
55
|
+
*/
|
|
56
|
+
struct {
|
|
57
|
+
bool hasBoolValue;
|
|
58
|
+
bool boolValue;
|
|
59
|
+
} boolValue_;
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* Used to keep track of the last field for the current and previous structs,
|
|
63
|
+
* so we can do the delta stuff.
|
|
64
|
+
*/
|
|
65
|
+
|
|
66
|
+
std::stack<int16_t> lastField_;
|
|
67
|
+
int16_t lastFieldId_;
|
|
68
|
+
|
|
69
|
+
enum Types {
|
|
70
|
+
CT_STOP = 0x00,
|
|
71
|
+
CT_BOOLEAN_TRUE = 0x01,
|
|
72
|
+
CT_BOOLEAN_FALSE = 0x02,
|
|
73
|
+
CT_BYTE = 0x03,
|
|
74
|
+
CT_I16 = 0x04,
|
|
75
|
+
CT_I32 = 0x05,
|
|
76
|
+
CT_I64 = 0x06,
|
|
77
|
+
CT_DOUBLE = 0x07,
|
|
78
|
+
CT_BINARY = 0x08,
|
|
79
|
+
CT_LIST = 0x09,
|
|
80
|
+
CT_SET = 0x0A,
|
|
81
|
+
CT_MAP = 0x0B,
|
|
82
|
+
CT_STRUCT = 0x0C,
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
static const int8_t TTypeToCType[16];
|
|
86
|
+
|
|
87
|
+
public:
|
|
88
|
+
TCompactProtocol(boost::shared_ptr<TTransport> trans) :
|
|
89
|
+
TProtocol(trans),
|
|
90
|
+
lastFieldId_(0),
|
|
91
|
+
string_limit_(0),
|
|
92
|
+
string_buf_(NULL),
|
|
93
|
+
string_buf_size_(0),
|
|
94
|
+
container_limit_(0) {
|
|
95
|
+
booleanField_.name = NULL;
|
|
96
|
+
boolValue_.hasBoolValue = false;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
TCompactProtocol(boost::shared_ptr<TTransport> trans,
|
|
100
|
+
int32_t string_limit,
|
|
101
|
+
int32_t container_limit) :
|
|
102
|
+
TProtocol(trans),
|
|
103
|
+
lastFieldId_(0),
|
|
104
|
+
string_limit_(string_limit),
|
|
105
|
+
string_buf_(NULL),
|
|
106
|
+
string_buf_size_(0),
|
|
107
|
+
container_limit_(container_limit) {
|
|
108
|
+
booleanField_.name = NULL;
|
|
109
|
+
boolValue_.hasBoolValue = false;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
|
|
113
|
+
|
|
114
|
+
/**
|
|
115
|
+
* Writing functions
|
|
116
|
+
*/
|
|
117
|
+
|
|
118
|
+
virtual uint32_t writeMessageBegin(const std::string& name,
|
|
119
|
+
const TMessageType messageType,
|
|
120
|
+
const int32_t seqid);
|
|
121
|
+
|
|
122
|
+
uint32_t writeStructBegin(const char* name);
|
|
123
|
+
|
|
124
|
+
uint32_t writeStructEnd();
|
|
125
|
+
|
|
126
|
+
uint32_t writeFieldBegin(const char* name,
|
|
127
|
+
const TType fieldType,
|
|
128
|
+
const int16_t fieldId);
|
|
129
|
+
|
|
130
|
+
uint32_t writeFieldStop();
|
|
131
|
+
|
|
132
|
+
uint32_t writeListBegin(const TType elemType,
|
|
133
|
+
const uint32_t size);
|
|
134
|
+
|
|
135
|
+
uint32_t writeSetBegin(const TType elemType,
|
|
136
|
+
const uint32_t size);
|
|
137
|
+
|
|
138
|
+
virtual uint32_t writeMapBegin(const TType keyType,
|
|
139
|
+
const TType valType,
|
|
140
|
+
const uint32_t size);
|
|
141
|
+
|
|
142
|
+
uint32_t writeBool(const bool value);
|
|
143
|
+
|
|
144
|
+
uint32_t writeByte(const int8_t byte);
|
|
145
|
+
|
|
146
|
+
uint32_t writeI16(const int16_t i16);
|
|
147
|
+
|
|
148
|
+
uint32_t writeI32(const int32_t i32);
|
|
149
|
+
|
|
150
|
+
uint32_t writeI64(const int64_t i64);
|
|
151
|
+
|
|
152
|
+
uint32_t writeDouble(const double dub);
|
|
153
|
+
|
|
154
|
+
uint32_t writeString(const std::string& str);
|
|
155
|
+
|
|
156
|
+
uint32_t writeBinary(const std::string& str);
|
|
157
|
+
|
|
158
|
+
/**
|
|
159
|
+
* These methods are called by structs, but don't actually have any wired
|
|
160
|
+
* output or purpose
|
|
161
|
+
*/
|
|
162
|
+
virtual uint32_t writeMessageEnd() { return 0; }
|
|
163
|
+
uint32_t writeMapEnd() { return 0; }
|
|
164
|
+
uint32_t writeListEnd() { return 0; }
|
|
165
|
+
uint32_t writeSetEnd() { return 0; }
|
|
166
|
+
uint32_t writeFieldEnd() { return 0; }
|
|
167
|
+
|
|
168
|
+
protected:
|
|
169
|
+
int32_t writeFieldBeginInternal(const char* name,
|
|
170
|
+
const TType fieldType,
|
|
171
|
+
const int16_t fieldId,
|
|
172
|
+
int8_t typeOverride);
|
|
173
|
+
uint32_t writeCollectionBegin(int8_t elemType, int32_t size);
|
|
174
|
+
uint32_t writeVarint32(uint32_t n);
|
|
175
|
+
uint32_t writeVarint64(uint64_t n);
|
|
176
|
+
uint64_t i64ToZigzag(const int64_t l);
|
|
177
|
+
uint32_t i32ToZigzag(const int32_t n);
|
|
178
|
+
inline int8_t getCompactType(int8_t ttype);
|
|
179
|
+
|
|
180
|
+
public:
|
|
181
|
+
uint32_t readMessageBegin(std::string& name,
|
|
182
|
+
TMessageType& messageType,
|
|
183
|
+
int32_t& seqid);
|
|
184
|
+
|
|
185
|
+
uint32_t readStructBegin(std::string& name);
|
|
186
|
+
|
|
187
|
+
uint32_t readStructEnd();
|
|
188
|
+
|
|
189
|
+
uint32_t readFieldBegin(std::string& name,
|
|
190
|
+
TType& fieldType,
|
|
191
|
+
int16_t& fieldId);
|
|
192
|
+
|
|
193
|
+
uint32_t readMapBegin(TType& keyType,
|
|
194
|
+
TType& valType,
|
|
195
|
+
uint32_t& size);
|
|
196
|
+
|
|
197
|
+
uint32_t readListBegin(TType& elemType,
|
|
198
|
+
uint32_t& size);
|
|
199
|
+
|
|
200
|
+
uint32_t readSetBegin(TType& elemType,
|
|
201
|
+
uint32_t& size);
|
|
202
|
+
|
|
203
|
+
uint32_t readBool(bool& value);
|
|
204
|
+
|
|
205
|
+
uint32_t readByte(int8_t& byte);
|
|
206
|
+
|
|
207
|
+
uint32_t readI16(int16_t& i16);
|
|
208
|
+
|
|
209
|
+
uint32_t readI32(int32_t& i32);
|
|
210
|
+
|
|
211
|
+
uint32_t readI64(int64_t& i64);
|
|
212
|
+
|
|
213
|
+
uint32_t readDouble(double& dub);
|
|
214
|
+
|
|
215
|
+
uint32_t readString(std::string& str);
|
|
216
|
+
|
|
217
|
+
uint32_t readBinary(std::string& str);
|
|
218
|
+
|
|
219
|
+
/*
|
|
220
|
+
*These methods are here for the struct to call, but don't have any wire
|
|
221
|
+
* encoding.
|
|
222
|
+
*/
|
|
223
|
+
uint32_t readMessageEnd() { return 0; }
|
|
224
|
+
uint32_t readFieldEnd() { return 0; }
|
|
225
|
+
uint32_t readMapEnd() { return 0; }
|
|
226
|
+
uint32_t readListEnd() { return 0; }
|
|
227
|
+
uint32_t readSetEnd() { return 0; }
|
|
228
|
+
|
|
229
|
+
protected:
|
|
230
|
+
uint32_t readVarint32(int32_t& i32);
|
|
231
|
+
uint32_t readVarint64(int64_t& i64);
|
|
232
|
+
int32_t zigzagToI32(uint32_t n);
|
|
233
|
+
int64_t zigzagToI64(uint64_t n);
|
|
234
|
+
TType getTType(int8_t type);
|
|
235
|
+
|
|
236
|
+
// Buffer for reading strings, save for the lifetime of the protocol to
|
|
237
|
+
// avoid memory churn allocating memory on every string read
|
|
238
|
+
int32_t string_limit_;
|
|
239
|
+
uint8_t* string_buf_;
|
|
240
|
+
int32_t string_buf_size_;
|
|
241
|
+
int32_t container_limit_;
|
|
242
|
+
};
|
|
243
|
+
|
|
244
|
+
/**
|
|
245
|
+
* Constructs compact protocol handlers
|
|
246
|
+
*/
|
|
247
|
+
class TCompactProtocolFactory : public TProtocolFactory {
|
|
248
|
+
public:
|
|
249
|
+
TCompactProtocolFactory() :
|
|
250
|
+
string_limit_(0),
|
|
251
|
+
container_limit_(0) {}
|
|
252
|
+
|
|
253
|
+
TCompactProtocolFactory(int32_t string_limit, int32_t container_limit) :
|
|
254
|
+
string_limit_(string_limit),
|
|
255
|
+
container_limit_(container_limit) {}
|
|
256
|
+
|
|
257
|
+
virtual ~TCompactProtocolFactory() {}
|
|
258
|
+
|
|
259
|
+
void setStringSizeLimit(int32_t string_limit) {
|
|
260
|
+
string_limit_ = string_limit;
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
void setContainerSizeLimit(int32_t container_limit) {
|
|
264
|
+
container_limit_ = container_limit;
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
boost::shared_ptr<TProtocol> getProtocol(boost::shared_ptr<TTransport> trans) {
|
|
268
|
+
return boost::shared_ptr<TProtocol>(new TCompactProtocol(trans, string_limit_, container_limit_));
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
private:
|
|
272
|
+
int32_t string_limit_;
|
|
273
|
+
int32_t container_limit_;
|
|
274
|
+
|
|
275
|
+
};
|
|
276
|
+
|
|
277
|
+
}}} // apache::thrift::protocol
|
|
278
|
+
|
|
279
|
+
#endif
|
|
@@ -0,0 +1,346 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Licensed to the Apache Software Foundation (ASF) under one
|
|
3
|
+
* or more contributor license agreements. See the NOTICE file
|
|
4
|
+
* distributed with this work for additional information
|
|
5
|
+
* regarding copyright ownership. The ASF licenses this file
|
|
6
|
+
* to you under the Apache License, Version 2.0 (the
|
|
7
|
+
* "License"); you may not use this file except in compliance
|
|
8
|
+
* with the License. You may obtain a copy of the License at
|
|
9
|
+
*
|
|
10
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
11
|
+
*
|
|
12
|
+
* Unless required by applicable law or agreed to in writing,
|
|
13
|
+
* software distributed under the License is distributed on an
|
|
14
|
+
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
15
|
+
* KIND, either express or implied. See the License for the
|
|
16
|
+
* specific language governing permissions and limitations
|
|
17
|
+
* under the License.
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
#include "TDebugProtocol.h"
|
|
21
|
+
|
|
22
|
+
#include <cassert>
|
|
23
|
+
#include <cctype>
|
|
24
|
+
#include <cstdio>
|
|
25
|
+
#include <stdexcept>
|
|
26
|
+
#include <boost/static_assert.hpp>
|
|
27
|
+
#include <boost/lexical_cast.hpp>
|
|
28
|
+
|
|
29
|
+
using std::string;
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
static string byte_to_hex(const uint8_t byte) {
|
|
33
|
+
char buf[3];
|
|
34
|
+
int ret = std::sprintf(buf, "%02x", (int)byte);
|
|
35
|
+
assert(ret == 2);
|
|
36
|
+
assert(buf[2] == '\0');
|
|
37
|
+
return buf;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
namespace apache { namespace thrift { namespace protocol {
|
|
42
|
+
|
|
43
|
+
string TDebugProtocol::fieldTypeName(TType type) {
|
|
44
|
+
switch (type) {
|
|
45
|
+
case T_STOP : return "stop" ;
|
|
46
|
+
case T_VOID : return "void" ;
|
|
47
|
+
case T_BOOL : return "bool" ;
|
|
48
|
+
case T_BYTE : return "byte" ;
|
|
49
|
+
case T_I16 : return "i16" ;
|
|
50
|
+
case T_I32 : return "i32" ;
|
|
51
|
+
case T_U64 : return "u64" ;
|
|
52
|
+
case T_I64 : return "i64" ;
|
|
53
|
+
case T_DOUBLE : return "double" ;
|
|
54
|
+
case T_STRING : return "string" ;
|
|
55
|
+
case T_STRUCT : return "struct" ;
|
|
56
|
+
case T_MAP : return "map" ;
|
|
57
|
+
case T_SET : return "set" ;
|
|
58
|
+
case T_LIST : return "list" ;
|
|
59
|
+
case T_UTF8 : return "utf8" ;
|
|
60
|
+
case T_UTF16 : return "utf16" ;
|
|
61
|
+
default: return "unknown";
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
void TDebugProtocol::indentUp() {
|
|
66
|
+
indent_str_ += string(indent_inc, ' ');
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
void TDebugProtocol::indentDown() {
|
|
70
|
+
if (indent_str_.length() < (string::size_type)indent_inc) {
|
|
71
|
+
throw TProtocolException(TProtocolException::INVALID_DATA);
|
|
72
|
+
}
|
|
73
|
+
indent_str_.erase(indent_str_.length() - indent_inc);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
uint32_t TDebugProtocol::writePlain(const string& str) {
|
|
77
|
+
trans_->write((uint8_t*)str.data(), str.length());
|
|
78
|
+
return str.length();
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
uint32_t TDebugProtocol::writeIndented(const string& str) {
|
|
82
|
+
trans_->write((uint8_t*)indent_str_.data(), indent_str_.length());
|
|
83
|
+
trans_->write((uint8_t*)str.data(), str.length());
|
|
84
|
+
return indent_str_.length() + str.length();
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
uint32_t TDebugProtocol::startItem() {
|
|
88
|
+
uint32_t size;
|
|
89
|
+
|
|
90
|
+
switch (write_state_.back()) {
|
|
91
|
+
case UNINIT:
|
|
92
|
+
// XXX figure out what to do here.
|
|
93
|
+
//throw TProtocolException(TProtocolException::INVALID_DATA);
|
|
94
|
+
//return writeIndented(str);
|
|
95
|
+
return 0;
|
|
96
|
+
case STRUCT:
|
|
97
|
+
return 0;
|
|
98
|
+
case SET:
|
|
99
|
+
return writeIndented("");
|
|
100
|
+
case MAP_KEY:
|
|
101
|
+
return writeIndented("");
|
|
102
|
+
case MAP_VALUE:
|
|
103
|
+
return writePlain(" -> ");
|
|
104
|
+
case LIST:
|
|
105
|
+
size = writeIndented(
|
|
106
|
+
"[" + boost::lexical_cast<string>(list_idx_.back()) + "] = ");
|
|
107
|
+
list_idx_.back()++;
|
|
108
|
+
return size;
|
|
109
|
+
default:
|
|
110
|
+
throw std::logic_error("Invalid enum value.");
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
uint32_t TDebugProtocol::endItem() {
|
|
115
|
+
//uint32_t size;
|
|
116
|
+
|
|
117
|
+
switch (write_state_.back()) {
|
|
118
|
+
case UNINIT:
|
|
119
|
+
// XXX figure out what to do here.
|
|
120
|
+
//throw TProtocolException(TProtocolException::INVALID_DATA);
|
|
121
|
+
//return writeIndented(str);
|
|
122
|
+
return 0;
|
|
123
|
+
case STRUCT:
|
|
124
|
+
return writePlain(",\n");
|
|
125
|
+
case SET:
|
|
126
|
+
return writePlain(",\n");
|
|
127
|
+
case MAP_KEY:
|
|
128
|
+
write_state_.back() = MAP_VALUE;
|
|
129
|
+
return 0;
|
|
130
|
+
case MAP_VALUE:
|
|
131
|
+
write_state_.back() = MAP_KEY;
|
|
132
|
+
return writePlain(",\n");
|
|
133
|
+
case LIST:
|
|
134
|
+
return writePlain(",\n");
|
|
135
|
+
default:
|
|
136
|
+
throw std::logic_error("Invalid enum value.");
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
uint32_t TDebugProtocol::writeItem(const std::string& str) {
|
|
141
|
+
uint32_t size = 0;
|
|
142
|
+
size += startItem();
|
|
143
|
+
size += writePlain(str);
|
|
144
|
+
size += endItem();
|
|
145
|
+
return size;
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
uint32_t TDebugProtocol::writeMessageBegin(const std::string& name,
|
|
149
|
+
const TMessageType messageType,
|
|
150
|
+
const int32_t seqid) {
|
|
151
|
+
string mtype;
|
|
152
|
+
switch (messageType) {
|
|
153
|
+
case T_CALL : mtype = "call" ; break;
|
|
154
|
+
case T_REPLY : mtype = "reply" ; break;
|
|
155
|
+
case T_EXCEPTION : mtype = "exn" ; break;
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
uint32_t size = writeIndented("(" + mtype + ") " + name + "(");
|
|
159
|
+
indentUp();
|
|
160
|
+
return size;
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
uint32_t TDebugProtocol::writeMessageEnd() {
|
|
164
|
+
indentDown();
|
|
165
|
+
return writeIndented(")\n");
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
uint32_t TDebugProtocol::writeStructBegin(const char* name) {
|
|
169
|
+
uint32_t size = 0;
|
|
170
|
+
size += startItem();
|
|
171
|
+
size += writePlain(string(name) + " {\n");
|
|
172
|
+
indentUp();
|
|
173
|
+
write_state_.push_back(STRUCT);
|
|
174
|
+
return size;
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
uint32_t TDebugProtocol::writeStructEnd() {
|
|
178
|
+
indentDown();
|
|
179
|
+
write_state_.pop_back();
|
|
180
|
+
uint32_t size = 0;
|
|
181
|
+
size += writeIndented("}");
|
|
182
|
+
size += endItem();
|
|
183
|
+
return size;
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
uint32_t TDebugProtocol::writeFieldBegin(const char* name,
|
|
187
|
+
const TType fieldType,
|
|
188
|
+
const int16_t fieldId) {
|
|
189
|
+
// sprintf(id_str, "%02d", fieldId);
|
|
190
|
+
string id_str = boost::lexical_cast<string>(fieldId);
|
|
191
|
+
if (id_str.length() == 1) id_str = '0' + id_str;
|
|
192
|
+
|
|
193
|
+
return writeIndented(
|
|
194
|
+
id_str + ": " +
|
|
195
|
+
name + " (" +
|
|
196
|
+
fieldTypeName(fieldType) + ") = ");
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
uint32_t TDebugProtocol::writeFieldEnd() {
|
|
200
|
+
assert(write_state_.back() == STRUCT);
|
|
201
|
+
return 0;
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
uint32_t TDebugProtocol::writeFieldStop() {
|
|
205
|
+
return 0;
|
|
206
|
+
//writeIndented("***STOP***\n");
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
uint32_t TDebugProtocol::writeMapBegin(const TType keyType,
|
|
210
|
+
const TType valType,
|
|
211
|
+
const uint32_t size) {
|
|
212
|
+
// TODO(dreiss): Optimize short maps?
|
|
213
|
+
uint32_t bsize = 0;
|
|
214
|
+
bsize += startItem();
|
|
215
|
+
bsize += writePlain(
|
|
216
|
+
"map<" + fieldTypeName(keyType) + "," + fieldTypeName(valType) + ">"
|
|
217
|
+
"[" + boost::lexical_cast<string>(size) + "] {\n");
|
|
218
|
+
indentUp();
|
|
219
|
+
write_state_.push_back(MAP_KEY);
|
|
220
|
+
return bsize;
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
uint32_t TDebugProtocol::writeMapEnd() {
|
|
224
|
+
indentDown();
|
|
225
|
+
write_state_.pop_back();
|
|
226
|
+
uint32_t size = 0;
|
|
227
|
+
size += writeIndented("}");
|
|
228
|
+
size += endItem();
|
|
229
|
+
return size;
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
uint32_t TDebugProtocol::writeListBegin(const TType elemType,
|
|
233
|
+
const uint32_t size) {
|
|
234
|
+
// TODO(dreiss): Optimize short arrays.
|
|
235
|
+
uint32_t bsize = 0;
|
|
236
|
+
bsize += startItem();
|
|
237
|
+
bsize += writePlain(
|
|
238
|
+
"list<" + fieldTypeName(elemType) + ">"
|
|
239
|
+
"[" + boost::lexical_cast<string>(size) + "] {\n");
|
|
240
|
+
indentUp();
|
|
241
|
+
write_state_.push_back(LIST);
|
|
242
|
+
list_idx_.push_back(0);
|
|
243
|
+
return bsize;
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
uint32_t TDebugProtocol::writeListEnd() {
|
|
247
|
+
indentDown();
|
|
248
|
+
write_state_.pop_back();
|
|
249
|
+
list_idx_.pop_back();
|
|
250
|
+
uint32_t size = 0;
|
|
251
|
+
size += writeIndented("}");
|
|
252
|
+
size += endItem();
|
|
253
|
+
return size;
|
|
254
|
+
}
|
|
255
|
+
|
|
256
|
+
uint32_t TDebugProtocol::writeSetBegin(const TType elemType,
|
|
257
|
+
const uint32_t size) {
|
|
258
|
+
// TODO(dreiss): Optimize short sets.
|
|
259
|
+
uint32_t bsize = 0;
|
|
260
|
+
bsize += startItem();
|
|
261
|
+
bsize += writePlain(
|
|
262
|
+
"set<" + fieldTypeName(elemType) + ">"
|
|
263
|
+
"[" + boost::lexical_cast<string>(size) + "] {\n");
|
|
264
|
+
indentUp();
|
|
265
|
+
write_state_.push_back(SET);
|
|
266
|
+
return bsize;
|
|
267
|
+
}
|
|
268
|
+
|
|
269
|
+
uint32_t TDebugProtocol::writeSetEnd() {
|
|
270
|
+
indentDown();
|
|
271
|
+
write_state_.pop_back();
|
|
272
|
+
uint32_t size = 0;
|
|
273
|
+
size += writeIndented("}");
|
|
274
|
+
size += endItem();
|
|
275
|
+
return size;
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
uint32_t TDebugProtocol::writeBool(const bool value) {
|
|
279
|
+
return writeItem(value ? "true" : "false");
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
uint32_t TDebugProtocol::writeByte(const int8_t byte) {
|
|
283
|
+
return writeItem("0x" + byte_to_hex(byte));
|
|
284
|
+
}
|
|
285
|
+
|
|
286
|
+
uint32_t TDebugProtocol::writeI16(const int16_t i16) {
|
|
287
|
+
return writeItem(boost::lexical_cast<string>(i16));
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
uint32_t TDebugProtocol::writeI32(const int32_t i32) {
|
|
291
|
+
return writeItem(boost::lexical_cast<string>(i32));
|
|
292
|
+
}
|
|
293
|
+
|
|
294
|
+
uint32_t TDebugProtocol::writeI64(const int64_t i64) {
|
|
295
|
+
return writeItem(boost::lexical_cast<string>(i64));
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
uint32_t TDebugProtocol::writeDouble(const double dub) {
|
|
299
|
+
return writeItem(boost::lexical_cast<string>(dub));
|
|
300
|
+
}
|
|
301
|
+
|
|
302
|
+
|
|
303
|
+
uint32_t TDebugProtocol::writeString(const string& str) {
|
|
304
|
+
// XXX Raw/UTF-8?
|
|
305
|
+
|
|
306
|
+
string to_show = str;
|
|
307
|
+
if (to_show.length() > (string::size_type)string_limit_) {
|
|
308
|
+
to_show = str.substr(0, string_prefix_size_);
|
|
309
|
+
to_show += "[...](" + boost::lexical_cast<string>(str.length()) + ")";
|
|
310
|
+
}
|
|
311
|
+
|
|
312
|
+
string output = "\"";
|
|
313
|
+
|
|
314
|
+
for (string::const_iterator it = to_show.begin(); it != to_show.end(); ++it) {
|
|
315
|
+
if (*it == '\\') {
|
|
316
|
+
output += "\\\\";
|
|
317
|
+
} else if (*it == '"') {
|
|
318
|
+
output += "\\\"";
|
|
319
|
+
} else if (std::isprint(*it)) {
|
|
320
|
+
output += *it;
|
|
321
|
+
} else {
|
|
322
|
+
switch (*it) {
|
|
323
|
+
case '\a': output += "\\a"; break;
|
|
324
|
+
case '\b': output += "\\b"; break;
|
|
325
|
+
case '\f': output += "\\f"; break;
|
|
326
|
+
case '\n': output += "\\n"; break;
|
|
327
|
+
case '\r': output += "\\r"; break;
|
|
328
|
+
case '\t': output += "\\t"; break;
|
|
329
|
+
case '\v': output += "\\v"; break;
|
|
330
|
+
default:
|
|
331
|
+
output += "\\x";
|
|
332
|
+
output += byte_to_hex(*it);
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
}
|
|
336
|
+
|
|
337
|
+
output += '\"';
|
|
338
|
+
return writeItem(output);
|
|
339
|
+
}
|
|
340
|
+
|
|
341
|
+
uint32_t TDebugProtocol::writeBinary(const string& str) {
|
|
342
|
+
// XXX Hex?
|
|
343
|
+
return TDebugProtocol::writeString(str);
|
|
344
|
+
}
|
|
345
|
+
|
|
346
|
+
}}} // apache::thrift::protocol
|