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,147 @@
|
|
|
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
|
+
module Thrift.Protocol.Binary
|
|
21
|
+
( module Thrift.Protocol
|
|
22
|
+
, BinaryProtocol(..)
|
|
23
|
+
) where
|
|
24
|
+
|
|
25
|
+
import Control.Exception ( throw )
|
|
26
|
+
|
|
27
|
+
import Data.Bits
|
|
28
|
+
import Data.Int
|
|
29
|
+
import Data.List ( foldl' )
|
|
30
|
+
|
|
31
|
+
import GHC.Exts
|
|
32
|
+
import GHC.Word
|
|
33
|
+
|
|
34
|
+
import Thrift.Protocol
|
|
35
|
+
import Thrift.Transport
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
version_mask = 0xffff0000
|
|
39
|
+
version_1 = 0x80010000
|
|
40
|
+
|
|
41
|
+
data BinaryProtocol a = Transport a => BinaryProtocol a
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
instance Protocol BinaryProtocol where
|
|
45
|
+
getTransport (BinaryProtocol t) = t
|
|
46
|
+
|
|
47
|
+
writeMessageBegin p (n, t, s) = do
|
|
48
|
+
writeI32 p (version_1 .|. (fromEnum t))
|
|
49
|
+
writeString p n
|
|
50
|
+
writeI32 p s
|
|
51
|
+
writeMessageEnd _ = return ()
|
|
52
|
+
|
|
53
|
+
writeStructBegin _ _ = return ()
|
|
54
|
+
writeStructEnd _ = return ()
|
|
55
|
+
writeFieldBegin p (_, t, i) = writeType p t >> writeI16 p i
|
|
56
|
+
writeFieldEnd _ = return ()
|
|
57
|
+
writeFieldStop p = writeType p T_STOP
|
|
58
|
+
writeMapBegin p (k, v, n) = writeType p k >> writeType p v >> writeI32 p n
|
|
59
|
+
writeMapEnd p = return ()
|
|
60
|
+
writeListBegin p (t, n) = writeType p t >> writeI32 p n
|
|
61
|
+
writeListEnd _ = return ()
|
|
62
|
+
writeSetBegin p (t, n) = writeType p t >> writeI32 p n
|
|
63
|
+
writeSetEnd _ = return ()
|
|
64
|
+
|
|
65
|
+
writeBool p b = tWrite (getTransport p) [toEnum $ if b then 1 else 0]
|
|
66
|
+
writeByte p b = tWrite (getTransport p) (getBytes b 1)
|
|
67
|
+
writeI16 p b = tWrite (getTransport p) (getBytes b 2)
|
|
68
|
+
writeI32 p b = tWrite (getTransport p) (getBytes b 4)
|
|
69
|
+
writeI64 p b = tWrite (getTransport p) (getBytes b 8)
|
|
70
|
+
writeDouble p d = writeI64 p (fromIntegral $ floatBits d)
|
|
71
|
+
writeString p s = writeI32 p (length s) >> tWrite (getTransport p) s
|
|
72
|
+
writeBinary = writeString
|
|
73
|
+
|
|
74
|
+
readMessageBegin p = do
|
|
75
|
+
ver <- readI32 p
|
|
76
|
+
if (ver .&. version_mask /= version_1)
|
|
77
|
+
then throw $ ProtocolExn PE_BAD_VERSION "Missing version identifier"
|
|
78
|
+
else do
|
|
79
|
+
s <- readString p
|
|
80
|
+
sz <- readI32 p
|
|
81
|
+
return (s, toEnum $ ver .&. 0xFF, sz)
|
|
82
|
+
readMessageEnd _ = return ()
|
|
83
|
+
readStructBegin _ = return ""
|
|
84
|
+
readStructEnd _ = return ()
|
|
85
|
+
readFieldBegin p = do
|
|
86
|
+
t <- readType p
|
|
87
|
+
n <- if t /= T_STOP then readI16 p else return 0
|
|
88
|
+
return ("", t, n)
|
|
89
|
+
readFieldEnd _ = return ()
|
|
90
|
+
readMapBegin p = do
|
|
91
|
+
kt <- readType p
|
|
92
|
+
vt <- readType p
|
|
93
|
+
n <- readI32 p
|
|
94
|
+
return (kt, vt, n)
|
|
95
|
+
readMapEnd _ = return ()
|
|
96
|
+
readListBegin p = do
|
|
97
|
+
t <- readType p
|
|
98
|
+
n <- readI32 p
|
|
99
|
+
return (t, n)
|
|
100
|
+
readListEnd _ = return ()
|
|
101
|
+
readSetBegin p = do
|
|
102
|
+
t <- readType p
|
|
103
|
+
n <- readI32 p
|
|
104
|
+
return (t, n)
|
|
105
|
+
readSetEnd _ = return ()
|
|
106
|
+
|
|
107
|
+
readBool p = (== 1) `fmap` readByte p
|
|
108
|
+
readByte p = do
|
|
109
|
+
bs <- tReadAll (getTransport p) 1
|
|
110
|
+
return $ fromIntegral (composeBytes bs :: Int8)
|
|
111
|
+
readI16 p = do
|
|
112
|
+
bs <- tReadAll (getTransport p) 2
|
|
113
|
+
return $ fromIntegral (composeBytes bs :: Int16)
|
|
114
|
+
readI32 p = composeBytes `fmap` tReadAll (getTransport p) 4
|
|
115
|
+
readI64 p = composeBytes `fmap` tReadAll (getTransport p) 8
|
|
116
|
+
readDouble p = do
|
|
117
|
+
bs <- readI64 p
|
|
118
|
+
return $ floatOfBits $ fromIntegral bs
|
|
119
|
+
readString p = readI32 p >>= tReadAll (getTransport p)
|
|
120
|
+
readBinary = readString
|
|
121
|
+
|
|
122
|
+
|
|
123
|
+
-- | Write a type as a byte
|
|
124
|
+
writeType :: (Protocol p, Transport t) => p t -> ThriftType -> IO ()
|
|
125
|
+
writeType p t = writeByte p (fromEnum t)
|
|
126
|
+
|
|
127
|
+
-- | Read a byte as though it were a ThriftType
|
|
128
|
+
readType :: (Protocol p, Transport t) => p t -> IO ThriftType
|
|
129
|
+
readType p = toEnum `fmap` readByte p
|
|
130
|
+
|
|
131
|
+
composeBytes :: (Bits b, Enum t) => [t] -> b
|
|
132
|
+
composeBytes = (foldl' fn 0) . (map $ fromIntegral . fromEnum)
|
|
133
|
+
where fn acc b = (acc `shiftL` 8) .|. b
|
|
134
|
+
|
|
135
|
+
getByte :: Bits a => a -> Int -> a
|
|
136
|
+
getByte i n = 255 .&. (i `shiftR` (8 * n))
|
|
137
|
+
|
|
138
|
+
getBytes :: (Bits a, Integral a) => a -> Int -> String
|
|
139
|
+
getBytes i 0 = []
|
|
140
|
+
getBytes i n = (toEnum $ fromIntegral $ getByte i (n-1)):(getBytes i (n-1))
|
|
141
|
+
|
|
142
|
+
floatBits :: Double -> Word64
|
|
143
|
+
floatBits (D# d#) = W64# (unsafeCoerce# d#)
|
|
144
|
+
|
|
145
|
+
floatOfBits :: Word64 -> Double
|
|
146
|
+
floatOfBits (W64# b#) = D# (unsafeCoerce# b#)
|
|
147
|
+
|
|
@@ -0,0 +1,65 @@
|
|
|
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
|
+
module Thrift.Server
|
|
21
|
+
( runBasicServer
|
|
22
|
+
, runThreadedServer
|
|
23
|
+
) where
|
|
24
|
+
|
|
25
|
+
import Control.Concurrent ( forkIO )
|
|
26
|
+
import Control.Exception
|
|
27
|
+
import Control.Monad ( forever, when )
|
|
28
|
+
|
|
29
|
+
import Network
|
|
30
|
+
|
|
31
|
+
import System.IO
|
|
32
|
+
|
|
33
|
+
import Thrift
|
|
34
|
+
import Thrift.Transport.Handle
|
|
35
|
+
import Thrift.Protocol.Binary
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
-- | A threaded sever that is capable of using any Transport or Protocol
|
|
39
|
+
-- instances.
|
|
40
|
+
runThreadedServer :: (Transport t, Protocol i, Protocol o)
|
|
41
|
+
=> (Socket -> IO (i t, o t))
|
|
42
|
+
-> h
|
|
43
|
+
-> (h -> (i t, o t) -> IO Bool)
|
|
44
|
+
-> PortID
|
|
45
|
+
-> IO a
|
|
46
|
+
runThreadedServer accepter hand proc port = do
|
|
47
|
+
socket <- listenOn port
|
|
48
|
+
acceptLoop (accepter socket) (proc hand)
|
|
49
|
+
|
|
50
|
+
-- | A basic threaded binary protocol socket server.
|
|
51
|
+
runBasicServer :: h
|
|
52
|
+
-> (h -> (BinaryProtocol Handle, BinaryProtocol Handle) -> IO Bool)
|
|
53
|
+
-> PortNumber
|
|
54
|
+
-> IO a
|
|
55
|
+
runBasicServer hand proc port = runThreadedServer binaryAccept hand proc (PortNumber port)
|
|
56
|
+
where binaryAccept s = do
|
|
57
|
+
(h, _, _) <- accept s
|
|
58
|
+
return (BinaryProtocol h, BinaryProtocol h)
|
|
59
|
+
|
|
60
|
+
acceptLoop :: IO t -> (t -> IO Bool) -> IO a
|
|
61
|
+
acceptLoop accepter proc = forever $
|
|
62
|
+
do ps <- accepter
|
|
63
|
+
forkIO $ handle (\(e :: SomeException) -> return ())
|
|
64
|
+
(loop $ proc ps)
|
|
65
|
+
where loop m = do { continue <- m; when continue (loop m) }
|
|
@@ -0,0 +1,60 @@
|
|
|
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
|
+
module Thrift.Transport
|
|
21
|
+
( Transport(..)
|
|
22
|
+
, TransportExn(..)
|
|
23
|
+
, TransportExnType(..)
|
|
24
|
+
) where
|
|
25
|
+
|
|
26
|
+
import Control.Monad ( when )
|
|
27
|
+
import Control.Exception ( Exception, throw )
|
|
28
|
+
|
|
29
|
+
import Data.Typeable ( Typeable )
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
class Transport a where
|
|
33
|
+
tIsOpen :: a -> IO Bool
|
|
34
|
+
tClose :: a -> IO ()
|
|
35
|
+
tRead :: a -> Int -> IO String
|
|
36
|
+
tWrite :: a -> String ->IO ()
|
|
37
|
+
tFlush :: a -> IO ()
|
|
38
|
+
tReadAll :: a -> Int -> IO String
|
|
39
|
+
|
|
40
|
+
tReadAll a 0 = return []
|
|
41
|
+
tReadAll a len = do
|
|
42
|
+
result <- tRead a len
|
|
43
|
+
let rlen = length result
|
|
44
|
+
when (rlen == 0) (throw $ TransportExn "Cannot read. Remote side has closed." TE_UNKNOWN)
|
|
45
|
+
if len <= rlen
|
|
46
|
+
then return result
|
|
47
|
+
else (result ++) `fmap` (tReadAll a (len - rlen))
|
|
48
|
+
|
|
49
|
+
data TransportExn = TransportExn String TransportExnType
|
|
50
|
+
deriving ( Show, Typeable )
|
|
51
|
+
instance Exception TransportExn
|
|
52
|
+
|
|
53
|
+
data TransportExnType
|
|
54
|
+
= TE_UNKNOWN
|
|
55
|
+
| TE_NOT_OPEN
|
|
56
|
+
| TE_ALREADY_OPEN
|
|
57
|
+
| TE_TIMED_OUT
|
|
58
|
+
| TE_END_OF_FILE
|
|
59
|
+
deriving ( Eq, Show, Typeable )
|
|
60
|
+
|
|
@@ -0,0 +1,58 @@
|
|
|
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
|
+
module Thrift.Transport.Handle
|
|
21
|
+
( module Thrift.Transport
|
|
22
|
+
, HandleSource(..)
|
|
23
|
+
) where
|
|
24
|
+
|
|
25
|
+
import Control.Exception ( throw )
|
|
26
|
+
import Control.Monad ( replicateM )
|
|
27
|
+
|
|
28
|
+
import Network
|
|
29
|
+
|
|
30
|
+
import System.IO
|
|
31
|
+
import System.IO.Error ( isEOFError )
|
|
32
|
+
|
|
33
|
+
import Thrift.Transport
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
instance Transport Handle where
|
|
37
|
+
tIsOpen = hIsOpen
|
|
38
|
+
tClose h = hClose h
|
|
39
|
+
tRead h n = replicateM n (hGetChar h) `catch` handleEOF
|
|
40
|
+
tWrite h s = mapM_ (hPutChar h) s
|
|
41
|
+
tFlush = hFlush
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
-- | Type class for all types that can open a Handle. This class is used to
|
|
45
|
+
-- replace tOpen in the Transport type class.
|
|
46
|
+
class HandleSource s where
|
|
47
|
+
hOpen :: s -> IO Handle
|
|
48
|
+
|
|
49
|
+
instance HandleSource FilePath where
|
|
50
|
+
hOpen s = openFile s ReadWriteMode
|
|
51
|
+
|
|
52
|
+
instance HandleSource (HostName, PortID) where
|
|
53
|
+
hOpen = uncurry connectTo
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
handleEOF e = if isEOFError e
|
|
57
|
+
then return []
|
|
58
|
+
else throw $ TransportExn "TChannelTransport: Could not read" TE_UNKNOWN
|
|
@@ -0,0 +1,38 @@
|
|
|
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
|
+
EXTRA_DIST = build.xml ivy.xml src test
|
|
21
|
+
|
|
22
|
+
export CLASSPATH
|
|
23
|
+
|
|
24
|
+
all-local:
|
|
25
|
+
$(ANT) $(ANT_FLAGS)
|
|
26
|
+
|
|
27
|
+
install-exec-hook:
|
|
28
|
+
$(ANT) $(ANT_FLAGS) install -Dinstall.path=$(DESTDIR)$(JAVA_PREFIX) \
|
|
29
|
+
-Dinstall.javadoc.path=$(DESTDIR)$(docdir)/java
|
|
30
|
+
|
|
31
|
+
# Make sure this doesn't fail if ant is not configured.
|
|
32
|
+
clean-local:
|
|
33
|
+
ANT=$(ANT) ; if test -z "$$ANT" ; then ANT=: ; fi ; \
|
|
34
|
+
$$ANT $(ANT_FLAGS) clean
|
|
35
|
+
|
|
36
|
+
check-local: all
|
|
37
|
+
$(ANT) $(ANT_FLAGS) test
|
|
38
|
+
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
Thrift Java Software Library
|
|
2
|
+
|
|
3
|
+
License
|
|
4
|
+
=======
|
|
5
|
+
|
|
6
|
+
Licensed to the Apache Software Foundation (ASF) under one
|
|
7
|
+
or more contributor license agreements. See the NOTICE file
|
|
8
|
+
distributed with this work for additional information
|
|
9
|
+
regarding copyright ownership. The ASF licenses this file
|
|
10
|
+
to you under the Apache License, Version 2.0 (the
|
|
11
|
+
"License"); you may not use this file except in compliance
|
|
12
|
+
with the License. You may obtain a copy of the License at
|
|
13
|
+
|
|
14
|
+
http://www.apache.org/licenses/LICENSE-2.0
|
|
15
|
+
|
|
16
|
+
Unless required by applicable law or agreed to in writing,
|
|
17
|
+
software distributed under the License is distributed on an
|
|
18
|
+
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
19
|
+
KIND, either express or implied. See the License for the
|
|
20
|
+
specific language governing permissions and limitations
|
|
21
|
+
under the License.
|
|
22
|
+
|
|
23
|
+
Using Thrift with Java
|
|
24
|
+
======================
|
|
25
|
+
|
|
26
|
+
The Thrift Java source is not build using the GNU tools, but rather uses
|
|
27
|
+
the Apache Ant build system, which tends to be predominant amongst Java
|
|
28
|
+
developers.
|
|
29
|
+
|
|
30
|
+
To compile the Java Thrift libraries, simply do the following:
|
|
31
|
+
|
|
32
|
+
ant
|
|
33
|
+
|
|
34
|
+
Yep, that's easy. Look for libthrift.jar in the base directory.
|
|
35
|
+
|
|
36
|
+
To include Thrift in your applications simply add libthrift.jar to your
|
|
37
|
+
classpath, or install if in your default system classpath of choice.
|
|
38
|
+
|
|
39
|
+
Dependencies
|
|
40
|
+
============
|
|
41
|
+
|
|
42
|
+
Apache Ant
|
|
43
|
+
http://ant.apache.org/
|
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
<?xml version="1.0"?>
|
|
2
|
+
<!--
|
|
3
|
+
Licensed to the Apache Software Foundation (ASF) under one
|
|
4
|
+
or more contributor license agreements. See the NOTICE file
|
|
5
|
+
distributed with this work for additional information
|
|
6
|
+
regarding copyright ownership. The ASF licenses this file
|
|
7
|
+
to you under the Apache License, Version 2.0 (the
|
|
8
|
+
"License"); you may not use this file except in compliance
|
|
9
|
+
with the License. You may obtain a copy of the License at
|
|
10
|
+
|
|
11
|
+
http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
+
|
|
13
|
+
Unless required by applicable law or agreed to in writing,
|
|
14
|
+
software distributed under the License is distributed on an
|
|
15
|
+
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
16
|
+
KIND, either express or implied. See the License for the
|
|
17
|
+
specific language governing permissions and limitations
|
|
18
|
+
under the License.
|
|
19
|
+
-->
|
|
20
|
+
<project name="libthrift" default="dist" basedir="."
|
|
21
|
+
xmlns:ivy="antlib:org.apache.ivy.ant">
|
|
22
|
+
|
|
23
|
+
<description>Thrift Build File</description>
|
|
24
|
+
|
|
25
|
+
<property environment="env" />
|
|
26
|
+
|
|
27
|
+
<property name="gen" location="gen-java" />
|
|
28
|
+
<property name="genbean" location="gen-javabean" />
|
|
29
|
+
|
|
30
|
+
<property name="src" location="src" />
|
|
31
|
+
<property name="build" location="build" />
|
|
32
|
+
<property name="javadoc" location="${build}/javadoc" />
|
|
33
|
+
<property name="install.path" value="/usr/local/lib" />
|
|
34
|
+
<property name="src.test" location="test" />
|
|
35
|
+
<property name="build.test" location="${build}/test" />
|
|
36
|
+
<property name="test.thrift.home" location="../../test"/>
|
|
37
|
+
|
|
38
|
+
<property file="${user.home}/.thrift-build.properties" />
|
|
39
|
+
|
|
40
|
+
<!-- ivy properties -->
|
|
41
|
+
<property name="ivy.version" value="2.0.0-rc2" />
|
|
42
|
+
<property name="ivy.dir" location="${build}/ivy" />
|
|
43
|
+
<property name="ivy.jar" location="${ivy.dir}/ivy-${ivy.version}.jar"/>
|
|
44
|
+
<property name="ivy.lib.dir" location="${ivy.dir}/lib" />
|
|
45
|
+
<property name="ivy_repo_url" value="http://repo2.maven.org/maven2/org/apache/ivy/ivy/${ivy.version}/ivy-${ivy.version}.jar"/>
|
|
46
|
+
<property name="ivysettings.xml" location="${ivy.dir}/ivysettings.xml" />
|
|
47
|
+
|
|
48
|
+
<path id="compile.classpath">
|
|
49
|
+
<fileset dir="${ivy.lib.dir}">
|
|
50
|
+
<include name="**/*.jar" />
|
|
51
|
+
</fileset>
|
|
52
|
+
</path>
|
|
53
|
+
|
|
54
|
+
<path id="test.classpath">
|
|
55
|
+
<path refid="compile.classpath" />
|
|
56
|
+
<pathelement path="${env.CLASSPATH}" />
|
|
57
|
+
<pathelement location="build/test" />
|
|
58
|
+
<pathelement location="libthrift.jar" />
|
|
59
|
+
</path>
|
|
60
|
+
|
|
61
|
+
<target name="init">
|
|
62
|
+
<tstamp />
|
|
63
|
+
<mkdir dir="${build}"/>
|
|
64
|
+
<mkdir dir="${build.test}" />
|
|
65
|
+
<!--
|
|
66
|
+
Allow Ivy to be disabled with "-Dnoivy=".
|
|
67
|
+
It is kind of a hack to pretend that we already found it,
|
|
68
|
+
but Ant doesn't provide an easy way of blocking dependencies
|
|
69
|
+
from executing or checking multiple conditions.
|
|
70
|
+
-->
|
|
71
|
+
<condition property="ivy.found"><isset property="noivy" /></condition>
|
|
72
|
+
<condition property="offline"><isset property="noivy" /></condition>
|
|
73
|
+
</target>
|
|
74
|
+
|
|
75
|
+
<target name="ivy-init-dirs">
|
|
76
|
+
<mkdir dir="${ivy.dir}" />
|
|
77
|
+
<mkdir dir="${ivy.lib.dir}" />
|
|
78
|
+
</target>
|
|
79
|
+
|
|
80
|
+
<target name="ivy-download" depends="ivy-init-dirs" description="To download ivy" unless="offline">
|
|
81
|
+
<get src="${ivy_repo_url}" dest="${ivy.jar}" usetimestamp="true"/>
|
|
82
|
+
</target>
|
|
83
|
+
|
|
84
|
+
<target name="ivy-probe-antlib">
|
|
85
|
+
<condition property="ivy.found">
|
|
86
|
+
<typefound uri="antlib:org.apache.ivy.ant" name="cleancache"/>
|
|
87
|
+
</condition>
|
|
88
|
+
</target>
|
|
89
|
+
|
|
90
|
+
<target name="ivy-init-antlib" depends="ivy-download,ivy-probe-antlib" unless="ivy.found">
|
|
91
|
+
<typedef uri="antlib:org.apache.ivy.ant" onerror="fail"
|
|
92
|
+
loaderRef="ivyLoader">
|
|
93
|
+
<classpath>
|
|
94
|
+
<pathelement location="${ivy.jar}"/>
|
|
95
|
+
</classpath>
|
|
96
|
+
</typedef>
|
|
97
|
+
<fail>
|
|
98
|
+
<condition >
|
|
99
|
+
<not>
|
|
100
|
+
<typefound uri="antlib:org.apache.ivy.ant" name="cleancache"/>
|
|
101
|
+
</not>
|
|
102
|
+
</condition>
|
|
103
|
+
You need Apache Ivy 2.0 or later from http://ant.apache.org/
|
|
104
|
+
It could not be loaded from ${ivy_repo_url}
|
|
105
|
+
</fail>
|
|
106
|
+
</target>
|
|
107
|
+
|
|
108
|
+
<target name="resolve" depends="ivy-init-antlib" description="retrieve dependencies with ivy" unless="noivy">
|
|
109
|
+
<ivy:retrieve />
|
|
110
|
+
</target>
|
|
111
|
+
|
|
112
|
+
<target name="compile" depends="init,resolve">
|
|
113
|
+
<javac srcdir="${src}" destdir="${build}" source="1.5" target="1.5" debug="true" classpathref="compile.classpath" />
|
|
114
|
+
</target>
|
|
115
|
+
|
|
116
|
+
<target name="javadoc" depends="init">
|
|
117
|
+
<javadoc sourcepath="${src}"
|
|
118
|
+
destdir="${javadoc}"
|
|
119
|
+
version="true"
|
|
120
|
+
windowtitle="Thrift Java API"
|
|
121
|
+
doctitle="Thrift Java API">
|
|
122
|
+
</javadoc>
|
|
123
|
+
</target>
|
|
124
|
+
|
|
125
|
+
<target name="dist" depends="compile">
|
|
126
|
+
<jar jarfile="libthrift.jar">
|
|
127
|
+
<fileset dir="${build}">
|
|
128
|
+
<include name="**/*.class" />
|
|
129
|
+
</fileset>
|
|
130
|
+
<fileset dir="src">
|
|
131
|
+
<include name="**/*.java" />
|
|
132
|
+
</fileset>
|
|
133
|
+
</jar>
|
|
134
|
+
</target>
|
|
135
|
+
|
|
136
|
+
<target name="install" depends="dist,javadoc">
|
|
137
|
+
<copy todir="${install.path}">
|
|
138
|
+
<fileset dir="."><include name="*.jar" /></fileset>
|
|
139
|
+
</copy>
|
|
140
|
+
<copy todir="${install.javadoc.path}">
|
|
141
|
+
<fileset dir="${javadoc}">
|
|
142
|
+
<include name="**/*" />
|
|
143
|
+
</fileset>
|
|
144
|
+
</copy>
|
|
145
|
+
</target>
|
|
146
|
+
|
|
147
|
+
<target name="clean">
|
|
148
|
+
<delete dir="${build}" />
|
|
149
|
+
<delete dir="${gen}"/>
|
|
150
|
+
<delete dir="${genbean}"/>
|
|
151
|
+
<delete dir="${javadoc}"/>
|
|
152
|
+
<delete file="libthrift.jar" />
|
|
153
|
+
</target>
|
|
154
|
+
|
|
155
|
+
<target name="compile-test" description="Build the test suite classes" depends="generate,dist">
|
|
156
|
+
<javac debug="true" srcdir="${gen}" destdir="${build.test}" classpathref="test.classpath" />
|
|
157
|
+
<javac debug="true" srcdir="${genbean}" destdir="${build.test}" classpathref="test.classpath" />
|
|
158
|
+
<javac debug="true" srcdir="${src.test}" destdir="${build.test}" classpathref="test.classpath" />
|
|
159
|
+
</target>
|
|
160
|
+
|
|
161
|
+
<target name="test" description="Run the full test suite" depends="compile-test">
|
|
162
|
+
<java classname="org.apache.thrift.test.JSONProtoTest"
|
|
163
|
+
classpathref="test.classpath" failonerror="true" />
|
|
164
|
+
<java classname="org.apache.thrift.test.TCompactProtocolTest"
|
|
165
|
+
classpathref="test.classpath" failonerror="true" />
|
|
166
|
+
<java classname="org.apache.thrift.test.IdentityTest"
|
|
167
|
+
classpathref="test.classpath" failonerror="true" />
|
|
168
|
+
<java classname="org.apache.thrift.test.EqualityTest"
|
|
169
|
+
classpathref="test.classpath" failonerror="true" />
|
|
170
|
+
<java classname="org.apache.thrift.test.ToStringTest"
|
|
171
|
+
classpathref="test.classpath" failonerror="true" />
|
|
172
|
+
<java classname="org.apache.thrift.test.DeepCopyTest"
|
|
173
|
+
classpathref="test.classpath" failonerror="true" />
|
|
174
|
+
<java classname="org.apache.thrift.test.MetaDataTest"
|
|
175
|
+
classpathref="test.classpath" failonerror="true" />
|
|
176
|
+
<java classname="org.apache.thrift.test.JavaBeansTest"
|
|
177
|
+
classpathref="test.classpath" failonerror="true" />
|
|
178
|
+
</target>
|
|
179
|
+
|
|
180
|
+
<target name="generate">
|
|
181
|
+
<exec executable="../../compiler/cpp/thrift">
|
|
182
|
+
<arg line="--gen java:hashcode ${test.thrift.home}/ThriftTest.thrift" />
|
|
183
|
+
</exec>
|
|
184
|
+
<exec executable="../../compiler/cpp/thrift">
|
|
185
|
+
<arg line="--gen java:hashcode ${test.thrift.home}/DebugProtoTest.thrift" />
|
|
186
|
+
</exec>
|
|
187
|
+
<exec executable="../../compiler/cpp/thrift">
|
|
188
|
+
<arg line="--gen java:hashcode ${test.thrift.home}/OptionalRequiredTest.thrift" />
|
|
189
|
+
</exec>
|
|
190
|
+
<exec executable="../../compiler/cpp/thrift">
|
|
191
|
+
<arg line="--gen java:beans,nocamel ${test.thrift.home}/JavaBeansTest.thrift" />
|
|
192
|
+
</exec>
|
|
193
|
+
</target>
|
|
194
|
+
|
|
195
|
+
</project>
|