couchbase 3.0.0 → 3.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (901) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1 -1
  3. data/ext/CMakeLists.txt +86 -169
  4. data/ext/build_version.hxx.in +3 -2
  5. data/ext/cmake/Backtrace.cmake +35 -0
  6. data/ext/cmake/BuildTracing.cmake +6 -0
  7. data/ext/cmake/Cache.cmake +29 -0
  8. data/ext/cmake/CompilerWarnings.cmake +78 -0
  9. data/ext/cmake/PreventInSourceBuilds.cmake +18 -0
  10. data/ext/cmake/Sanitizers.cmake +66 -0
  11. data/ext/cmake/StandardProjectSettings.cmake +40 -0
  12. data/ext/cmake/StaticAnalyzers.cmake +37 -0
  13. data/ext/cmake/Testing.cmake +52 -0
  14. data/ext/cmake/ThirdPartyDependencies.cmake +20 -0
  15. data/ext/cmake/VersionInfo.cmake +37 -0
  16. data/ext/couchbase/bucket.hxx +37 -12
  17. data/ext/couchbase/capabilities.hxx +117 -0
  18. data/ext/couchbase/cbcrypto/cbcrypto.cc +15 -15
  19. data/ext/couchbase/cluster.hxx +34 -2
  20. data/ext/couchbase/cluster_options.hxx +1 -0
  21. data/ext/couchbase/configuration.hxx +228 -52
  22. data/ext/couchbase/couchbase.cxx +914 -35
  23. data/ext/couchbase/diagnostics.hxx +251 -0
  24. data/ext/couchbase/document_id.hxx +3 -1
  25. data/ext/couchbase/errors.hxx +10 -1
  26. data/ext/couchbase/io/http_command.hxx +11 -7
  27. data/ext/couchbase/io/http_context.hxx +37 -0
  28. data/ext/couchbase/io/http_message.hxx +9 -0
  29. data/ext/couchbase/io/http_parser.hxx +2 -0
  30. data/ext/couchbase/io/http_session.hxx +100 -14
  31. data/ext/couchbase/io/http_session_manager.hxx +65 -5
  32. data/ext/couchbase/io/mcbp_command.hxx +16 -7
  33. data/ext/couchbase/io/mcbp_session.hxx +193 -51
  34. data/ext/couchbase/io/query_cache.hxx +61 -0
  35. data/ext/couchbase/io/retry_context.hxx +1 -2
  36. data/ext/couchbase/io/retry_orchestrator.hxx +16 -0
  37. data/ext/couchbase/io/retry_strategy.hxx +1 -1
  38. data/ext/couchbase/io/streams.hxx +61 -10
  39. data/ext/couchbase/operations.hxx +13 -0
  40. data/ext/couchbase/operations/analytics_dataset_create.hxx +1 -1
  41. data/ext/couchbase/operations/analytics_dataset_drop.hxx +1 -1
  42. data/ext/couchbase/operations/analytics_dataset_get_all.hxx +1 -1
  43. data/ext/couchbase/operations/analytics_dataverse_create.hxx +1 -1
  44. data/ext/couchbase/operations/analytics_dataverse_drop.hxx +1 -1
  45. data/ext/couchbase/operations/analytics_get_pending_mutations.hxx +1 -1
  46. data/ext/couchbase/operations/analytics_index_create.hxx +1 -1
  47. data/ext/couchbase/operations/analytics_index_drop.hxx +1 -1
  48. data/ext/couchbase/operations/analytics_index_get_all.hxx +1 -1
  49. data/ext/couchbase/operations/analytics_link_connect.hxx +1 -1
  50. data/ext/couchbase/operations/analytics_link_disconnect.hxx +1 -1
  51. data/ext/couchbase/operations/bucket_create.hxx +11 -5
  52. data/ext/couchbase/operations/bucket_drop.hxx +1 -1
  53. data/ext/couchbase/operations/bucket_flush.hxx +1 -1
  54. data/ext/couchbase/operations/bucket_get.hxx +1 -1
  55. data/ext/couchbase/operations/bucket_get_all.hxx +1 -1
  56. data/ext/couchbase/operations/bucket_settings.hxx +43 -4
  57. data/ext/couchbase/operations/bucket_update.hxx +11 -5
  58. data/ext/couchbase/operations/cluster_developer_preview_enable.hxx +1 -1
  59. data/ext/couchbase/operations/collection_create.hxx +3 -1
  60. data/ext/couchbase/operations/collection_drop.hxx +1 -1
  61. data/ext/couchbase/operations/collections_manifest_get.hxx +70 -0
  62. data/ext/couchbase/operations/document_analytics.hxx +6 -1
  63. data/ext/couchbase/operations/document_get_projected.hxx +1 -1
  64. data/ext/couchbase/operations/document_query.hxx +85 -8
  65. data/ext/couchbase/operations/document_search.hxx +14 -4
  66. data/ext/couchbase/operations/document_view.hxx +1 -1
  67. data/ext/couchbase/operations/group_drop.hxx +71 -0
  68. data/ext/couchbase/operations/group_get.hxx +75 -0
  69. data/ext/couchbase/operations/group_get_all.hxx +70 -0
  70. data/ext/couchbase/operations/group_upsert.hxx +118 -0
  71. data/ext/couchbase/operations/query_index_build_deferred.hxx +1 -1
  72. data/ext/couchbase/operations/query_index_create.hxx +1 -1
  73. data/ext/couchbase/operations/query_index_drop.hxx +1 -1
  74. data/ext/couchbase/operations/query_index_get_all.hxx +3 -2
  75. data/ext/couchbase/operations/rbac.hxx +276 -0
  76. data/ext/couchbase/operations/role_get_all.hxx +70 -0
  77. data/ext/couchbase/operations/scope_create.hxx +6 -2
  78. data/ext/couchbase/operations/scope_drop.hxx +1 -1
  79. data/ext/couchbase/operations/scope_get_all.hxx +1 -1
  80. data/ext/couchbase/operations/search_get_stats.hxx +59 -0
  81. data/ext/couchbase/operations/search_index_analyze_document.hxx +1 -1
  82. data/ext/couchbase/operations/search_index_control_ingest.hxx +1 -1
  83. data/ext/couchbase/operations/search_index_control_plan_freeze.hxx +1 -1
  84. data/ext/couchbase/operations/search_index_control_query.hxx +1 -1
  85. data/ext/couchbase/operations/search_index_drop.hxx +1 -1
  86. data/ext/couchbase/operations/search_index_get.hxx +1 -1
  87. data/ext/couchbase/operations/search_index_get_all.hxx +1 -1
  88. data/ext/couchbase/operations/search_index_get_documents_count.hxx +24 -16
  89. data/ext/couchbase/operations/search_index_get_stats.hxx +81 -0
  90. data/ext/couchbase/operations/search_index_upsert.hxx +1 -1
  91. data/ext/couchbase/operations/user_drop.hxx +72 -0
  92. data/ext/couchbase/operations/user_get.hxx +76 -0
  93. data/ext/couchbase/operations/user_get_all.hxx +71 -0
  94. data/ext/couchbase/operations/user_upsert.hxx +125 -0
  95. data/ext/couchbase/operations/view_index_drop.hxx +1 -1
  96. data/ext/couchbase/operations/view_index_get.hxx +1 -1
  97. data/ext/couchbase/operations/view_index_get_all.hxx +1 -1
  98. data/ext/couchbase/operations/view_index_upsert.hxx +1 -1
  99. data/ext/couchbase/origin.hxx +4 -4
  100. data/ext/couchbase/platform/terminate_handler.cc +5 -4
  101. data/ext/couchbase/protocol/client_opcode.hxx +38 -38
  102. data/ext/couchbase/protocol/client_response.hxx +2 -2
  103. data/ext/couchbase/protocol/cmd_cluster_map_change_notification.hxx +6 -3
  104. data/ext/couchbase/protocol/cmd_get_cluster_config.hxx +3 -1
  105. data/ext/couchbase/protocol/magic.hxx +6 -6
  106. data/ext/couchbase/protocol/server_opcode.hxx +2 -2
  107. data/ext/couchbase/protocol/status.hxx +57 -57
  108. data/ext/couchbase/service_type.hxx +1 -1
  109. data/ext/couchbase/utils/connection_string.hxx +12 -3
  110. data/ext/couchbase/version.hxx +1 -1
  111. data/ext/extconf.rb +21 -9
  112. data/ext/test/test_helper.hxx +141 -0
  113. data/ext/test/test_helper_native.hxx +59 -0
  114. data/ext/test/test_helper_ruby.hxx +72 -0
  115. data/ext/test/test_native_diagnostics.cxx +385 -0
  116. data/ext/test/test_native_trivial_crud.cxx +83 -0
  117. data/ext/test/test_ruby_trivial_crud.cxx +35 -0
  118. data/ext/test/test_ruby_trivial_query.cxx +34 -0
  119. data/ext/third_party/asio/asio/include/asio.hpp +35 -0
  120. data/ext/third_party/asio/asio/include/asio/any_io_executor.hpp +71 -0
  121. data/ext/third_party/asio/asio/include/asio/associated_allocator.hpp +1 -7
  122. data/ext/third_party/asio/asio/include/asio/associated_executor.hpp +36 -19
  123. data/ext/third_party/asio/asio/include/asio/async_result.hpp +1 -8
  124. data/ext/third_party/asio/asio/include/asio/awaitable.hpp +14 -4
  125. data/ext/third_party/asio/asio/include/asio/basic_datagram_socket.hpp +12 -7
  126. data/ext/third_party/asio/asio/include/asio/basic_deadline_timer.hpp +4 -4
  127. data/ext/third_party/asio/asio/include/asio/basic_raw_socket.hpp +11 -7
  128. data/ext/third_party/asio/asio/include/asio/basic_seq_packet_socket.hpp +9 -4
  129. data/ext/third_party/asio/asio/include/asio/basic_serial_port.hpp +6 -6
  130. data/ext/third_party/asio/asio/include/asio/basic_signal_set.hpp +4 -4
  131. data/ext/third_party/asio/asio/include/asio/basic_socket.hpp +5 -5
  132. data/ext/third_party/asio/asio/include/asio/basic_socket_acceptor.hpp +13 -7
  133. data/ext/third_party/asio/asio/include/asio/basic_stream_socket.hpp +7 -3
  134. data/ext/third_party/asio/asio/include/asio/basic_waitable_timer.hpp +52 -4
  135. data/ext/third_party/asio/asio/include/asio/bind_executor.hpp +10 -15
  136. data/ext/third_party/asio/asio/include/asio/buffer.hpp +6 -4
  137. data/ext/third_party/asio/asio/include/asio/co_spawn.hpp +380 -9
  138. data/ext/third_party/asio/asio/include/asio/defer.hpp +4 -1
  139. data/ext/third_party/asio/asio/include/asio/detached.hpp +50 -0
  140. data/ext/third_party/asio/asio/include/asio/detail/atomic_count.hpp +19 -0
  141. data/ext/third_party/asio/asio/include/asio/detail/bind_handler.hpp +144 -26
  142. data/ext/third_party/asio/asio/include/asio/detail/blocking_executor_op.hpp +107 -0
  143. data/ext/third_party/asio/asio/include/asio/detail/buffer_sequence_adapter.hpp +106 -0
  144. data/ext/third_party/asio/asio/include/asio/detail/bulk_executor_op.hpp +88 -0
  145. data/ext/third_party/asio/asio/include/asio/detail/completion_handler.hpp +10 -5
  146. data/ext/third_party/asio/asio/include/asio/detail/conditionally_enabled_event.hpp +8 -0
  147. data/ext/third_party/asio/asio/include/asio/detail/config.hpp +360 -37
  148. data/ext/third_party/asio/asio/include/asio/detail/deadline_timer_service.hpp +17 -2
  149. data/ext/third_party/asio/asio/include/asio/detail/descriptor_ops.hpp +24 -6
  150. data/ext/third_party/asio/asio/include/asio/detail/descriptor_read_op.hpp +32 -14
  151. data/ext/third_party/asio/asio/include/asio/detail/descriptor_write_op.hpp +32 -14
  152. data/ext/third_party/asio/asio/include/asio/detail/executor_function.hpp +133 -34
  153. data/ext/third_party/asio/asio/include/asio/detail/handler_alloc_helpers.hpp +42 -0
  154. data/ext/third_party/asio/asio/include/asio/detail/handler_invoke_helpers.hpp +23 -0
  155. data/ext/third_party/asio/asio/include/asio/detail/handler_tracking.hpp +26 -0
  156. data/ext/third_party/asio/asio/include/asio/detail/handler_work.hpp +370 -45
  157. data/ext/third_party/asio/asio/include/asio/detail/impl/descriptor_ops.ipp +208 -74
  158. data/ext/third_party/asio/asio/include/asio/detail/impl/handler_tracking.ipp +39 -1
  159. data/ext/third_party/asio/asio/include/asio/detail/impl/reactive_serial_port_service.ipp +12 -15
  160. data/ext/third_party/asio/asio/include/asio/detail/impl/scheduler.ipp +37 -0
  161. data/ext/third_party/asio/asio/include/asio/detail/impl/signal_set_service.ipp +2 -1
  162. data/ext/third_party/asio/asio/include/asio/detail/impl/socket_ops.ipp +661 -274
  163. data/ext/third_party/asio/asio/include/asio/detail/impl/strand_executor_service.hpp +210 -4
  164. data/ext/third_party/asio/asio/include/asio/detail/impl/strand_service.hpp +8 -9
  165. data/ext/third_party/asio/asio/include/asio/detail/impl/strand_service.ipp +5 -4
  166. data/ext/third_party/asio/asio/include/asio/detail/impl/win_iocp_io_context.ipp +15 -6
  167. data/ext/third_party/asio/asio/include/asio/detail/io_object_impl.hpp +32 -50
  168. data/ext/third_party/asio/asio/include/asio/detail/memory.hpp +3 -0
  169. data/ext/third_party/asio/asio/include/asio/detail/null_event.hpp +6 -0
  170. data/ext/third_party/asio/asio/include/asio/detail/pop_options.hpp +1 -1
  171. data/ext/third_party/asio/asio/include/asio/detail/posix_event.hpp +13 -0
  172. data/ext/third_party/asio/asio/include/asio/detail/push_options.hpp +1 -1
  173. data/ext/third_party/asio/asio/include/asio/detail/reactive_descriptor_service.hpp +38 -13
  174. data/ext/third_party/asio/asio/include/asio/detail/reactive_null_buffers_op.hpp +12 -6
  175. data/ext/third_party/asio/asio/include/asio/detail/reactive_serial_port_service.hpp +2 -3
  176. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_accept_op.hpp +36 -24
  177. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_connect_op.hpp +17 -10
  178. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_recv_op.hpp +38 -16
  179. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_recvfrom_op.hpp +36 -14
  180. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_recvmsg_op.hpp +21 -11
  181. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_send_op.hpp +43 -17
  182. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_sendto_op.hpp +39 -17
  183. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_service.hpp +44 -21
  184. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_service_base.hpp +41 -18
  185. data/ext/third_party/asio/asio/include/asio/detail/reactive_wait_op.hpp +12 -6
  186. data/ext/third_party/asio/asio/include/asio/detail/reactor_op.hpp +3 -1
  187. data/ext/third_party/asio/asio/include/asio/detail/resolve_endpoint_op.hpp +10 -8
  188. data/ext/third_party/asio/asio/include/asio/detail/resolve_query_op.hpp +11 -9
  189. data/ext/third_party/asio/asio/include/asio/detail/scheduler.hpp +8 -0
  190. data/ext/third_party/asio/asio/include/asio/detail/signal_handler.hpp +7 -5
  191. data/ext/third_party/asio/asio/include/asio/detail/socket_ops.hpp +46 -0
  192. data/ext/third_party/asio/asio/include/asio/detail/source_location.hpp +45 -0
  193. data/ext/third_party/asio/asio/include/asio/detail/std_event.hpp +12 -0
  194. data/ext/third_party/asio/asio/include/asio/detail/strand_executor_service.hpp +25 -1
  195. data/ext/third_party/asio/asio/include/asio/detail/strand_service.hpp +4 -1
  196. data/ext/third_party/asio/asio/include/asio/detail/thread_info_base.hpp +58 -0
  197. data/ext/third_party/asio/asio/include/asio/detail/type_traits.hpp +59 -0
  198. data/ext/third_party/asio/asio/include/asio/detail/variadic_templates.hpp +144 -1
  199. data/ext/third_party/asio/asio/include/asio/detail/wait_handler.hpp +9 -6
  200. data/ext/third_party/asio/asio/include/asio/detail/win_event.hpp +13 -0
  201. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_handle_read_op.hpp +9 -5
  202. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_handle_write_op.hpp +9 -5
  203. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_io_context.hpp +5 -1
  204. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_null_buffers_op.hpp +10 -6
  205. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_overlapped_op.hpp +9 -5
  206. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_overlapped_ptr.hpp +18 -6
  207. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_accept_op.hpp +15 -11
  208. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_connect_op.hpp +10 -5
  209. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_recv_op.hpp +8 -4
  210. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_recvfrom_op.hpp +8 -4
  211. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_recvmsg_op.hpp +8 -4
  212. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_send_op.hpp +8 -4
  213. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_wait_op.hpp +10 -5
  214. data/ext/third_party/asio/asio/include/asio/detail/winrt_resolve_op.hpp +8 -4
  215. data/ext/third_party/asio/asio/include/asio/detail/winrt_socket_connect_op.hpp +8 -4
  216. data/ext/third_party/asio/asio/include/asio/detail/winrt_socket_recv_op.hpp +8 -4
  217. data/ext/third_party/asio/asio/include/asio/detail/winrt_socket_send_op.hpp +8 -4
  218. data/ext/third_party/asio/asio/include/asio/detail/work_dispatcher.hpp +81 -6
  219. data/ext/third_party/asio/asio/include/asio/detail/wrapped_handler.hpp +45 -9
  220. data/ext/third_party/asio/asio/include/asio/dispatch.hpp +4 -1
  221. data/ext/third_party/asio/asio/include/asio/execution.hpp +48 -0
  222. data/ext/third_party/asio/asio/include/asio/execution/allocator.hpp +249 -0
  223. data/ext/third_party/asio/asio/include/asio/execution/any_executor.hpp +2264 -0
  224. data/ext/third_party/asio/asio/include/asio/execution/bad_executor.hpp +47 -0
  225. data/ext/third_party/asio/asio/include/asio/execution/blocking.hpp +1351 -0
  226. data/ext/third_party/asio/asio/include/asio/execution/blocking_adaptation.hpp +1064 -0
  227. data/ext/third_party/asio/asio/include/asio/execution/bulk_execute.hpp +390 -0
  228. data/ext/third_party/asio/asio/include/asio/execution/bulk_guarantee.hpp +1018 -0
  229. data/ext/third_party/asio/asio/include/asio/execution/connect.hpp +486 -0
  230. data/ext/third_party/asio/asio/include/asio/execution/context.hpp +185 -0
  231. data/ext/third_party/asio/asio/include/asio/execution/context_as.hpp +201 -0
  232. data/ext/third_party/asio/asio/include/asio/execution/detail/as_invocable.hpp +152 -0
  233. data/ext/third_party/asio/asio/include/asio/execution/detail/as_operation.hpp +105 -0
  234. data/ext/third_party/asio/asio/include/asio/execution/detail/as_receiver.hpp +128 -0
  235. data/ext/third_party/asio/asio/include/asio/execution/detail/bulk_sender.hpp +261 -0
  236. data/ext/third_party/asio/asio/include/asio/execution/detail/submit_receiver.hpp +233 -0
  237. data/ext/third_party/asio/asio/include/asio/execution/detail/void_receiver.hpp +90 -0
  238. data/ext/third_party/asio/asio/include/asio/execution/execute.hpp +264 -0
  239. data/ext/third_party/asio/asio/include/asio/execution/executor.hpp +238 -0
  240. data/ext/third_party/asio/asio/include/asio/execution/impl/bad_executor.ipp +40 -0
  241. data/ext/third_party/asio/asio/include/asio/execution/impl/receiver_invocation_error.ipp +36 -0
  242. data/ext/third_party/asio/asio/include/asio/execution/invocable_archetype.hpp +71 -0
  243. data/ext/third_party/asio/asio/include/asio/execution/mapping.hpp +917 -0
  244. data/ext/third_party/asio/asio/include/asio/execution/occupancy.hpp +178 -0
  245. data/ext/third_party/asio/asio/include/asio/execution/operation_state.hpp +94 -0
  246. data/ext/third_party/asio/asio/include/asio/execution/outstanding_work.hpp +721 -0
  247. data/ext/third_party/asio/asio/include/asio/execution/prefer_only.hpp +327 -0
  248. data/ext/third_party/asio/asio/include/asio/execution/receiver.hpp +280 -0
  249. data/ext/third_party/asio/asio/include/asio/execution/receiver_invocation_error.hpp +48 -0
  250. data/ext/third_party/asio/asio/include/asio/execution/relationship.hpp +720 -0
  251. data/ext/third_party/asio/asio/include/asio/execution/schedule.hpp +290 -0
  252. data/ext/third_party/asio/asio/include/asio/execution/scheduler.hpp +86 -0
  253. data/ext/third_party/asio/asio/include/asio/execution/sender.hpp +311 -0
  254. data/ext/third_party/asio/asio/include/asio/execution/set_done.hpp +253 -0
  255. data/ext/third_party/asio/asio/include/asio/execution/set_error.hpp +253 -0
  256. data/ext/third_party/asio/asio/include/asio/execution/set_value.hpp +486 -0
  257. data/ext/third_party/asio/asio/include/asio/execution/start.hpp +250 -0
  258. data/ext/third_party/asio/asio/include/asio/execution/submit.hpp +450 -0
  259. data/ext/third_party/asio/asio/include/asio/executor.hpp +7 -1
  260. data/ext/third_party/asio/asio/include/asio/executor_work_guard.hpp +126 -9
  261. data/ext/third_party/asio/asio/include/asio/handler_alloc_hook.hpp +28 -5
  262. data/ext/third_party/asio/asio/include/asio/handler_invoke_hook.hpp +29 -3
  263. data/ext/third_party/asio/asio/include/asio/impl/awaitable.hpp +14 -0
  264. data/ext/third_party/asio/asio/include/asio/impl/buffered_read_stream.hpp +44 -8
  265. data/ext/third_party/asio/asio/include/asio/impl/buffered_write_stream.hpp +44 -8
  266. data/ext/third_party/asio/asio/include/asio/impl/co_spawn.hpp +145 -7
  267. data/ext/third_party/asio/asio/include/asio/impl/compose.hpp +124 -22
  268. data/ext/third_party/asio/asio/include/asio/impl/connect.hpp +52 -8
  269. data/ext/third_party/asio/asio/include/asio/impl/defer.hpp +147 -12
  270. data/ext/third_party/asio/asio/include/asio/impl/dispatch.hpp +142 -12
  271. data/ext/third_party/asio/asio/include/asio/impl/executor.hpp +15 -101
  272. data/ext/third_party/asio/asio/include/asio/impl/executor.ipp +5 -0
  273. data/ext/third_party/asio/asio/include/asio/impl/handler_alloc_hook.ipp +13 -4
  274. data/ext/third_party/asio/asio/include/asio/impl/io_context.hpp +144 -57
  275. data/ext/third_party/asio/asio/include/asio/impl/multiple_exceptions.ipp +49 -0
  276. data/ext/third_party/asio/asio/include/asio/impl/post.hpp +147 -12
  277. data/ext/third_party/asio/asio/include/asio/impl/read.hpp +85 -18
  278. data/ext/third_party/asio/asio/include/asio/impl/read_at.hpp +59 -14
  279. data/ext/third_party/asio/asio/include/asio/impl/read_until.hpp +241 -56
  280. data/ext/third_party/asio/asio/include/asio/impl/redirect_error.hpp +22 -4
  281. data/ext/third_party/asio/asio/include/asio/impl/spawn.hpp +58 -22
  282. data/ext/third_party/asio/asio/include/asio/impl/src.hpp +3 -0
  283. data/ext/third_party/asio/asio/include/asio/impl/system_context.ipp +16 -4
  284. data/ext/third_party/asio/asio/include/asio/impl/system_executor.hpp +113 -12
  285. data/ext/third_party/asio/asio/include/asio/impl/thread_pool.hpp +260 -37
  286. data/ext/third_party/asio/asio/include/asio/impl/thread_pool.ipp +61 -7
  287. data/ext/third_party/asio/asio/include/asio/impl/use_awaitable.hpp +5 -2
  288. data/ext/third_party/asio/asio/include/asio/impl/use_future.hpp +147 -6
  289. data/ext/third_party/asio/asio/include/asio/impl/write.hpp +75 -14
  290. data/ext/third_party/asio/asio/include/asio/impl/write_at.hpp +53 -11
  291. data/ext/third_party/asio/asio/include/asio/io_context.hpp +706 -48
  292. data/ext/third_party/asio/asio/include/asio/io_context_strand.hpp +3 -1
  293. data/ext/third_party/asio/asio/include/asio/ip/basic_resolver.hpp +4 -4
  294. data/ext/third_party/asio/asio/include/asio/is_applicable_property.hpp +61 -0
  295. data/ext/third_party/asio/asio/include/asio/multiple_exceptions.hpp +58 -0
  296. data/ext/third_party/asio/asio/include/asio/posix/basic_descriptor.hpp +4 -4
  297. data/ext/third_party/asio/asio/include/asio/posix/basic_stream_descriptor.hpp +5 -5
  298. data/ext/third_party/asio/asio/include/asio/post.hpp +4 -1
  299. data/ext/third_party/asio/asio/include/asio/prefer.hpp +656 -0
  300. data/ext/third_party/asio/asio/include/asio/query.hpp +296 -0
  301. data/ext/third_party/asio/asio/include/asio/read_until.hpp +6 -6
  302. data/ext/third_party/asio/asio/include/asio/require.hpp +524 -0
  303. data/ext/third_party/asio/asio/include/asio/require_concept.hpp +310 -0
  304. data/ext/third_party/asio/asio/include/asio/spawn.hpp +12 -4
  305. data/ext/third_party/asio/asio/include/asio/ssl/detail/buffered_handshake_op.hpp +5 -0
  306. data/ext/third_party/asio/asio/include/asio/ssl/detail/engine.hpp +5 -0
  307. data/ext/third_party/asio/asio/include/asio/ssl/detail/handshake_op.hpp +5 -0
  308. data/ext/third_party/asio/asio/include/asio/ssl/detail/impl/engine.ipp +16 -3
  309. data/ext/third_party/asio/asio/include/asio/ssl/detail/io.hpp +38 -4
  310. data/ext/third_party/asio/asio/include/asio/ssl/detail/read_op.hpp +5 -0
  311. data/ext/third_party/asio/asio/include/asio/ssl/detail/shutdown_op.hpp +5 -0
  312. data/ext/third_party/asio/asio/include/asio/ssl/detail/stream_core.hpp +36 -2
  313. data/ext/third_party/asio/asio/include/asio/ssl/detail/write_op.hpp +10 -1
  314. data/ext/third_party/asio/asio/include/asio/ssl/stream.hpp +15 -0
  315. data/ext/third_party/asio/asio/include/asio/static_thread_pool.hpp +31 -0
  316. data/ext/third_party/asio/asio/include/asio/strand.hpp +232 -9
  317. data/ext/third_party/asio/asio/include/asio/system_context.hpp +12 -3
  318. data/ext/third_party/asio/asio/include/asio/system_executor.hpp +557 -24
  319. data/ext/third_party/asio/asio/include/asio/thread_pool.hpp +913 -37
  320. data/ext/third_party/asio/asio/include/asio/traits/bulk_execute_free.hpp +114 -0
  321. data/ext/third_party/asio/asio/include/asio/traits/bulk_execute_member.hpp +114 -0
  322. data/ext/third_party/asio/asio/include/asio/traits/connect_free.hpp +112 -0
  323. data/ext/third_party/asio/asio/include/asio/traits/connect_member.hpp +112 -0
  324. data/ext/third_party/asio/asio/include/asio/traits/equality_comparable.hpp +100 -0
  325. data/ext/third_party/asio/asio/include/asio/traits/execute_free.hpp +108 -0
  326. data/ext/third_party/asio/asio/include/asio/traits/execute_member.hpp +108 -0
  327. data/ext/third_party/asio/asio/include/asio/traits/prefer_free.hpp +108 -0
  328. data/ext/third_party/asio/asio/include/asio/traits/prefer_member.hpp +108 -0
  329. data/ext/third_party/asio/asio/include/asio/traits/query_free.hpp +108 -0
  330. data/ext/third_party/asio/asio/include/asio/traits/query_member.hpp +108 -0
  331. data/ext/third_party/asio/asio/include/asio/traits/query_static_constexpr_member.hpp +108 -0
  332. data/ext/third_party/asio/asio/include/asio/traits/require_concept_free.hpp +108 -0
  333. data/ext/third_party/asio/asio/include/asio/traits/require_concept_member.hpp +108 -0
  334. data/ext/third_party/asio/asio/include/asio/traits/require_free.hpp +108 -0
  335. data/ext/third_party/asio/asio/include/asio/traits/require_member.hpp +108 -0
  336. data/ext/third_party/asio/asio/include/asio/traits/schedule_free.hpp +108 -0
  337. data/ext/third_party/asio/asio/include/asio/traits/schedule_member.hpp +108 -0
  338. data/ext/third_party/asio/asio/include/asio/traits/set_done_free.hpp +108 -0
  339. data/ext/third_party/asio/asio/include/asio/traits/set_done_member.hpp +108 -0
  340. data/ext/third_party/asio/asio/include/asio/traits/set_error_free.hpp +112 -0
  341. data/ext/third_party/asio/asio/include/asio/traits/set_error_member.hpp +112 -0
  342. data/ext/third_party/asio/asio/include/asio/traits/set_value_free.hpp +234 -0
  343. data/ext/third_party/asio/asio/include/asio/traits/set_value_member.hpp +234 -0
  344. data/ext/third_party/asio/asio/include/asio/traits/start_free.hpp +108 -0
  345. data/ext/third_party/asio/asio/include/asio/traits/start_member.hpp +108 -0
  346. data/ext/third_party/asio/asio/include/asio/traits/static_query.hpp +108 -0
  347. data/ext/third_party/asio/asio/include/asio/traits/static_require.hpp +123 -0
  348. data/ext/third_party/asio/asio/include/asio/traits/static_require_concept.hpp +123 -0
  349. data/ext/third_party/asio/asio/include/asio/traits/submit_free.hpp +112 -0
  350. data/ext/third_party/asio/asio/include/asio/traits/submit_member.hpp +112 -0
  351. data/ext/third_party/asio/asio/include/asio/ts/executor.hpp +1 -0
  352. data/ext/third_party/asio/asio/include/asio/ts/netfwd.hpp +67 -8
  353. data/ext/third_party/asio/asio/include/asio/use_awaitable.hpp +63 -4
  354. data/ext/third_party/asio/asio/include/asio/version.hpp +1 -1
  355. data/ext/third_party/asio/asio/include/asio/windows/basic_object_handle.hpp +4 -4
  356. data/ext/third_party/asio/asio/include/asio/windows/basic_overlapped_handle.hpp +2 -2
  357. data/ext/third_party/asio/asio/include/asio/windows/basic_random_access_handle.hpp +5 -5
  358. data/ext/third_party/asio/asio/include/asio/windows/basic_stream_handle.hpp +5 -5
  359. data/ext/third_party/asio/asio/include/asio/windows/overlapped_ptr.hpp +4 -2
  360. data/ext/third_party/gsl/CMakeLists.txt +13 -5
  361. data/ext/third_party/gsl/include/gsl/gsl_assert +1 -1
  362. data/ext/third_party/gsl/include/gsl/gsl_byte +3 -3
  363. data/ext/third_party/gsl/include/gsl/gsl_narrow +52 -0
  364. data/ext/third_party/gsl/include/gsl/gsl_util +8 -50
  365. data/ext/third_party/gsl/include/gsl/multi_span +0 -10
  366. data/ext/third_party/gsl/include/gsl/pointers +14 -28
  367. data/ext/third_party/gsl/include/gsl/span +98 -46
  368. data/ext/third_party/gsl/include/gsl/string_span +37 -47
  369. data/ext/third_party/http_parser/http_parser.c +17 -10
  370. data/ext/third_party/http_parser/http_parser.h +4 -2
  371. data/ext/third_party/json/include/tao/json/basic_value.hpp +3 -2
  372. data/ext/third_party/json/include/tao/json/binary.hpp +4 -4
  373. data/ext/third_party/json/include/tao/json/binary_view.hpp +2 -2
  374. data/ext/third_party/json/include/tao/json/binding.hpp +2 -2
  375. data/ext/third_party/json/include/tao/json/binding/factory.hpp +8 -7
  376. data/ext/third_party/json/include/tao/json/binding/internal/array.hpp +2 -1
  377. data/ext/third_party/json/include/tao/json/binding/internal/object.hpp +6 -5
  378. data/ext/third_party/json/include/tao/json/binding/versions.hpp +3 -1
  379. data/ext/third_party/json/include/tao/json/cbor.hpp +1 -0
  380. data/ext/third_party/json/include/tao/json/cbor/consume_file.hpp +7 -7
  381. data/ext/third_party/json/include/tao/json/cbor/events/from_binary.hpp +43 -0
  382. data/ext/third_party/json/include/tao/json/cbor/events/from_file.hpp +4 -4
  383. data/ext/third_party/json/include/tao/json/cbor/events/from_string.hpp +3 -3
  384. data/ext/third_party/json/include/tao/json/cbor/from_binary.hpp +32 -0
  385. data/ext/third_party/json/include/tao/json/cbor/from_file.hpp +5 -5
  386. data/ext/third_party/json/include/tao/json/cbor/internal/grammar.hpp +2 -1
  387. data/ext/third_party/json/include/tao/json/consume_file.hpp +7 -7
  388. data/ext/third_party/json/include/tao/json/contrib/internal/indirect_traits.hpp +13 -6
  389. data/ext/third_party/json/include/tao/json/contrib/position.hpp +15 -15
  390. data/ext/third_party/json/include/tao/json/contrib/reference.hpp +5 -7
  391. data/ext/third_party/json/include/tao/json/contrib/schema.hpp +58 -35
  392. data/ext/third_party/json/include/tao/json/contrib/shared_ptr_traits.hpp +12 -4
  393. data/ext/third_party/json/include/tao/json/contrib/unique_ptr_traits.hpp +12 -4
  394. data/ext/third_party/json/include/tao/json/contrib/unordered_map_traits.hpp +1 -1
  395. data/ext/third_party/json/include/tao/json/contrib/unordered_set_traits.hpp +2 -2
  396. data/ext/third_party/json/include/tao/json/events/compare.hpp +2 -12
  397. data/ext/third_party/json/include/tao/json/events/from_file.hpp +4 -4
  398. data/ext/third_party/json/include/tao/json/events/from_string.hpp +2 -2
  399. data/ext/third_party/json/include/tao/json/events/invalid_string_to_binary.hpp +1 -1
  400. data/ext/third_party/json/include/tao/json/events/key_camel_case_to_snake_case.hpp +3 -3
  401. data/ext/third_party/json/include/tao/json/events/key_snake_case_to_camel_case.hpp +1 -1
  402. data/ext/third_party/json/include/tao/json/events/tee.hpp +2 -2
  403. data/ext/third_party/json/include/tao/json/events/to_pretty_stream.hpp +1 -1
  404. data/ext/third_party/json/include/tao/json/events/to_stream.hpp +1 -1
  405. data/ext/third_party/json/include/tao/json/events/transformer.hpp +3 -3
  406. data/ext/third_party/json/include/tao/json/events/validate_event_order.hpp +3 -3
  407. data/ext/third_party/json/include/tao/json/events/virtual_ref.hpp +6 -0
  408. data/ext/third_party/json/include/tao/json/external/pegtl.hpp +4 -13
  409. data/ext/third_party/json/include/tao/json/external/pegtl/argv_input.hpp +3 -5
  410. data/ext/third_party/json/include/tao/json/external/pegtl/ascii.hpp +5 -18
  411. data/ext/third_party/json/include/tao/json/external/pegtl/buffer_input.hpp +3 -3
  412. data/ext/third_party/json/include/tao/json/external/pegtl/change_action.hpp +2 -2
  413. data/ext/third_party/json/include/tao/json/external/pegtl/change_action_and_state.hpp +6 -6
  414. data/ext/third_party/json/include/tao/json/external/pegtl/change_action_and_states.hpp +5 -5
  415. data/ext/third_party/json/include/tao/json/external/pegtl/change_control.hpp +2 -2
  416. data/ext/third_party/json/include/tao/json/external/pegtl/change_state.hpp +6 -6
  417. data/ext/third_party/json/include/tao/json/external/pegtl/change_states.hpp +5 -5
  418. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/alphabet.hpp +52 -52
  419. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/analyze.hpp +176 -0
  420. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/analyze_traits.hpp +275 -0
  421. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/control_action.hpp +77 -0
  422. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/coverage.hpp +151 -0
  423. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/forward.hpp +16 -0
  424. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/http.hpp +37 -18
  425. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/icu/internal.hpp +20 -22
  426. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/icu/utf16.hpp +6 -10
  427. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/icu/utf32.hpp +6 -10
  428. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/icu/utf8.hpp +2 -4
  429. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/if_then.hpp +11 -10
  430. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/integer.hpp +116 -131
  431. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/endian.hpp +4 -4
  432. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/endian_gcc.hpp +2 -2
  433. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/endian_win.hpp +2 -2
  434. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/peek_mask_uint.hpp +9 -9
  435. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/peek_mask_uint8.hpp +9 -10
  436. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/peek_uint.hpp +9 -9
  437. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/peek_uint8.hpp +9 -10
  438. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/peek_utf16.hpp +10 -10
  439. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/peek_utf32.hpp +9 -9
  440. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/read_uint.hpp +3 -3
  441. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/internal/set_stack_guard.hpp +52 -0
  442. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/parse_tree.hpp +80 -201
  443. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/parse_tree_to_dot.hpp +11 -10
  444. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/print.hpp +75 -0
  445. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/print_coverage.hpp +53 -0
  446. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/raw_string.hpp +45 -36
  447. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/remove_first_state.hpp +33 -50
  448. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/remove_last_states.hpp +117 -0
  449. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/rep_one_min_max.hpp +43 -11
  450. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/rep_string.hpp +1 -2
  451. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/shuffle_states.hpp +193 -0
  452. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/state_control.hpp +118 -0
  453. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/trace.hpp +227 -0
  454. data/ext/third_party/json/include/tao/json/external/pegtl/{uint16.hpp → contrib/uint16.hpp} +5 -5
  455. data/ext/third_party/json/include/tao/json/external/pegtl/{uint32.hpp → contrib/uint32.hpp} +5 -5
  456. data/ext/third_party/json/include/tao/json/external/pegtl/{uint64.hpp → contrib/uint64.hpp} +5 -5
  457. data/ext/third_party/json/include/tao/json/external/pegtl/{uint8.hpp → contrib/uint8.hpp} +5 -5
  458. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/unescape.hpp +14 -14
  459. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/uri.hpp +1 -1
  460. data/ext/third_party/json/include/tao/json/external/pegtl/{utf16.hpp → contrib/utf16.hpp} +5 -5
  461. data/ext/third_party/json/include/tao/json/external/pegtl/{utf32.hpp → contrib/utf32.hpp} +5 -5
  462. data/ext/third_party/json/include/tao/json/external/pegtl/cstream_input.hpp +2 -3
  463. data/ext/third_party/json/include/tao/json/external/pegtl/{internal/demangle.hpp → demangle.hpp} +12 -14
  464. data/ext/third_party/json/include/tao/json/external/pegtl/disable_action.hpp +2 -2
  465. data/ext/third_party/json/include/tao/json/external/pegtl/discard_input.hpp +2 -2
  466. data/ext/third_party/json/include/tao/json/external/pegtl/discard_input_on_failure.hpp +2 -2
  467. data/ext/third_party/json/include/tao/json/external/pegtl/discard_input_on_success.hpp +2 -2
  468. data/ext/third_party/json/include/tao/json/external/pegtl/enable_action.hpp +2 -2
  469. data/ext/third_party/json/include/tao/json/external/pegtl/file_input.hpp +1 -1
  470. data/ext/third_party/json/include/tao/json/external/pegtl/internal/action.hpp +19 -9
  471. data/ext/third_party/json/include/tao/json/external/pegtl/internal/action_input.hpp +7 -8
  472. data/ext/third_party/json/include/tao/json/external/pegtl/internal/any.hpp +14 -14
  473. data/ext/third_party/json/include/tao/json/external/pegtl/internal/apply.hpp +9 -9
  474. data/ext/third_party/json/include/tao/json/external/pegtl/internal/apply0.hpp +8 -7
  475. data/ext/third_party/json/include/tao/json/external/pegtl/internal/apply_single.hpp +4 -4
  476. data/ext/third_party/json/include/tao/json/external/pegtl/internal/at.hpp +17 -15
  477. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bof.hpp +7 -6
  478. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bol.hpp +8 -8
  479. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bump.hpp +4 -4
  480. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bump_help.hpp +3 -3
  481. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bytes.hpp +17 -10
  482. data/ext/third_party/json/include/tao/json/external/pegtl/internal/control.hpp +19 -9
  483. data/ext/third_party/json/include/tao/json/external/pegtl/internal/cr_crlf_eol.hpp +2 -2
  484. data/ext/third_party/json/include/tao/json/external/pegtl/internal/cr_eol.hpp +2 -2
  485. data/ext/third_party/json/include/tao/json/external/pegtl/internal/crlf_eol.hpp +2 -2
  486. data/ext/third_party/json/include/tao/json/external/pegtl/internal/cstream_reader.hpp +1 -1
  487. data/ext/third_party/json/include/tao/json/external/pegtl/internal/{always_false.hpp → dependent_false.hpp} +3 -8
  488. data/ext/third_party/json/include/tao/json/external/pegtl/internal/disable.hpp +19 -9
  489. data/ext/third_party/json/include/tao/json/external/pegtl/internal/discard.hpp +7 -6
  490. data/ext/third_party/json/include/tao/json/external/pegtl/internal/enable.hpp +19 -9
  491. data/ext/third_party/json/include/tao/json/external/pegtl/internal/{skip_control.hpp → enable_control.hpp} +5 -5
  492. data/ext/third_party/json/include/tao/json/external/pegtl/internal/eof.hpp +7 -6
  493. data/ext/third_party/json/include/tao/json/external/pegtl/internal/eol.hpp +8 -7
  494. data/ext/third_party/json/include/tao/json/external/pegtl/internal/eolf.hpp +8 -7
  495. data/ext/third_party/json/include/tao/json/external/pegtl/internal/failure.hpp +32 -0
  496. data/ext/third_party/json/include/tao/json/external/pegtl/internal/file_mapper_posix.hpp +61 -10
  497. data/ext/third_party/json/include/tao/json/external/pegtl/internal/file_mapper_win32.hpp +27 -33
  498. data/ext/third_party/json/include/tao/json/external/pegtl/internal/file_reader.hpp +29 -26
  499. data/ext/third_party/json/include/tao/json/external/pegtl/internal/has_apply.hpp +3 -7
  500. data/ext/third_party/json/include/tao/json/external/pegtl/internal/has_apply0.hpp +3 -7
  501. data/ext/third_party/json/include/tao/json/external/pegtl/internal/has_match.hpp +4 -20
  502. data/ext/third_party/json/include/tao/json/external/pegtl/internal/has_unwind.hpp +21 -0
  503. data/ext/third_party/json/include/tao/json/external/pegtl/internal/if_apply.hpp +8 -7
  504. data/ext/third_party/json/include/tao/json/external/pegtl/internal/if_must.hpp +8 -9
  505. data/ext/third_party/json/include/tao/json/external/pegtl/internal/if_must_else.hpp +2 -0
  506. data/ext/third_party/json/include/tao/json/external/pegtl/internal/if_then_else.hpp +7 -7
  507. data/ext/third_party/json/include/tao/json/external/pegtl/internal/istream_reader.hpp +1 -2
  508. data/ext/third_party/json/include/tao/json/external/pegtl/internal/istring.hpp +11 -11
  509. data/ext/third_party/json/include/tao/json/external/pegtl/internal/iterator.hpp +7 -10
  510. data/ext/third_party/json/include/tao/json/external/pegtl/internal/lf_crlf_eol.hpp +2 -2
  511. data/ext/third_party/json/include/tao/json/external/pegtl/internal/lf_eol.hpp +2 -2
  512. data/ext/third_party/json/include/tao/json/external/pegtl/internal/list_tail.hpp +4 -2
  513. data/ext/third_party/json/include/tao/json/external/pegtl/internal/list_tail_pad.hpp +1 -1
  514. data/ext/third_party/json/include/tao/json/external/pegtl/internal/marker.hpp +3 -5
  515. data/ext/third_party/json/include/tao/json/external/pegtl/internal/minus.hpp +21 -0
  516. data/ext/third_party/json/include/tao/json/external/pegtl/internal/missing_apply.hpp +5 -2
  517. data/ext/third_party/json/include/tao/json/external/pegtl/internal/missing_apply0.hpp +5 -2
  518. data/ext/third_party/json/include/tao/json/external/pegtl/internal/must.hpp +16 -24
  519. data/ext/third_party/json/include/tao/json/external/pegtl/internal/not_at.hpp +17 -15
  520. data/ext/third_party/json/include/tao/json/external/pegtl/internal/one.hpp +23 -12
  521. data/ext/third_party/json/include/tao/json/external/pegtl/internal/opt.hpp +16 -16
  522. data/ext/third_party/json/include/tao/json/external/pegtl/internal/path_to_string.hpp +26 -0
  523. data/ext/third_party/json/include/tao/json/external/pegtl/internal/peek_char.hpp +5 -5
  524. data/ext/third_party/json/include/tao/json/external/pegtl/internal/peek_utf8.hpp +12 -13
  525. data/ext/third_party/json/include/tao/json/external/pegtl/internal/plus.hpp +18 -11
  526. data/ext/third_party/json/include/tao/json/external/pegtl/internal/raise.hpp +8 -17
  527. data/ext/third_party/json/include/tao/json/external/pegtl/internal/range.hpp +22 -17
  528. data/ext/third_party/json/include/tao/json/external/pegtl/internal/ranges.hpp +28 -18
  529. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rematch.hpp +12 -9
  530. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rep.hpp +26 -25
  531. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rep_min_max.hpp +23 -21
  532. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rep_opt.hpp +24 -9
  533. data/ext/third_party/json/include/tao/json/external/pegtl/internal/require.hpp +10 -10
  534. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rules.hpp +4 -4
  535. data/ext/third_party/json/include/tao/json/external/pegtl/internal/seq.hpp +18 -33
  536. data/ext/third_party/json/include/tao/json/external/pegtl/internal/sor.hpp +24 -17
  537. data/ext/third_party/json/include/tao/json/external/pegtl/internal/star.hpp +13 -8
  538. data/ext/third_party/json/include/tao/json/external/pegtl/internal/state.hpp +21 -11
  539. data/ext/third_party/json/include/tao/json/external/pegtl/internal/string.hpp +11 -11
  540. data/ext/third_party/json/include/tao/json/external/pegtl/internal/success.hpp +32 -0
  541. data/ext/third_party/json/include/tao/json/external/pegtl/internal/try_catch_type.hpp +16 -16
  542. data/ext/third_party/json/include/tao/json/external/pegtl/internal/until.hpp +18 -14
  543. data/ext/third_party/json/include/tao/json/external/pegtl/istream_input.hpp +2 -3
  544. data/ext/third_party/json/include/tao/json/external/pegtl/match.hpp +125 -29
  545. data/ext/third_party/json/include/tao/json/external/pegtl/memory_input.hpp +32 -48
  546. data/ext/third_party/json/include/tao/json/external/pegtl/mmap_input.hpp +16 -16
  547. data/ext/third_party/json/include/tao/json/external/pegtl/must_if.hpp +64 -0
  548. data/ext/third_party/json/include/tao/json/external/pegtl/normal.hpp +25 -25
  549. data/ext/third_party/json/include/tao/json/external/pegtl/nothing.hpp +1 -2
  550. data/ext/third_party/json/include/tao/json/external/pegtl/parse.hpp +6 -8
  551. data/ext/third_party/json/include/tao/json/external/pegtl/parse_error.hpp +80 -35
  552. data/ext/third_party/json/include/tao/json/external/pegtl/position.hpp +18 -10
  553. data/ext/third_party/json/include/tao/json/external/pegtl/read_input.hpp +18 -38
  554. data/ext/third_party/json/include/tao/json/external/pegtl/rules.hpp +6 -5
  555. data/ext/third_party/json/include/tao/json/external/pegtl/string_input.hpp +3 -5
  556. data/ext/third_party/json/include/tao/json/external/pegtl/type_list.hpp +46 -0
  557. data/ext/third_party/json/include/tao/json/external/pegtl/visit.hpp +66 -0
  558. data/ext/third_party/json/include/tao/json/from_file.hpp +5 -5
  559. data/ext/third_party/json/include/tao/json/internal/action.hpp +3 -3
  560. data/ext/third_party/json/include/tao/json/internal/dependent_false.hpp +14 -0
  561. data/ext/third_party/json/include/tao/json/internal/errors.hpp +17 -17
  562. data/ext/third_party/json/include/tao/json/internal/format.hpp +0 -2
  563. data/ext/third_party/json/include/tao/json/internal/grammar.hpp +17 -17
  564. data/ext/third_party/json/include/tao/json/internal/pair.hpp +1 -1
  565. data/ext/third_party/json/include/tao/json/internal/sha256.hpp +8 -8
  566. data/ext/third_party/json/include/tao/json/internal/single.hpp +1 -1
  567. data/ext/third_party/json/include/tao/json/internal/type_traits.hpp +12 -29
  568. data/ext/third_party/json/include/tao/json/jaxn/consume_file.hpp +7 -7
  569. data/ext/third_party/json/include/tao/json/jaxn/events/from_file.hpp +4 -4
  570. data/ext/third_party/json/include/tao/json/jaxn/events/from_string.hpp +2 -2
  571. data/ext/third_party/json/include/tao/json/jaxn/from_file.hpp +5 -5
  572. data/ext/third_party/json/include/tao/json/jaxn/internal/action.hpp +6 -6
  573. data/ext/third_party/json/include/tao/json/jaxn/internal/bunescape_action.hpp +2 -2
  574. data/ext/third_party/json/include/tao/json/jaxn/internal/errors.hpp +43 -43
  575. data/ext/third_party/json/include/tao/json/jaxn/internal/grammar.hpp +36 -36
  576. data/ext/third_party/json/include/tao/json/jaxn/internal/integer.hpp +10 -11
  577. data/ext/third_party/json/include/tao/json/jaxn/is_identifier.hpp +2 -2
  578. data/ext/third_party/json/include/tao/json/jaxn/parts_parser.hpp +1 -3
  579. data/ext/third_party/json/include/tao/json/message_extension.hpp +2 -2
  580. data/ext/third_party/json/include/tao/json/msgpack.hpp +1 -0
  581. data/ext/third_party/json/include/tao/json/msgpack/consume_file.hpp +7 -7
  582. data/ext/third_party/json/include/tao/json/msgpack/events/from_binary.hpp +43 -0
  583. data/ext/third_party/json/include/tao/json/msgpack/events/from_file.hpp +4 -4
  584. data/ext/third_party/json/include/tao/json/msgpack/events/from_string.hpp +4 -4
  585. data/ext/third_party/json/include/tao/json/msgpack/events/to_stream.hpp +4 -4
  586. data/ext/third_party/json/include/tao/json/msgpack/from_binary.hpp +32 -0
  587. data/ext/third_party/json/include/tao/json/msgpack/from_file.hpp +5 -5
  588. data/ext/third_party/json/include/tao/json/msgpack/internal/grammar.hpp +2 -1
  589. data/ext/third_party/json/include/tao/json/operators.hpp +0 -4
  590. data/ext/third_party/json/include/tao/json/parts_parser.hpp +3 -7
  591. data/ext/third_party/json/include/tao/json/self_contained.hpp +6 -18
  592. data/ext/third_party/json/include/tao/json/span.hpp +94 -166
  593. data/ext/third_party/json/include/tao/json/ubjson.hpp +1 -0
  594. data/ext/third_party/json/include/tao/json/ubjson/consume_file.hpp +7 -7
  595. data/ext/third_party/json/include/tao/json/ubjson/events/from_binary.hpp +43 -0
  596. data/ext/third_party/json/include/tao/json/ubjson/events/from_file.hpp +4 -4
  597. data/ext/third_party/json/include/tao/json/ubjson/events/from_string.hpp +3 -3
  598. data/ext/third_party/json/include/tao/json/ubjson/from_binary.hpp +32 -0
  599. data/ext/third_party/json/include/tao/json/ubjson/from_file.hpp +5 -5
  600. data/ext/third_party/json/include/tao/json/ubjson/internal/grammar.hpp +5 -3
  601. data/ext/third_party/json/include/tao/json/utf8.hpp +1 -1
  602. data/ext/third_party/snappy/snappy.cc +6 -2
  603. data/ext/third_party/spdlog/CMakeLists.txt +24 -57
  604. data/ext/third_party/spdlog/cmake/version.rc.in +1 -1
  605. data/ext/third_party/spdlog/include/spdlog/async.h +3 -3
  606. data/ext/third_party/spdlog/include/spdlog/cfg/argv.h +3 -4
  607. data/ext/third_party/spdlog/include/spdlog/cfg/env.h +6 -4
  608. data/ext/third_party/spdlog/include/spdlog/cfg/helpers-inl.h +22 -6
  609. data/ext/third_party/spdlog/include/spdlog/cfg/helpers.h +3 -2
  610. data/ext/third_party/spdlog/include/spdlog/common.h +1 -2
  611. data/ext/third_party/spdlog/include/spdlog/details/fmt_helper.h +9 -1
  612. data/ext/third_party/spdlog/include/spdlog/details/os.h +1 -1
  613. data/ext/third_party/spdlog/include/spdlog/details/registry-inl.h +21 -7
  614. data/ext/third_party/spdlog/include/spdlog/details/registry.h +6 -3
  615. data/ext/third_party/spdlog/include/spdlog/details/synchronous_factory.h +1 -1
  616. data/ext/third_party/spdlog/include/spdlog/details/tcp_client-windows.h +1 -1
  617. data/ext/third_party/spdlog/include/spdlog/details/tcp_client.h +8 -7
  618. data/ext/third_party/spdlog/include/spdlog/fmt/bin_to_hex.h +2 -2
  619. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/chrono.h +66 -62
  620. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/color.h +35 -37
  621. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/compile.h +173 -103
  622. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/core.h +538 -445
  623. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/format-inl.h +114 -64
  624. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/format.h +1152 -1071
  625. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/locale.h +16 -16
  626. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/os.h +450 -0
  627. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/ostream.h +37 -13
  628. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/posix.h +1 -1
  629. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/printf.h +93 -63
  630. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/ranges.h +35 -36
  631. data/ext/third_party/spdlog/include/spdlog/fmt/chrono.h +20 -0
  632. data/ext/third_party/spdlog/include/spdlog/fmt/fmt.h +2 -0
  633. data/ext/third_party/spdlog/include/spdlog/logger-inl.h +5 -1
  634. data/ext/third_party/spdlog/include/spdlog/logger.h +50 -76
  635. data/ext/third_party/spdlog/include/spdlog/pattern_formatter-inl.h +23 -8
  636. data/ext/third_party/spdlog/include/spdlog/pattern_formatter.h +3 -3
  637. data/ext/third_party/spdlog/include/spdlog/sinks/daily_file_sink.h +1 -1
  638. data/ext/third_party/spdlog/include/spdlog/sinks/msvc_sink.h +5 -5
  639. data/ext/third_party/spdlog/include/spdlog/sinks/ringbuffer_sink.h +6 -4
  640. data/ext/third_party/spdlog/include/spdlog/sinks/stdout_sinks-inl.h +32 -3
  641. data/ext/third_party/spdlog/include/spdlog/sinks/stdout_sinks.h +7 -0
  642. data/ext/third_party/spdlog/include/spdlog/sinks/wincolor_sink-inl.h +4 -14
  643. data/ext/third_party/spdlog/include/spdlog/spdlog-inl.h +11 -1
  644. data/ext/third_party/spdlog/include/spdlog/spdlog.h +23 -68
  645. data/ext/third_party/spdlog/include/spdlog/stopwatch.h +61 -0
  646. data/ext/third_party/spdlog/include/spdlog/version.h +2 -2
  647. data/ext/third_party/spdlog/src/fmt.cpp +21 -147
  648. data/lib/couchbase/cluster.rb +111 -1
  649. data/lib/couchbase/collection_options.rb +18 -1
  650. data/lib/couchbase/errors.rb +3 -0
  651. data/lib/couchbase/management/bucket_manager.rb +36 -3
  652. data/lib/couchbase/management/search_index_manager.rb +42 -1
  653. data/lib/couchbase/management/user_manager.rb +155 -48
  654. data/lib/couchbase/query_options.rb +7 -0
  655. data/lib/couchbase/scope.rb +1 -0
  656. data/lib/couchbase/search_options.rb +69 -1
  657. data/lib/couchbase/version.rb +1 -1
  658. metadata +172 -268
  659. data/.rubocop.yml +0 -227
  660. data/.rubocop_todo.yml +0 -47
  661. data/.yardopts +0 -1
  662. data/CONTRIBUTING.md +0 -110
  663. data/Gemfile +0 -37
  664. data/Rakefile +0 -51
  665. data/couchbase.gemspec +0 -79
  666. data/examples/analytics.rb +0 -236
  667. data/examples/auth.rb +0 -33
  668. data/examples/crud.rb +0 -34
  669. data/examples/managing_analytics_indexes.rb +0 -86
  670. data/examples/managing_buckets.rb +0 -61
  671. data/examples/managing_collections.rb +0 -71
  672. data/examples/managing_query_indexes.rb +0 -83
  673. data/examples/managing_search_indexes.rb +0 -77
  674. data/examples/managing_view_indexes.rb +0 -68
  675. data/examples/query.rb +0 -32
  676. data/examples/query_with_consistency.rb +0 -86
  677. data/examples/search.rb +0 -202
  678. data/examples/search_with_consistency.rb +0 -97
  679. data/examples/subdocument.rb +0 -63
  680. data/examples/view.rb +0 -59
  681. data/ext/.clang-format +0 -15
  682. data/ext/.clang-tidy +0 -22
  683. data/ext/.cmake-format.yaml +0 -8
  684. data/ext/.gitignore +0 -2
  685. data/ext/.idea/.name +0 -1
  686. data/ext/.idea/dictionaries/couchbase_terms.xml +0 -14
  687. data/ext/.idea/ext.iml +0 -2
  688. data/ext/.idea/misc.xml +0 -16
  689. data/ext/.idea/modules.xml +0 -8
  690. data/ext/.idea/vcs.xml +0 -12
  691. data/ext/test/main.cxx +0 -184
  692. data/ext/third_party/asio/.appveyor.yml +0 -107
  693. data/ext/third_party/asio/.cirrus.yml +0 -16
  694. data/ext/third_party/asio/.gitignore +0 -3
  695. data/ext/third_party/asio/.travis.yml +0 -323
  696. data/ext/third_party/asio/asio/.gitignore +0 -23
  697. data/ext/third_party/asio/asio/COPYING +0 -4
  698. data/ext/third_party/asio/asio/INSTALL +0 -5
  699. data/ext/third_party/asio/asio/LICENSE_1_0.txt +0 -23
  700. data/ext/third_party/asio/asio/Makefile.am +0 -19
  701. data/ext/third_party/asio/asio/README +0 -4
  702. data/ext/third_party/asio/asio/asio.manifest +0 -4865
  703. data/ext/third_party/asio/asio/autogen.sh +0 -55
  704. data/ext/third_party/asio/asio/boost_asio.manifest +0 -5193
  705. data/ext/third_party/asio/asio/boostify.pl +0 -603
  706. data/ext/third_party/asio/asio/configure.ac +0 -182
  707. data/ext/third_party/asio/asio/include/.gitignore +0 -2
  708. data/ext/third_party/asio/asio/include/Makefile.am +0 -484
  709. data/ext/third_party/asio/asio/include/asio/detail/io_object_executor.hpp +0 -167
  710. data/ext/third_party/asio/asio/include/asio/impl/src.cpp +0 -25
  711. data/ext/third_party/asio/asio/release.pl +0 -440
  712. data/ext/third_party/asio/asio/src/.gitignore +0 -11
  713. data/ext/third_party/asio/asio/src/Makefile.am +0 -23
  714. data/ext/third_party/asio/asio/src/Makefile.mgw +0 -204
  715. data/ext/third_party/asio/asio/src/Makefile.msc +0 -497
  716. data/ext/third_party/asio/asio/src/asio.cpp +0 -11
  717. data/ext/third_party/asio/asio/src/asio_ssl.cpp +0 -11
  718. data/ext/third_party/asio/asio/src/doc/.gitignore +0 -5
  719. data/ext/third_party/asio/asio/src/doc/Jamfile.v2 +0 -62
  720. data/ext/third_party/asio/asio/src/doc/asio.png +0 -0
  721. data/ext/third_party/asio/asio/src/doc/asio.qbk +0 -127
  722. data/ext/third_party/asio/asio/src/doc/asioref.sty +0 -90
  723. data/ext/third_party/asio/asio/src/doc/asioref.xsl +0 -94
  724. data/ext/third_party/asio/asio/src/doc/boost_bind_dox.txt +0 -5
  725. data/ext/third_party/asio/asio/src/doc/doxy2qbk.pl +0 -22
  726. data/ext/third_party/asio/asio/src/doc/examples.qbk +0 -564
  727. data/ext/third_party/asio/asio/src/doc/history.qbk +0 -1794
  728. data/ext/third_party/asio/asio/src/doc/index.xml +0 -13
  729. data/ext/third_party/asio/asio/src/doc/makepdf.pl +0 -26
  730. data/ext/third_party/asio/asio/src/doc/net_ts.qbk +0 -479
  731. data/ext/third_party/asio/asio/src/doc/noncopyable_dox.txt +0 -3
  732. data/ext/third_party/asio/asio/src/doc/overview.qbk +0 -103
  733. data/ext/third_party/asio/asio/src/doc/overview/allocation.qbk +0 -89
  734. data/ext/third_party/asio/asio/src/doc/overview/async.qbk +0 -185
  735. data/ext/third_party/asio/asio/src/doc/overview/async_op1.dot +0 -78
  736. data/ext/third_party/asio/asio/src/doc/overview/async_op1.png +0 -0
  737. data/ext/third_party/asio/asio/src/doc/overview/async_op2.dot +0 -78
  738. data/ext/third_party/asio/asio/src/doc/overview/async_op2.png +0 -0
  739. data/ext/third_party/asio/asio/src/doc/overview/basics.qbk +0 -106
  740. data/ext/third_party/asio/asio/src/doc/overview/bsd_sockets.qbk +0 -270
  741. data/ext/third_party/asio/asio/src/doc/overview/buffers.qbk +0 -163
  742. data/ext/third_party/asio/asio/src/doc/overview/concurrency_hint.qbk +0 -88
  743. data/ext/third_party/asio/asio/src/doc/overview/coroutine.qbk +0 -51
  744. data/ext/third_party/asio/asio/src/doc/overview/coroutines_ts.qbk +0 -97
  745. data/ext/third_party/asio/asio/src/doc/overview/cpp2011.qbk +0 -271
  746. data/ext/third_party/asio/asio/src/doc/overview/handler_tracking.qbk +0 -220
  747. data/ext/third_party/asio/asio/src/doc/overview/implementation.qbk +0 -305
  748. data/ext/third_party/asio/asio/src/doc/overview/iostreams.qbk +0 -72
  749. data/ext/third_party/asio/asio/src/doc/overview/line_based.qbk +0 -118
  750. data/ext/third_party/asio/asio/src/doc/overview/other_protocols.qbk +0 -94
  751. data/ext/third_party/asio/asio/src/doc/overview/posix.qbk +0 -152
  752. data/ext/third_party/asio/asio/src/doc/overview/proactor.dot +0 -100
  753. data/ext/third_party/asio/asio/src/doc/overview/proactor.png +0 -0
  754. data/ext/third_party/asio/asio/src/doc/overview/protocols.qbk +0 -149
  755. data/ext/third_party/asio/asio/src/doc/overview/rationale.qbk +0 -54
  756. data/ext/third_party/asio/asio/src/doc/overview/reactor.qbk +0 -44
  757. data/ext/third_party/asio/asio/src/doc/overview/serial_ports.qbk +0 -45
  758. data/ext/third_party/asio/asio/src/doc/overview/signals.qbk +0 -44
  759. data/ext/third_party/asio/asio/src/doc/overview/spawn.qbk +0 -102
  760. data/ext/third_party/asio/asio/src/doc/overview/ssl.qbk +0 -124
  761. data/ext/third_party/asio/asio/src/doc/overview/strands.qbk +0 -114
  762. data/ext/third_party/asio/asio/src/doc/overview/streams.qbk +0 -62
  763. data/ext/third_party/asio/asio/src/doc/overview/sync_op.dot +0 -67
  764. data/ext/third_party/asio/asio/src/doc/overview/sync_op.png +0 -0
  765. data/ext/third_party/asio/asio/src/doc/overview/threads.qbk +0 -67
  766. data/ext/third_party/asio/asio/src/doc/overview/timers.qbk +0 -52
  767. data/ext/third_party/asio/asio/src/doc/overview/windows.qbk +0 -126
  768. data/ext/third_party/asio/asio/src/doc/project-root.jam +0 -1
  769. data/ext/third_party/asio/asio/src/doc/quickref.xml +0 -561
  770. data/ext/third_party/asio/asio/src/doc/reference.dox +0 -264
  771. data/ext/third_party/asio/asio/src/doc/reference.qbk +0 -125973
  772. data/ext/third_party/asio/asio/src/doc/reference.xsl +0 -1831
  773. data/ext/third_party/asio/asio/src/doc/release_checklist.htm +0 -68
  774. data/ext/third_party/asio/asio/src/doc/requirements/AcceptHandler.qbk +0 -72
  775. data/ext/third_party/asio/asio/src/doc/requirements/AcceptableProtocol.qbk +0 -25
  776. data/ext/third_party/asio/asio/src/doc/requirements/AsyncRandomAccessReadDevice.qbk +0 -56
  777. data/ext/third_party/asio/asio/src/doc/requirements/AsyncRandomAccessWriteDevice.qbk +0 -57
  778. data/ext/third_party/asio/asio/src/doc/requirements/AsyncReadStream.qbk +0 -50
  779. data/ext/third_party/asio/asio/src/doc/requirements/AsyncWriteStream.qbk +0 -48
  780. data/ext/third_party/asio/asio/src/doc/requirements/BufferedHandshakeHandler.qbk +0 -55
  781. data/ext/third_party/asio/asio/src/doc/requirements/CompletionCondition.qbk +0 -42
  782. data/ext/third_party/asio/asio/src/doc/requirements/CompletionHandler.qbk +0 -63
  783. data/ext/third_party/asio/asio/src/doc/requirements/ConnectCondition.qbk +0 -34
  784. data/ext/third_party/asio/asio/src/doc/requirements/ConnectHandler.qbk +0 -72
  785. data/ext/third_party/asio/asio/src/doc/requirements/ConstBufferSequence.qbk +0 -53
  786. data/ext/third_party/asio/asio/src/doc/requirements/DynamicBuffer.qbk +0 -16
  787. data/ext/third_party/asio/asio/src/doc/requirements/DynamicBuffer_v1.qbk +0 -93
  788. data/ext/third_party/asio/asio/src/doc/requirements/DynamicBuffer_v2.qbk +0 -94
  789. data/ext/third_party/asio/asio/src/doc/requirements/Endpoint.qbk +0 -97
  790. data/ext/third_party/asio/asio/src/doc/requirements/EndpointSequence.qbk +0 -30
  791. data/ext/third_party/asio/asio/src/doc/requirements/ExecutionContext.qbk +0 -36
  792. data/ext/third_party/asio/asio/src/doc/requirements/Executor.qbk +0 -141
  793. data/ext/third_party/asio/asio/src/doc/requirements/GettableSerialPortOption.qbk +0 -33
  794. data/ext/third_party/asio/asio/src/doc/requirements/GettableSocketOption.qbk +0 -67
  795. data/ext/third_party/asio/asio/src/doc/requirements/Handler.qbk +0 -64
  796. data/ext/third_party/asio/asio/src/doc/requirements/HandshakeHandler.qbk +0 -72
  797. data/ext/third_party/asio/asio/src/doc/requirements/InternetProtocol.qbk +0 -47
  798. data/ext/third_party/asio/asio/src/doc/requirements/IoControlCommand.qbk +0 -34
  799. data/ext/third_party/asio/asio/src/doc/requirements/IoObjectService.qbk +0 -62
  800. data/ext/third_party/asio/asio/src/doc/requirements/IteratorConnectHandler.qbk +0 -81
  801. data/ext/third_party/asio/asio/src/doc/requirements/LegacyCompletionHandler.qbk +0 -65
  802. data/ext/third_party/asio/asio/src/doc/requirements/MoveAcceptHandler.qbk +0 -61
  803. data/ext/third_party/asio/asio/src/doc/requirements/MutableBufferSequence.qbk +0 -54
  804. data/ext/third_party/asio/asio/src/doc/requirements/ProtoAllocator.qbk +0 -19
  805. data/ext/third_party/asio/asio/src/doc/requirements/Protocol.qbk +0 -56
  806. data/ext/third_party/asio/asio/src/doc/requirements/RangeConnectHandler.qbk +0 -82
  807. data/ext/third_party/asio/asio/src/doc/requirements/ReadHandler.qbk +0 -79
  808. data/ext/third_party/asio/asio/src/doc/requirements/ResolveHandler.qbk +0 -82
  809. data/ext/third_party/asio/asio/src/doc/requirements/Service.qbk +0 -40
  810. data/ext/third_party/asio/asio/src/doc/requirements/SettableSerialPortOption.qbk +0 -33
  811. data/ext/third_party/asio/asio/src/doc/requirements/SettableSocketOption.qbk +0 -54
  812. data/ext/third_party/asio/asio/src/doc/requirements/ShutdownHandler.qbk +0 -72
  813. data/ext/third_party/asio/asio/src/doc/requirements/SignalHandler.qbk +0 -79
  814. data/ext/third_party/asio/asio/src/doc/requirements/SyncRandomAccessReadDevice.qbk +0 -49
  815. data/ext/third_party/asio/asio/src/doc/requirements/SyncRandomAccessWriteDevice.qbk +0 -49
  816. data/ext/third_party/asio/asio/src/doc/requirements/SyncReadStream.qbk +0 -41
  817. data/ext/third_party/asio/asio/src/doc/requirements/SyncWriteStream.qbk +0 -39
  818. data/ext/third_party/asio/asio/src/doc/requirements/TimeTraits.qbk +0 -72
  819. data/ext/third_party/asio/asio/src/doc/requirements/WaitHandler.qbk +0 -72
  820. data/ext/third_party/asio/asio/src/doc/requirements/WaitTraits.qbk +0 -52
  821. data/ext/third_party/asio/asio/src/doc/requirements/WriteHandler.qbk +0 -79
  822. data/ext/third_party/asio/asio/src/doc/requirements/asynchronous_operations.qbk +0 -300
  823. data/ext/third_party/asio/asio/src/doc/requirements/asynchronous_socket_operations.qbk +0 -39
  824. data/ext/third_party/asio/asio/src/doc/requirements/read_write_operations.qbk +0 -34
  825. data/ext/third_party/asio/asio/src/doc/requirements/synchronous_socket_operations.qbk +0 -37
  826. data/ext/third_party/asio/asio/src/doc/std_exception_dox.txt +0 -7
  827. data/ext/third_party/asio/asio/src/doc/tutorial.dox +0 -226
  828. data/ext/third_party/asio/asio/src/doc/tutorial.qbk +0 -2387
  829. data/ext/third_party/asio/asio/src/doc/tutorial.xsl +0 -437
  830. data/ext/third_party/asio/asio/src/doc/using.qbk +0 -309
  831. data/ext/third_party/asio/asio/tsify.pl +0 -574
  832. data/ext/third_party/gsl/.clang-format +0 -34
  833. data/ext/third_party/gsl/.github/workflows/main.yml +0 -94
  834. data/ext/third_party/gsl/.gitignore +0 -16
  835. data/ext/third_party/gsl/.travis.yml +0 -551
  836. data/ext/third_party/gsl/CMakeSettings.json +0 -18
  837. data/ext/third_party/gsl/CONTRIBUTING.md +0 -29
  838. data/ext/third_party/gsl/GSL.natvis +0 -98
  839. data/ext/third_party/gsl/README.md +0 -124
  840. data/ext/third_party/gsl/appveyor.yml +0 -128
  841. data/ext/third_party/http_parser/.gitignore +0 -30
  842. data/ext/third_party/http_parser/.mailmap +0 -8
  843. data/ext/third_party/http_parser/.travis.yml +0 -13
  844. data/ext/third_party/http_parser/AUTHORS +0 -68
  845. data/ext/third_party/http_parser/Makefile +0 -160
  846. data/ext/third_party/http_parser/README.md +0 -246
  847. data/ext/third_party/http_parser/bench.c +0 -128
  848. data/ext/third_party/http_parser/http_parser.gyp +0 -111
  849. data/ext/third_party/http_parser/test.c +0 -4600
  850. data/ext/third_party/json/.appveyor.yml +0 -44
  851. data/ext/third_party/json/.clang-format +0 -84
  852. data/ext/third_party/json/.conan/build.py +0 -80
  853. data/ext/third_party/json/.conan/test_package/CMakeLists.txt +0 -12
  854. data/ext/third_party/json/.conan/test_package/conanfile.py +0 -24
  855. data/ext/third_party/json/.conan/test_package/test_package.cpp +0 -16
  856. data/ext/third_party/json/.gitignore +0 -3
  857. data/ext/third_party/json/.travis.yml +0 -173
  858. data/ext/third_party/json/Makefile +0 -77
  859. data/ext/third_party/json/README.md +0 -149
  860. data/ext/third_party/json/conanfile.py +0 -28
  861. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/analyze_cycles.hpp +0 -127
  862. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/counted.hpp +0 -23
  863. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/generic.hpp +0 -31
  864. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/grammar_info.hpp +0 -32
  865. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/insert_guard.hpp +0 -51
  866. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/insert_rules.hpp +0 -25
  867. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/rule_info.hpp +0 -29
  868. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/rule_type.hpp +0 -21
  869. data/ext/third_party/json/include/tao/json/external/pegtl/analyze.hpp +0 -21
  870. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/counter.hpp +0 -54
  871. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/tracer.hpp +0 -158
  872. data/ext/third_party/json/include/tao/json/external/pegtl/internal/alnum.hpp +0 -18
  873. data/ext/third_party/json/include/tao/json/external/pegtl/internal/alpha.hpp +0 -18
  874. data/ext/third_party/json/include/tao/json/external/pegtl/internal/dusel_mode.hpp +0 -23
  875. data/ext/third_party/json/include/tao/json/external/pegtl/internal/duseltronik.hpp +0 -187
  876. data/ext/third_party/json/include/tao/json/external/pegtl/internal/file_opener.hpp +0 -72
  877. data/ext/third_party/json/include/tao/json/external/pegtl/internal/trivial.hpp +0 -32
  878. data/ext/third_party/snappy/.appveyor.yml +0 -36
  879. data/ext/third_party/snappy/.gitignore +0 -8
  880. data/ext/third_party/snappy/.travis.yml +0 -98
  881. data/ext/third_party/snappy/AUTHORS +0 -1
  882. data/ext/third_party/snappy/CONTRIBUTING.md +0 -26
  883. data/ext/third_party/snappy/NEWS +0 -188
  884. data/ext/third_party/snappy/README.md +0 -148
  885. data/ext/third_party/snappy/docs/README.md +0 -72
  886. data/ext/third_party/snappy/format_description.txt +0 -110
  887. data/ext/third_party/snappy/framing_format.txt +0 -135
  888. data/ext/third_party/snappy/snappy-test.cc +0 -613
  889. data/ext/third_party/snappy/snappy-test.h +0 -526
  890. data/ext/third_party/snappy/snappy_compress_fuzzer.cc +0 -60
  891. data/ext/third_party/snappy/snappy_uncompress_fuzzer.cc +0 -58
  892. data/ext/third_party/snappy/snappy_unittest.cc +0 -1512
  893. data/ext/third_party/spdlog/.clang-format +0 -108
  894. data/ext/third_party/spdlog/.clang-tidy +0 -54
  895. data/ext/third_party/spdlog/.gitattributes +0 -1
  896. data/ext/third_party/spdlog/.gitignore +0 -83
  897. data/ext/third_party/spdlog/.travis.yml +0 -112
  898. data/ext/third_party/spdlog/INSTALL +0 -24
  899. data/ext/third_party/spdlog/README.md +0 -423
  900. data/ext/third_party/spdlog/appveyor.yml +0 -51
  901. data/ext/third_party/spdlog/include/spdlog/cfg/log_levels.h +0 -47
@@ -1,60 +0,0 @@
1
- // Copyright 2019 Google Inc. All Rights Reserved.
2
- //
3
- // Redistribution and use in source and binary forms, with or without
4
- // modification, are permitted provided that the following conditions are
5
- // met:
6
- //
7
- // * Redistributions of source code must retain the above copyright
8
- // notice, this list of conditions and the following disclaimer.
9
- // * Redistributions in binary form must reproduce the above
10
- // copyright notice, this list of conditions and the following disclaimer
11
- // in the documentation and/or other materials provided with the
12
- // distribution.
13
- // * Neither the name of Google Inc. nor the names of its
14
- // contributors may be used to endorse or promote products derived from
15
- // this software without specific prior written permission.
16
- //
17
- // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18
- // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19
- // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20
- // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21
- // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22
- // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23
- // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24
- // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25
- // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26
- // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27
- // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
- //
29
- // libFuzzer harness for fuzzing snappy compression code.
30
-
31
- #include <stddef.h>
32
- #include <stdint.h>
33
-
34
- #include <cassert>
35
- #include <string>
36
-
37
- #include "snappy.h"
38
-
39
- // Entry point for LibFuzzer.
40
- extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
41
- std::string input(reinterpret_cast<const char*>(data), size);
42
-
43
- std::string compressed;
44
- size_t compressed_size =
45
- snappy::Compress(input.data(), input.size(), &compressed);
46
-
47
- (void)compressed_size; // Variable only used in debug builds.
48
- assert(compressed_size == compressed.size());
49
- assert(compressed.size() <= snappy::MaxCompressedLength(input.size()));
50
- assert(snappy::IsValidCompressedBuffer(compressed.data(), compressed.size()));
51
-
52
- std::string uncompressed_after_compress;
53
- bool uncompress_succeeded = snappy::Uncompress(
54
- compressed.data(), compressed.size(), &uncompressed_after_compress);
55
-
56
- (void)uncompress_succeeded; // Variable only used in debug builds.
57
- assert(uncompress_succeeded);
58
- assert(input == uncompressed_after_compress);
59
- return 0;
60
- }
@@ -1,58 +0,0 @@
1
- // Copyright 2019 Google Inc. All Rights Reserved.
2
- //
3
- // Redistribution and use in source and binary forms, with or without
4
- // modification, are permitted provided that the following conditions are
5
- // met:
6
- //
7
- // * Redistributions of source code must retain the above copyright
8
- // notice, this list of conditions and the following disclaimer.
9
- // * Redistributions in binary form must reproduce the above
10
- // copyright notice, this list of conditions and the following disclaimer
11
- // in the documentation and/or other materials provided with the
12
- // distribution.
13
- // * Neither the name of Google Inc. nor the names of its
14
- // contributors may be used to endorse or promote products derived from
15
- // this software without specific prior written permission.
16
- //
17
- // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18
- // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19
- // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20
- // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21
- // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22
- // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23
- // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24
- // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25
- // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26
- // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27
- // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
- //
29
- // libFuzzer harness for fuzzing snappy's decompression code.
30
-
31
- #include <stddef.h>
32
- #include <stdint.h>
33
-
34
- #include <cassert>
35
- #include <string>
36
-
37
- #include "snappy.h"
38
-
39
- // Entry point for LibFuzzer.
40
- extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
41
- std::string input(reinterpret_cast<const char*>(data), size);
42
-
43
- // Avoid self-crafted decompression bombs.
44
- size_t uncompressed_size;
45
- constexpr size_t kMaxUncompressedSize = 1 << 20;
46
- bool get_uncompressed_length_succeeded = snappy::GetUncompressedLength(
47
- input.data(), input.size(), &uncompressed_size);
48
- if (!get_uncompressed_length_succeeded ||
49
- (uncompressed_size > kMaxUncompressedSize)) {
50
- return 0;
51
- }
52
-
53
- std::string uncompressed;
54
- // The return value of snappy::Uncompress() is ignored because decompression
55
- // will fail on invalid inputs.
56
- snappy::Uncompress(input.data(), input.size(), &uncompressed);
57
- return 0;
58
- }
@@ -1,1512 +0,0 @@
1
- // Copyright 2005 and onwards Google Inc.
2
- //
3
- // Redistribution and use in source and binary forms, with or without
4
- // modification, are permitted provided that the following conditions are
5
- // met:
6
- //
7
- // * Redistributions of source code must retain the above copyright
8
- // notice, this list of conditions and the following disclaimer.
9
- // * Redistributions in binary form must reproduce the above
10
- // copyright notice, this list of conditions and the following disclaimer
11
- // in the documentation and/or other materials provided with the
12
- // distribution.
13
- // * Neither the name of Google Inc. nor the names of its
14
- // contributors may be used to endorse or promote products derived from
15
- // this software without specific prior written permission.
16
- //
17
- // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18
- // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19
- // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20
- // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21
- // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22
- // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23
- // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24
- // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25
- // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26
- // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27
- // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
-
29
- #include <cmath>
30
- #include <cstdlib>
31
-
32
- #include <algorithm>
33
- #include <random>
34
- #include <string>
35
- #include <utility>
36
- #include <vector>
37
-
38
- #include "snappy.h"
39
- #include "snappy-internal.h"
40
- #include "snappy-test.h"
41
- #include "snappy-sinksource.h"
42
-
43
- DEFINE_int32(start_len, -1,
44
- "Starting prefix size for testing (-1: just full file contents)");
45
- DEFINE_int32(end_len, -1,
46
- "Starting prefix size for testing (-1: just full file contents)");
47
- DEFINE_int32(bytes, 10485760,
48
- "How many bytes to compress/uncompress per file for timing");
49
-
50
- DEFINE_bool(zlib, false,
51
- "Run zlib compression (http://www.zlib.net)");
52
- DEFINE_bool(lzo, false,
53
- "Run LZO compression (http://www.oberhumer.com/opensource/lzo/)");
54
- DEFINE_bool(snappy, true, "Run snappy compression");
55
-
56
- DEFINE_bool(write_compressed, false,
57
- "Write compressed versions of each file to <file>.comp");
58
- DEFINE_bool(write_uncompressed, false,
59
- "Write uncompressed versions of each file to <file>.uncomp");
60
-
61
- DEFINE_bool(snappy_dump_decompression_table, false,
62
- "If true, we print the decompression table during tests.");
63
-
64
- namespace snappy {
65
-
66
- #if defined(HAVE_FUNC_MMAP) && defined(HAVE_FUNC_SYSCONF)
67
-
68
- // To test against code that reads beyond its input, this class copies a
69
- // string to a newly allocated group of pages, the last of which
70
- // is made unreadable via mprotect. Note that we need to allocate the
71
- // memory with mmap(), as POSIX allows mprotect() only on memory allocated
72
- // with mmap(), and some malloc/posix_memalign implementations expect to
73
- // be able to read previously allocated memory while doing heap allocations.
74
- class DataEndingAtUnreadablePage {
75
- public:
76
- explicit DataEndingAtUnreadablePage(const std::string& s) {
77
- const size_t page_size = sysconf(_SC_PAGESIZE);
78
- const size_t size = s.size();
79
- // Round up space for string to a multiple of page_size.
80
- size_t space_for_string = (size + page_size - 1) & ~(page_size - 1);
81
- alloc_size_ = space_for_string + page_size;
82
- mem_ = mmap(NULL, alloc_size_,
83
- PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0);
84
- CHECK_NE(MAP_FAILED, mem_);
85
- protected_page_ = reinterpret_cast<char*>(mem_) + space_for_string;
86
- char* dst = protected_page_ - size;
87
- std::memcpy(dst, s.data(), size);
88
- data_ = dst;
89
- size_ = size;
90
- // Make guard page unreadable.
91
- CHECK_EQ(0, mprotect(protected_page_, page_size, PROT_NONE));
92
- }
93
-
94
- ~DataEndingAtUnreadablePage() {
95
- const size_t page_size = sysconf(_SC_PAGESIZE);
96
- // Undo the mprotect.
97
- CHECK_EQ(0, mprotect(protected_page_, page_size, PROT_READ|PROT_WRITE));
98
- CHECK_EQ(0, munmap(mem_, alloc_size_));
99
- }
100
-
101
- const char* data() const { return data_; }
102
- size_t size() const { return size_; }
103
-
104
- private:
105
- size_t alloc_size_;
106
- void* mem_;
107
- char* protected_page_;
108
- const char* data_;
109
- size_t size_;
110
- };
111
-
112
- #else // defined(HAVE_FUNC_MMAP) && defined(HAVE_FUNC_SYSCONF)
113
-
114
- // Fallback for systems without mmap.
115
- using DataEndingAtUnreadablePage = std::string;
116
-
117
- #endif
118
-
119
- enum CompressorType {
120
- ZLIB, LZO, SNAPPY
121
- };
122
-
123
- const char* names[] = {
124
- "ZLIB", "LZO", "SNAPPY"
125
- };
126
-
127
- static size_t MinimumRequiredOutputSpace(size_t input_size,
128
- CompressorType comp) {
129
- switch (comp) {
130
- #ifdef ZLIB_VERSION
131
- case ZLIB:
132
- return ZLib::MinCompressbufSize(input_size);
133
- #endif // ZLIB_VERSION
134
-
135
- #ifdef LZO_VERSION
136
- case LZO:
137
- return input_size + input_size/64 + 16 + 3;
138
- #endif // LZO_VERSION
139
-
140
- case SNAPPY:
141
- return snappy::MaxCompressedLength(input_size);
142
-
143
- default:
144
- LOG(FATAL) << "Unknown compression type number " << comp;
145
- return 0;
146
- }
147
- }
148
-
149
- // Returns true if we successfully compressed, false otherwise.
150
- //
151
- // If compressed_is_preallocated is set, do not resize the compressed buffer.
152
- // This is typically what you want for a benchmark, in order to not spend
153
- // time in the memory allocator. If you do set this flag, however,
154
- // "compressed" must be preinitialized to at least MinCompressbufSize(comp)
155
- // number of bytes, and may contain junk bytes at the end after return.
156
- static bool Compress(const char* input, size_t input_size, CompressorType comp,
157
- std::string* compressed, bool compressed_is_preallocated) {
158
- if (!compressed_is_preallocated) {
159
- compressed->resize(MinimumRequiredOutputSpace(input_size, comp));
160
- }
161
-
162
- switch (comp) {
163
- #ifdef ZLIB_VERSION
164
- case ZLIB: {
165
- ZLib zlib;
166
- uLongf destlen = compressed->size();
167
- int ret = zlib.Compress(
168
- reinterpret_cast<Bytef*>(string_as_array(compressed)),
169
- &destlen,
170
- reinterpret_cast<const Bytef*>(input),
171
- input_size);
172
- CHECK_EQ(Z_OK, ret);
173
- if (!compressed_is_preallocated) {
174
- compressed->resize(destlen);
175
- }
176
- return true;
177
- }
178
- #endif // ZLIB_VERSION
179
-
180
- #ifdef LZO_VERSION
181
- case LZO: {
182
- unsigned char* mem = new unsigned char[LZO1X_1_15_MEM_COMPRESS];
183
- lzo_uint destlen;
184
- int ret = lzo1x_1_15_compress(
185
- reinterpret_cast<const uint8_t*>(input),
186
- input_size,
187
- reinterpret_cast<uint8_t*>(string_as_array(compressed)),
188
- &destlen,
189
- mem);
190
- CHECK_EQ(LZO_E_OK, ret);
191
- delete[] mem;
192
- if (!compressed_is_preallocated) {
193
- compressed->resize(destlen);
194
- }
195
- break;
196
- }
197
- #endif // LZO_VERSION
198
-
199
- case SNAPPY: {
200
- size_t destlen;
201
- snappy::RawCompress(input, input_size,
202
- string_as_array(compressed),
203
- &destlen);
204
- CHECK_LE(destlen, snappy::MaxCompressedLength(input_size));
205
- if (!compressed_is_preallocated) {
206
- compressed->resize(destlen);
207
- }
208
- break;
209
- }
210
-
211
- default: {
212
- return false; // the asked-for library wasn't compiled in
213
- }
214
- }
215
- return true;
216
- }
217
-
218
- static bool Uncompress(const std::string& compressed, CompressorType comp,
219
- int size, std::string* output) {
220
- switch (comp) {
221
- #ifdef ZLIB_VERSION
222
- case ZLIB: {
223
- output->resize(size);
224
- ZLib zlib;
225
- uLongf destlen = output->size();
226
- int ret = zlib.Uncompress(
227
- reinterpret_cast<Bytef*>(string_as_array(output)),
228
- &destlen,
229
- reinterpret_cast<const Bytef*>(compressed.data()),
230
- compressed.size());
231
- CHECK_EQ(Z_OK, ret);
232
- CHECK_EQ(static_cast<uLongf>(size), destlen);
233
- break;
234
- }
235
- #endif // ZLIB_VERSION
236
-
237
- #ifdef LZO_VERSION
238
- case LZO: {
239
- output->resize(size);
240
- lzo_uint destlen;
241
- int ret = lzo1x_decompress(
242
- reinterpret_cast<const uint8_t*>(compressed.data()),
243
- compressed.size(),
244
- reinterpret_cast<uint8_t*>(string_as_array(output)),
245
- &destlen,
246
- NULL);
247
- CHECK_EQ(LZO_E_OK, ret);
248
- CHECK_EQ(static_cast<lzo_uint>(size), destlen);
249
- break;
250
- }
251
- #endif // LZO_VERSION
252
-
253
- case SNAPPY: {
254
- snappy::RawUncompress(compressed.data(), compressed.size(),
255
- string_as_array(output));
256
- break;
257
- }
258
-
259
- default: {
260
- return false; // the asked-for library wasn't compiled in
261
- }
262
- }
263
- return true;
264
- }
265
-
266
- static void Measure(const char* data,
267
- size_t length,
268
- CompressorType comp,
269
- int repeats,
270
- int block_size) {
271
- // Run tests a few time and pick median running times
272
- static const int kRuns = 5;
273
- double ctime[kRuns];
274
- double utime[kRuns];
275
- int compressed_size = 0;
276
-
277
- {
278
- // Chop the input into blocks
279
- int num_blocks = (length + block_size - 1) / block_size;
280
- std::vector<const char*> input(num_blocks);
281
- std::vector<size_t> input_length(num_blocks);
282
- std::vector<std::string> compressed(num_blocks);
283
- std::vector<std::string> output(num_blocks);
284
- for (int b = 0; b < num_blocks; ++b) {
285
- int input_start = b * block_size;
286
- int input_limit = std::min<int>((b+1)*block_size, length);
287
- input[b] = data+input_start;
288
- input_length[b] = input_limit-input_start;
289
- }
290
-
291
- // Pre-grow the output buffers so we don't measure string append time.
292
- for (std::string& compressed_block : compressed) {
293
- compressed_block.resize(MinimumRequiredOutputSpace(block_size, comp));
294
- }
295
-
296
- // First, try one trial compression to make sure the code is compiled in
297
- if (!Compress(input[0], input_length[0], comp, &compressed[0], true)) {
298
- LOG(WARNING) << "Skipping " << names[comp] << ": "
299
- << "library not compiled in";
300
- return;
301
- }
302
-
303
- for (int run = 0; run < kRuns; ++run) {
304
- CycleTimer ctimer, utimer;
305
-
306
- // Pre-grow the output buffers so we don't measure string append time.
307
- for (std::string& compressed_block : compressed) {
308
- compressed_block.resize(MinimumRequiredOutputSpace(block_size, comp));
309
- }
310
-
311
- ctimer.Start();
312
- for (int b = 0; b < num_blocks; ++b) {
313
- for (int i = 0; i < repeats; ++i)
314
- Compress(input[b], input_length[b], comp, &compressed[b], true);
315
- }
316
- ctimer.Stop();
317
-
318
- // Compress once more, with resizing, so we don't leave junk
319
- // at the end that will confuse the decompressor.
320
- for (int b = 0; b < num_blocks; ++b) {
321
- Compress(input[b], input_length[b], comp, &compressed[b], false);
322
- }
323
-
324
- for (int b = 0; b < num_blocks; ++b) {
325
- output[b].resize(input_length[b]);
326
- }
327
-
328
- utimer.Start();
329
- for (int i = 0; i < repeats; ++i) {
330
- for (int b = 0; b < num_blocks; ++b)
331
- Uncompress(compressed[b], comp, input_length[b], &output[b]);
332
- }
333
- utimer.Stop();
334
-
335
- ctime[run] = ctimer.Get();
336
- utime[run] = utimer.Get();
337
- }
338
-
339
- compressed_size = 0;
340
- for (const std::string& compressed_item : compressed) {
341
- compressed_size += compressed_item.size();
342
- }
343
- }
344
-
345
- std::sort(ctime, ctime + kRuns);
346
- std::sort(utime, utime + kRuns);
347
- const int med = kRuns/2;
348
-
349
- float comp_rate = (length / ctime[med]) * repeats / 1048576.0;
350
- float uncomp_rate = (length / utime[med]) * repeats / 1048576.0;
351
- std::string x = names[comp];
352
- x += ":";
353
- std::string urate = (uncomp_rate >= 0) ? StrFormat("%.1f", uncomp_rate)
354
- : std::string("?");
355
- std::printf("%-7s [b %dM] bytes %6d -> %6d %4.1f%% "
356
- "comp %5.1f MB/s uncomp %5s MB/s\n",
357
- x.c_str(),
358
- block_size/(1<<20),
359
- static_cast<int>(length), static_cast<uint32_t>(compressed_size),
360
- (compressed_size * 100.0) / std::max<int>(1, length),
361
- comp_rate,
362
- urate.c_str());
363
- }
364
-
365
- static int VerifyString(const std::string& input) {
366
- std::string compressed;
367
- DataEndingAtUnreadablePage i(input);
368
- const size_t written = snappy::Compress(i.data(), i.size(), &compressed);
369
- CHECK_EQ(written, compressed.size());
370
- CHECK_LE(compressed.size(),
371
- snappy::MaxCompressedLength(input.size()));
372
- CHECK(snappy::IsValidCompressedBuffer(compressed.data(), compressed.size()));
373
-
374
- std::string uncompressed;
375
- DataEndingAtUnreadablePage c(compressed);
376
- CHECK(snappy::Uncompress(c.data(), c.size(), &uncompressed));
377
- CHECK_EQ(uncompressed, input);
378
- return uncompressed.size();
379
- }
380
-
381
- static void VerifyStringSink(const std::string& input) {
382
- std::string compressed;
383
- DataEndingAtUnreadablePage i(input);
384
- const size_t written = snappy::Compress(i.data(), i.size(), &compressed);
385
- CHECK_EQ(written, compressed.size());
386
- CHECK_LE(compressed.size(),
387
- snappy::MaxCompressedLength(input.size()));
388
- CHECK(snappy::IsValidCompressedBuffer(compressed.data(), compressed.size()));
389
-
390
- std::string uncompressed;
391
- uncompressed.resize(input.size());
392
- snappy::UncheckedByteArraySink sink(string_as_array(&uncompressed));
393
- DataEndingAtUnreadablePage c(compressed);
394
- snappy::ByteArraySource source(c.data(), c.size());
395
- CHECK(snappy::Uncompress(&source, &sink));
396
- CHECK_EQ(uncompressed, input);
397
- }
398
-
399
- static void VerifyIOVec(const std::string& input) {
400
- std::string compressed;
401
- DataEndingAtUnreadablePage i(input);
402
- const size_t written = snappy::Compress(i.data(), i.size(), &compressed);
403
- CHECK_EQ(written, compressed.size());
404
- CHECK_LE(compressed.size(),
405
- snappy::MaxCompressedLength(input.size()));
406
- CHECK(snappy::IsValidCompressedBuffer(compressed.data(), compressed.size()));
407
-
408
- // Try uncompressing into an iovec containing a random number of entries
409
- // ranging from 1 to 10.
410
- char* buf = new char[input.size()];
411
- std::minstd_rand0 rng(input.size());
412
- std::uniform_int_distribution<size_t> uniform_1_to_10(1, 10);
413
- size_t num = uniform_1_to_10(rng);
414
- if (input.size() < num) {
415
- num = input.size();
416
- }
417
- struct iovec* iov = new iovec[num];
418
- size_t used_so_far = 0;
419
- std::bernoulli_distribution one_in_five(1.0 / 5);
420
- for (size_t i = 0; i < num; ++i) {
421
- assert(used_so_far < input.size());
422
- iov[i].iov_base = buf + used_so_far;
423
- if (i == num - 1) {
424
- iov[i].iov_len = input.size() - used_so_far;
425
- } else {
426
- // Randomly choose to insert a 0 byte entry.
427
- if (one_in_five(rng)) {
428
- iov[i].iov_len = 0;
429
- } else {
430
- std::uniform_int_distribution<size_t> uniform_not_used_so_far(
431
- 0, input.size() - used_so_far - 1);
432
- iov[i].iov_len = uniform_not_used_so_far(rng);
433
- }
434
- }
435
- used_so_far += iov[i].iov_len;
436
- }
437
- CHECK(snappy::RawUncompressToIOVec(
438
- compressed.data(), compressed.size(), iov, num));
439
- CHECK(!memcmp(buf, input.data(), input.size()));
440
- delete[] iov;
441
- delete[] buf;
442
- }
443
-
444
- // Test that data compressed by a compressor that does not
445
- // obey block sizes is uncompressed properly.
446
- static void VerifyNonBlockedCompression(const std::string& input) {
447
- if (input.length() > snappy::kBlockSize) {
448
- // We cannot test larger blocks than the maximum block size, obviously.
449
- return;
450
- }
451
-
452
- std::string prefix;
453
- Varint::Append32(&prefix, input.size());
454
-
455
- // Setup compression table
456
- snappy::internal::WorkingMemory wmem(input.size());
457
- int table_size;
458
- uint16_t* table = wmem.GetHashTable(input.size(), &table_size);
459
-
460
- // Compress entire input in one shot
461
- std::string compressed;
462
- compressed += prefix;
463
- compressed.resize(prefix.size()+snappy::MaxCompressedLength(input.size()));
464
- char* dest = string_as_array(&compressed) + prefix.size();
465
- char* end = snappy::internal::CompressFragment(input.data(), input.size(),
466
- dest, table, table_size);
467
- compressed.resize(end - compressed.data());
468
-
469
- // Uncompress into std::string
470
- std::string uncomp_str;
471
- CHECK(snappy::Uncompress(compressed.data(), compressed.size(), &uncomp_str));
472
- CHECK_EQ(uncomp_str, input);
473
-
474
- // Uncompress using source/sink
475
- std::string uncomp_str2;
476
- uncomp_str2.resize(input.size());
477
- snappy::UncheckedByteArraySink sink(string_as_array(&uncomp_str2));
478
- snappy::ByteArraySource source(compressed.data(), compressed.size());
479
- CHECK(snappy::Uncompress(&source, &sink));
480
- CHECK_EQ(uncomp_str2, input);
481
-
482
- // Uncompress into iovec
483
- {
484
- static const int kNumBlocks = 10;
485
- struct iovec vec[kNumBlocks];
486
- const int block_size = 1 + input.size() / kNumBlocks;
487
- std::string iovec_data(block_size * kNumBlocks, 'x');
488
- for (int i = 0; i < kNumBlocks; ++i) {
489
- vec[i].iov_base = string_as_array(&iovec_data) + i * block_size;
490
- vec[i].iov_len = block_size;
491
- }
492
- CHECK(snappy::RawUncompressToIOVec(compressed.data(), compressed.size(),
493
- vec, kNumBlocks));
494
- CHECK_EQ(std::string(iovec_data.data(), input.size()), input);
495
- }
496
- }
497
-
498
- // Expand the input so that it is at least K times as big as block size
499
- static std::string Expand(const std::string& input) {
500
- static const int K = 3;
501
- std::string data = input;
502
- while (data.size() < K * snappy::kBlockSize) {
503
- data += input;
504
- }
505
- return data;
506
- }
507
-
508
- static int Verify(const std::string& input) {
509
- VLOG(1) << "Verifying input of size " << input.size();
510
-
511
- // Compress using string based routines
512
- const int result = VerifyString(input);
513
-
514
- // Verify using sink based routines
515
- VerifyStringSink(input);
516
-
517
- VerifyNonBlockedCompression(input);
518
- VerifyIOVec(input);
519
- if (!input.empty()) {
520
- const std::string expanded = Expand(input);
521
- VerifyNonBlockedCompression(expanded);
522
- VerifyIOVec(input);
523
- }
524
-
525
- return result;
526
- }
527
-
528
- static bool IsValidCompressedBuffer(const std::string& c) {
529
- return snappy::IsValidCompressedBuffer(c.data(), c.size());
530
- }
531
- static bool Uncompress(const std::string& c, std::string* u) {
532
- return snappy::Uncompress(c.data(), c.size(), u);
533
- }
534
-
535
- // This test checks to ensure that snappy doesn't coredump if it gets
536
- // corrupted data.
537
- TEST(CorruptedTest, VerifyCorrupted) {
538
- std::string source = "making sure we don't crash with corrupted input";
539
- VLOG(1) << source;
540
- std::string dest;
541
- std::string uncmp;
542
- snappy::Compress(source.data(), source.size(), &dest);
543
-
544
- // Mess around with the data. It's hard to simulate all possible
545
- // corruptions; this is just one example ...
546
- CHECK_GT(dest.size(), 3);
547
- dest[1]--;
548
- dest[3]++;
549
- // this really ought to fail.
550
- CHECK(!IsValidCompressedBuffer(dest));
551
- CHECK(!Uncompress(dest, &uncmp));
552
-
553
- // This is testing for a security bug - a buffer that decompresses to 100k
554
- // but we lie in the snappy header and only reserve 0 bytes of memory :)
555
- source.resize(100000);
556
- for (char& source_char : source) {
557
- source_char = 'A';
558
- }
559
- snappy::Compress(source.data(), source.size(), &dest);
560
- dest[0] = dest[1] = dest[2] = dest[3] = 0;
561
- CHECK(!IsValidCompressedBuffer(dest));
562
- CHECK(!Uncompress(dest, &uncmp));
563
-
564
- if (sizeof(void *) == 4) {
565
- // Another security check; check a crazy big length can't DoS us with an
566
- // over-allocation.
567
- // Currently this is done only for 32-bit builds. On 64-bit builds,
568
- // where 3 GB might be an acceptable allocation size, Uncompress()
569
- // attempts to decompress, and sometimes causes the test to run out of
570
- // memory.
571
- dest[0] = dest[1] = dest[2] = dest[3] = '\xff';
572
- // This decodes to a really large size, i.e., about 3 GB.
573
- dest[4] = 'k';
574
- CHECK(!IsValidCompressedBuffer(dest));
575
- CHECK(!Uncompress(dest, &uncmp));
576
- } else {
577
- LOG(WARNING) << "Crazy decompression lengths not checked on 64-bit build";
578
- }
579
-
580
- // This decodes to about 2 MB; much smaller, but should still fail.
581
- dest[0] = dest[1] = dest[2] = '\xff';
582
- dest[3] = 0x00;
583
- CHECK(!IsValidCompressedBuffer(dest));
584
- CHECK(!Uncompress(dest, &uncmp));
585
-
586
- // try reading stuff in from a bad file.
587
- for (int i = 1; i <= 3; ++i) {
588
- std::string data =
589
- ReadTestDataFile(StrFormat("baddata%d.snappy", i).c_str(), 0);
590
- std::string uncmp;
591
- // check that we don't return a crazy length
592
- size_t ulen;
593
- CHECK(!snappy::GetUncompressedLength(data.data(), data.size(), &ulen)
594
- || (ulen < (1<<20)));
595
- uint32_t ulen2;
596
- snappy::ByteArraySource source(data.data(), data.size());
597
- CHECK(!snappy::GetUncompressedLength(&source, &ulen2) ||
598
- (ulen2 < (1<<20)));
599
- CHECK(!IsValidCompressedBuffer(data));
600
- CHECK(!Uncompress(data, &uncmp));
601
- }
602
- }
603
-
604
- // Helper routines to construct arbitrary compressed strings.
605
- // These mirror the compression code in snappy.cc, but are copied
606
- // here so that we can bypass some limitations in the how snappy.cc
607
- // invokes these routines.
608
- static void AppendLiteral(std::string* dst, const std::string& literal) {
609
- if (literal.empty()) return;
610
- int n = literal.size() - 1;
611
- if (n < 60) {
612
- // Fit length in tag byte
613
- dst->push_back(0 | (n << 2));
614
- } else {
615
- // Encode in upcoming bytes
616
- char number[4];
617
- int count = 0;
618
- while (n > 0) {
619
- number[count++] = n & 0xff;
620
- n >>= 8;
621
- }
622
- dst->push_back(0 | ((59+count) << 2));
623
- *dst += std::string(number, count);
624
- }
625
- *dst += literal;
626
- }
627
-
628
- static void AppendCopy(std::string* dst, int offset, int length) {
629
- while (length > 0) {
630
- // Figure out how much to copy in one shot
631
- int to_copy;
632
- if (length >= 68) {
633
- to_copy = 64;
634
- } else if (length > 64) {
635
- to_copy = 60;
636
- } else {
637
- to_copy = length;
638
- }
639
- length -= to_copy;
640
-
641
- if ((to_copy >= 4) && (to_copy < 12) && (offset < 2048)) {
642
- assert(to_copy-4 < 8); // Must fit in 3 bits
643
- dst->push_back(1 | ((to_copy-4) << 2) | ((offset >> 8) << 5));
644
- dst->push_back(offset & 0xff);
645
- } else if (offset < 65536) {
646
- dst->push_back(2 | ((to_copy-1) << 2));
647
- dst->push_back(offset & 0xff);
648
- dst->push_back(offset >> 8);
649
- } else {
650
- dst->push_back(3 | ((to_copy-1) << 2));
651
- dst->push_back(offset & 0xff);
652
- dst->push_back((offset >> 8) & 0xff);
653
- dst->push_back((offset >> 16) & 0xff);
654
- dst->push_back((offset >> 24) & 0xff);
655
- }
656
- }
657
- }
658
-
659
- TEST(Snappy, SimpleTests) {
660
- Verify("");
661
- Verify("a");
662
- Verify("ab");
663
- Verify("abc");
664
-
665
- Verify("aaaaaaa" + std::string(16, 'b') + std::string("aaaaa") + "abc");
666
- Verify("aaaaaaa" + std::string(256, 'b') + std::string("aaaaa") + "abc");
667
- Verify("aaaaaaa" + std::string(2047, 'b') + std::string("aaaaa") + "abc");
668
- Verify("aaaaaaa" + std::string(65536, 'b') + std::string("aaaaa") + "abc");
669
- Verify("abcaaaaaaa" + std::string(65536, 'b') + std::string("aaaaa") + "abc");
670
- }
671
-
672
- // Verify max blowup (lots of four-byte copies)
673
- TEST(Snappy, MaxBlowup) {
674
- std::mt19937 rng;
675
- std::uniform_int_distribution<int> uniform_byte(0, 255);
676
- std::string input;
677
- for (int i = 0; i < 80000; ++i)
678
- input.push_back(static_cast<char>(uniform_byte(rng)));
679
-
680
- for (int i = 0; i < 80000; i += 4) {
681
- std::string four_bytes(input.end() - i - 4, input.end() - i);
682
- input.append(four_bytes);
683
- }
684
- Verify(input);
685
- }
686
-
687
- TEST(Snappy, RandomData) {
688
- std::minstd_rand0 rng(FLAGS_test_random_seed);
689
- std::uniform_int_distribution<int> uniform_0_to_3(0, 3);
690
- std::uniform_int_distribution<int> uniform_0_to_8(0, 8);
691
- std::uniform_int_distribution<int> uniform_byte(0, 255);
692
- std::uniform_int_distribution<size_t> uniform_4k(0, 4095);
693
- std::uniform_int_distribution<size_t> uniform_64k(0, 65535);
694
- std::bernoulli_distribution one_in_ten(1.0 / 10);
695
-
696
- constexpr int num_ops = 20000;
697
- for (int i = 0; i < num_ops; ++i) {
698
- if ((i % 1000) == 0) {
699
- VLOG(0) << "Random op " << i << " of " << num_ops;
700
- }
701
-
702
- std::string x;
703
- size_t len = uniform_4k(rng);
704
- if (i < 100) {
705
- len = 65536 + uniform_64k(rng);
706
- }
707
- while (x.size() < len) {
708
- int run_len = 1;
709
- if (one_in_ten(rng)) {
710
- int skewed_bits = uniform_0_to_8(rng);
711
- // int is guaranteed to hold at least 16 bits, this uses at most 8 bits.
712
- std::uniform_int_distribution<int> skewed_low(0,
713
- (1 << skewed_bits) - 1);
714
- run_len = skewed_low(rng);
715
- }
716
- char c = static_cast<char>(uniform_byte(rng));
717
- if (i >= 100) {
718
- int skewed_bits = uniform_0_to_3(rng);
719
- // int is guaranteed to hold at least 16 bits, this uses at most 3 bits.
720
- std::uniform_int_distribution<int> skewed_low(0,
721
- (1 << skewed_bits) - 1);
722
- c = static_cast<char>(skewed_low(rng));
723
- }
724
- while (run_len-- > 0 && x.size() < len) {
725
- x.push_back(c);
726
- }
727
- }
728
-
729
- Verify(x);
730
- }
731
- }
732
-
733
- TEST(Snappy, FourByteOffset) {
734
- // The new compressor cannot generate four-byte offsets since
735
- // it chops up the input into 32KB pieces. So we hand-emit the
736
- // copy manually.
737
-
738
- // The two fragments that make up the input string.
739
- std::string fragment1 = "012345689abcdefghijklmnopqrstuvwxyz";
740
- std::string fragment2 = "some other string";
741
-
742
- // How many times each fragment is emitted.
743
- const int n1 = 2;
744
- const int n2 = 100000 / fragment2.size();
745
- const size_t length = n1 * fragment1.size() + n2 * fragment2.size();
746
-
747
- std::string compressed;
748
- Varint::Append32(&compressed, length);
749
-
750
- AppendLiteral(&compressed, fragment1);
751
- std::string src = fragment1;
752
- for (int i = 0; i < n2; ++i) {
753
- AppendLiteral(&compressed, fragment2);
754
- src += fragment2;
755
- }
756
- AppendCopy(&compressed, src.size(), fragment1.size());
757
- src += fragment1;
758
- CHECK_EQ(length, src.size());
759
-
760
- std::string uncompressed;
761
- CHECK(snappy::IsValidCompressedBuffer(compressed.data(), compressed.size()));
762
- CHECK(snappy::Uncompress(compressed.data(), compressed.size(),
763
- &uncompressed));
764
- CHECK_EQ(uncompressed, src);
765
- }
766
-
767
- TEST(Snappy, IOVecEdgeCases) {
768
- // Test some tricky edge cases in the iovec output that are not necessarily
769
- // exercised by random tests.
770
-
771
- // Our output blocks look like this initially (the last iovec is bigger
772
- // than depicted):
773
- // [ ] [ ] [ ] [ ] [ ]
774
- static const int kLengths[] = { 2, 1, 4, 8, 128 };
775
-
776
- struct iovec iov[ARRAYSIZE(kLengths)];
777
- for (int i = 0; i < ARRAYSIZE(kLengths); ++i) {
778
- iov[i].iov_base = new char[kLengths[i]];
779
- iov[i].iov_len = kLengths[i];
780
- }
781
-
782
- std::string compressed;
783
- Varint::Append32(&compressed, 22);
784
-
785
- // A literal whose output crosses three blocks.
786
- // [ab] [c] [123 ] [ ] [ ]
787
- AppendLiteral(&compressed, "abc123");
788
-
789
- // A copy whose output crosses two blocks (source and destination
790
- // segments marked).
791
- // [ab] [c] [1231] [23 ] [ ]
792
- // ^--^ --
793
- AppendCopy(&compressed, 3, 3);
794
-
795
- // A copy where the input is, at first, in the block before the output:
796
- //
797
- // [ab] [c] [1231] [231231 ] [ ]
798
- // ^--- ^---
799
- // Then during the copy, the pointers move such that the input and
800
- // output pointers are in the same block:
801
- //
802
- // [ab] [c] [1231] [23123123] [ ]
803
- // ^- ^-
804
- // And then they move again, so that the output pointer is no longer
805
- // in the same block as the input pointer:
806
- // [ab] [c] [1231] [23123123] [123 ]
807
- // ^-- ^--
808
- AppendCopy(&compressed, 6, 9);
809
-
810
- // Finally, a copy where the input is from several blocks back,
811
- // and it also crosses three blocks:
812
- //
813
- // [ab] [c] [1231] [23123123] [123b ]
814
- // ^ ^
815
- // [ab] [c] [1231] [23123123] [123bc ]
816
- // ^ ^
817
- // [ab] [c] [1231] [23123123] [123bc12 ]
818
- // ^- ^-
819
- AppendCopy(&compressed, 17, 4);
820
-
821
- CHECK(snappy::RawUncompressToIOVec(
822
- compressed.data(), compressed.size(), iov, ARRAYSIZE(iov)));
823
- CHECK_EQ(0, memcmp(iov[0].iov_base, "ab", 2));
824
- CHECK_EQ(0, memcmp(iov[1].iov_base, "c", 1));
825
- CHECK_EQ(0, memcmp(iov[2].iov_base, "1231", 4));
826
- CHECK_EQ(0, memcmp(iov[3].iov_base, "23123123", 8));
827
- CHECK_EQ(0, memcmp(iov[4].iov_base, "123bc12", 7));
828
-
829
- for (int i = 0; i < ARRAYSIZE(kLengths); ++i) {
830
- delete[] reinterpret_cast<char *>(iov[i].iov_base);
831
- }
832
- }
833
-
834
- TEST(Snappy, IOVecLiteralOverflow) {
835
- static const int kLengths[] = { 3, 4 };
836
-
837
- struct iovec iov[ARRAYSIZE(kLengths)];
838
- for (int i = 0; i < ARRAYSIZE(kLengths); ++i) {
839
- iov[i].iov_base = new char[kLengths[i]];
840
- iov[i].iov_len = kLengths[i];
841
- }
842
-
843
- std::string compressed;
844
- Varint::Append32(&compressed, 8);
845
-
846
- AppendLiteral(&compressed, "12345678");
847
-
848
- CHECK(!snappy::RawUncompressToIOVec(
849
- compressed.data(), compressed.size(), iov, ARRAYSIZE(iov)));
850
-
851
- for (int i = 0; i < ARRAYSIZE(kLengths); ++i) {
852
- delete[] reinterpret_cast<char *>(iov[i].iov_base);
853
- }
854
- }
855
-
856
- TEST(Snappy, IOVecCopyOverflow) {
857
- static const int kLengths[] = { 3, 4 };
858
-
859
- struct iovec iov[ARRAYSIZE(kLengths)];
860
- for (int i = 0; i < ARRAYSIZE(kLengths); ++i) {
861
- iov[i].iov_base = new char[kLengths[i]];
862
- iov[i].iov_len = kLengths[i];
863
- }
864
-
865
- std::string compressed;
866
- Varint::Append32(&compressed, 8);
867
-
868
- AppendLiteral(&compressed, "123");
869
- AppendCopy(&compressed, 3, 5);
870
-
871
- CHECK(!snappy::RawUncompressToIOVec(
872
- compressed.data(), compressed.size(), iov, ARRAYSIZE(iov)));
873
-
874
- for (int i = 0; i < ARRAYSIZE(kLengths); ++i) {
875
- delete[] reinterpret_cast<char *>(iov[i].iov_base);
876
- }
877
- }
878
-
879
- static bool CheckUncompressedLength(const std::string& compressed,
880
- size_t* ulength) {
881
- const bool result1 = snappy::GetUncompressedLength(compressed.data(),
882
- compressed.size(),
883
- ulength);
884
-
885
- snappy::ByteArraySource source(compressed.data(), compressed.size());
886
- uint32_t length;
887
- const bool result2 = snappy::GetUncompressedLength(&source, &length);
888
- CHECK_EQ(result1, result2);
889
- return result1;
890
- }
891
-
892
- TEST(SnappyCorruption, TruncatedVarint) {
893
- std::string compressed, uncompressed;
894
- size_t ulength;
895
- compressed.push_back('\xf0');
896
- CHECK(!CheckUncompressedLength(compressed, &ulength));
897
- CHECK(!snappy::IsValidCompressedBuffer(compressed.data(), compressed.size()));
898
- CHECK(!snappy::Uncompress(compressed.data(), compressed.size(),
899
- &uncompressed));
900
- }
901
-
902
- TEST(SnappyCorruption, UnterminatedVarint) {
903
- std::string compressed, uncompressed;
904
- size_t ulength;
905
- compressed.push_back('\x80');
906
- compressed.push_back('\x80');
907
- compressed.push_back('\x80');
908
- compressed.push_back('\x80');
909
- compressed.push_back('\x80');
910
- compressed.push_back(10);
911
- CHECK(!CheckUncompressedLength(compressed, &ulength));
912
- CHECK(!snappy::IsValidCompressedBuffer(compressed.data(), compressed.size()));
913
- CHECK(!snappy::Uncompress(compressed.data(), compressed.size(),
914
- &uncompressed));
915
- }
916
-
917
- TEST(SnappyCorruption, OverflowingVarint) {
918
- std::string compressed, uncompressed;
919
- size_t ulength;
920
- compressed.push_back('\xfb');
921
- compressed.push_back('\xff');
922
- compressed.push_back('\xff');
923
- compressed.push_back('\xff');
924
- compressed.push_back('\x7f');
925
- CHECK(!CheckUncompressedLength(compressed, &ulength));
926
- CHECK(!snappy::IsValidCompressedBuffer(compressed.data(), compressed.size()));
927
- CHECK(!snappy::Uncompress(compressed.data(), compressed.size(),
928
- &uncompressed));
929
- }
930
-
931
- TEST(Snappy, ReadPastEndOfBuffer) {
932
- // Check that we do not read past end of input
933
-
934
- // Make a compressed string that ends with a single-byte literal
935
- std::string compressed;
936
- Varint::Append32(&compressed, 1);
937
- AppendLiteral(&compressed, "x");
938
-
939
- std::string uncompressed;
940
- DataEndingAtUnreadablePage c(compressed);
941
- CHECK(snappy::Uncompress(c.data(), c.size(), &uncompressed));
942
- CHECK_EQ(uncompressed, std::string("x"));
943
- }
944
-
945
- // Check for an infinite loop caused by a copy with offset==0
946
- TEST(Snappy, ZeroOffsetCopy) {
947
- const char* compressed = "\x40\x12\x00\x00";
948
- // \x40 Length (must be > kMaxIncrementCopyOverflow)
949
- // \x12\x00\x00 Copy with offset==0, length==5
950
- char uncompressed[100];
951
- EXPECT_FALSE(snappy::RawUncompress(compressed, 4, uncompressed));
952
- }
953
-
954
- TEST(Snappy, ZeroOffsetCopyValidation) {
955
- const char* compressed = "\x05\x12\x00\x00";
956
- // \x05 Length
957
- // \x12\x00\x00 Copy with offset==0, length==5
958
- EXPECT_FALSE(snappy::IsValidCompressedBuffer(compressed, 4));
959
- }
960
-
961
- namespace {
962
-
963
- int TestFindMatchLength(const char* s1, const char *s2, unsigned length) {
964
- uint64_t data;
965
- std::pair<size_t, bool> p =
966
- snappy::internal::FindMatchLength(s1, s2, s2 + length, &data);
967
- CHECK_EQ(p.first < 8, p.second);
968
- return p.first;
969
- }
970
-
971
- } // namespace
972
-
973
- TEST(Snappy, FindMatchLength) {
974
- // Exercise all different code paths through the function.
975
- // 64-bit version:
976
-
977
- // Hit s1_limit in 64-bit loop, hit s1_limit in single-character loop.
978
- EXPECT_EQ(6, TestFindMatchLength("012345", "012345", 6));
979
- EXPECT_EQ(11, TestFindMatchLength("01234567abc", "01234567abc", 11));
980
-
981
- // Hit s1_limit in 64-bit loop, find a non-match in single-character loop.
982
- EXPECT_EQ(9, TestFindMatchLength("01234567abc", "01234567axc", 9));
983
-
984
- // Same, but edge cases.
985
- EXPECT_EQ(11, TestFindMatchLength("01234567abc!", "01234567abc!", 11));
986
- EXPECT_EQ(11, TestFindMatchLength("01234567abc!", "01234567abc?", 11));
987
-
988
- // Find non-match at once in first loop.
989
- EXPECT_EQ(0, TestFindMatchLength("01234567xxxxxxxx", "?1234567xxxxxxxx", 16));
990
- EXPECT_EQ(1, TestFindMatchLength("01234567xxxxxxxx", "0?234567xxxxxxxx", 16));
991
- EXPECT_EQ(4, TestFindMatchLength("01234567xxxxxxxx", "01237654xxxxxxxx", 16));
992
- EXPECT_EQ(7, TestFindMatchLength("01234567xxxxxxxx", "0123456?xxxxxxxx", 16));
993
-
994
- // Find non-match in first loop after one block.
995
- EXPECT_EQ(8, TestFindMatchLength("abcdefgh01234567xxxxxxxx",
996
- "abcdefgh?1234567xxxxxxxx", 24));
997
- EXPECT_EQ(9, TestFindMatchLength("abcdefgh01234567xxxxxxxx",
998
- "abcdefgh0?234567xxxxxxxx", 24));
999
- EXPECT_EQ(12, TestFindMatchLength("abcdefgh01234567xxxxxxxx",
1000
- "abcdefgh01237654xxxxxxxx", 24));
1001
- EXPECT_EQ(15, TestFindMatchLength("abcdefgh01234567xxxxxxxx",
1002
- "abcdefgh0123456?xxxxxxxx", 24));
1003
-
1004
- // 32-bit version:
1005
-
1006
- // Short matches.
1007
- EXPECT_EQ(0, TestFindMatchLength("01234567", "?1234567", 8));
1008
- EXPECT_EQ(1, TestFindMatchLength("01234567", "0?234567", 8));
1009
- EXPECT_EQ(2, TestFindMatchLength("01234567", "01?34567", 8));
1010
- EXPECT_EQ(3, TestFindMatchLength("01234567", "012?4567", 8));
1011
- EXPECT_EQ(4, TestFindMatchLength("01234567", "0123?567", 8));
1012
- EXPECT_EQ(5, TestFindMatchLength("01234567", "01234?67", 8));
1013
- EXPECT_EQ(6, TestFindMatchLength("01234567", "012345?7", 8));
1014
- EXPECT_EQ(7, TestFindMatchLength("01234567", "0123456?", 8));
1015
- EXPECT_EQ(7, TestFindMatchLength("01234567", "0123456?", 7));
1016
- EXPECT_EQ(7, TestFindMatchLength("01234567!", "0123456??", 7));
1017
-
1018
- // Hit s1_limit in 32-bit loop, hit s1_limit in single-character loop.
1019
- EXPECT_EQ(10, TestFindMatchLength("xxxxxxabcd", "xxxxxxabcd", 10));
1020
- EXPECT_EQ(10, TestFindMatchLength("xxxxxxabcd?", "xxxxxxabcd?", 10));
1021
- EXPECT_EQ(13, TestFindMatchLength("xxxxxxabcdef", "xxxxxxabcdef", 13));
1022
-
1023
- // Same, but edge cases.
1024
- EXPECT_EQ(12, TestFindMatchLength("xxxxxx0123abc!", "xxxxxx0123abc!", 12));
1025
- EXPECT_EQ(12, TestFindMatchLength("xxxxxx0123abc!", "xxxxxx0123abc?", 12));
1026
-
1027
- // Hit s1_limit in 32-bit loop, find a non-match in single-character loop.
1028
- EXPECT_EQ(11, TestFindMatchLength("xxxxxx0123abc", "xxxxxx0123axc", 13));
1029
-
1030
- // Find non-match at once in first loop.
1031
- EXPECT_EQ(6, TestFindMatchLength("xxxxxx0123xxxxxxxx",
1032
- "xxxxxx?123xxxxxxxx", 18));
1033
- EXPECT_EQ(7, TestFindMatchLength("xxxxxx0123xxxxxxxx",
1034
- "xxxxxx0?23xxxxxxxx", 18));
1035
- EXPECT_EQ(8, TestFindMatchLength("xxxxxx0123xxxxxxxx",
1036
- "xxxxxx0132xxxxxxxx", 18));
1037
- EXPECT_EQ(9, TestFindMatchLength("xxxxxx0123xxxxxxxx",
1038
- "xxxxxx012?xxxxxxxx", 18));
1039
-
1040
- // Same, but edge cases.
1041
- EXPECT_EQ(6, TestFindMatchLength("xxxxxx0123", "xxxxxx?123", 10));
1042
- EXPECT_EQ(7, TestFindMatchLength("xxxxxx0123", "xxxxxx0?23", 10));
1043
- EXPECT_EQ(8, TestFindMatchLength("xxxxxx0123", "xxxxxx0132", 10));
1044
- EXPECT_EQ(9, TestFindMatchLength("xxxxxx0123", "xxxxxx012?", 10));
1045
-
1046
- // Find non-match in first loop after one block.
1047
- EXPECT_EQ(10, TestFindMatchLength("xxxxxxabcd0123xx",
1048
- "xxxxxxabcd?123xx", 16));
1049
- EXPECT_EQ(11, TestFindMatchLength("xxxxxxabcd0123xx",
1050
- "xxxxxxabcd0?23xx", 16));
1051
- EXPECT_EQ(12, TestFindMatchLength("xxxxxxabcd0123xx",
1052
- "xxxxxxabcd0132xx", 16));
1053
- EXPECT_EQ(13, TestFindMatchLength("xxxxxxabcd0123xx",
1054
- "xxxxxxabcd012?xx", 16));
1055
-
1056
- // Same, but edge cases.
1057
- EXPECT_EQ(10, TestFindMatchLength("xxxxxxabcd0123", "xxxxxxabcd?123", 14));
1058
- EXPECT_EQ(11, TestFindMatchLength("xxxxxxabcd0123", "xxxxxxabcd0?23", 14));
1059
- EXPECT_EQ(12, TestFindMatchLength("xxxxxxabcd0123", "xxxxxxabcd0132", 14));
1060
- EXPECT_EQ(13, TestFindMatchLength("xxxxxxabcd0123", "xxxxxxabcd012?", 14));
1061
- }
1062
-
1063
- TEST(Snappy, FindMatchLengthRandom) {
1064
- constexpr int kNumTrials = 10000;
1065
- constexpr int kTypicalLength = 10;
1066
- std::minstd_rand0 rng(FLAGS_test_random_seed);
1067
- std::uniform_int_distribution<int> uniform_byte(0, 255);
1068
- std::bernoulli_distribution one_in_two(1.0 / 2);
1069
- std::bernoulli_distribution one_in_typical_length(1.0 / kTypicalLength);
1070
-
1071
- for (int i = 0; i < kNumTrials; ++i) {
1072
- std::string s, t;
1073
- char a = static_cast<char>(uniform_byte(rng));
1074
- char b = static_cast<char>(uniform_byte(rng));
1075
- while (!one_in_typical_length(rng)) {
1076
- s.push_back(one_in_two(rng) ? a : b);
1077
- t.push_back(one_in_two(rng) ? a : b);
1078
- }
1079
- DataEndingAtUnreadablePage u(s);
1080
- DataEndingAtUnreadablePage v(t);
1081
- size_t matched = TestFindMatchLength(u.data(), v.data(), t.size());
1082
- if (matched == t.size()) {
1083
- EXPECT_EQ(s, t);
1084
- } else {
1085
- EXPECT_NE(s[matched], t[matched]);
1086
- for (size_t j = 0; j < matched; ++j) {
1087
- EXPECT_EQ(s[j], t[j]);
1088
- }
1089
- }
1090
- }
1091
- }
1092
-
1093
- static uint16_t MakeEntry(unsigned int extra,
1094
- unsigned int len,
1095
- unsigned int copy_offset) {
1096
- // Check that all of the fields fit within the allocated space
1097
- assert(extra == (extra & 0x7)); // At most 3 bits
1098
- assert(copy_offset == (copy_offset & 0x7)); // At most 3 bits
1099
- assert(len == (len & 0x7f)); // At most 7 bits
1100
- return len | (copy_offset << 8) | (extra << 11);
1101
- }
1102
-
1103
- // Check that the decompression table is correct, and optionally print out
1104
- // the computed one.
1105
- TEST(Snappy, VerifyCharTable) {
1106
- using snappy::internal::LITERAL;
1107
- using snappy::internal::COPY_1_BYTE_OFFSET;
1108
- using snappy::internal::COPY_2_BYTE_OFFSET;
1109
- using snappy::internal::COPY_4_BYTE_OFFSET;
1110
- using snappy::internal::char_table;
1111
-
1112
- uint16_t dst[256];
1113
-
1114
- // Place invalid entries in all places to detect missing initialization
1115
- int assigned = 0;
1116
- for (int i = 0; i < 256; ++i) {
1117
- dst[i] = 0xffff;
1118
- }
1119
-
1120
- // Small LITERAL entries. We store (len-1) in the top 6 bits.
1121
- for (uint8_t len = 1; len <= 60; ++len) {
1122
- dst[LITERAL | ((len - 1) << 2)] = MakeEntry(0, len, 0);
1123
- assigned++;
1124
- }
1125
-
1126
- // Large LITERAL entries. We use 60..63 in the high 6 bits to
1127
- // encode the number of bytes of length info that follow the opcode.
1128
- for (uint8_t extra_bytes = 1; extra_bytes <= 4; ++extra_bytes) {
1129
- // We set the length field in the lookup table to 1 because extra
1130
- // bytes encode len-1.
1131
- dst[LITERAL | ((extra_bytes + 59) << 2)] = MakeEntry(extra_bytes, 1, 0);
1132
- assigned++;
1133
- }
1134
-
1135
- // COPY_1_BYTE_OFFSET.
1136
- //
1137
- // The tag byte in the compressed data stores len-4 in 3 bits, and
1138
- // offset/256 in 5 bits. offset%256 is stored in the next byte.
1139
- //
1140
- // This format is used for length in range [4..11] and offset in
1141
- // range [0..2047]
1142
- for (uint8_t len = 4; len < 12; ++len) {
1143
- for (uint16_t offset = 0; offset < 2048; offset += 256) {
1144
- uint8_t offset_high = static_cast<uint8_t>(offset >> 8);
1145
- dst[COPY_1_BYTE_OFFSET | ((len - 4) << 2) | (offset_high << 5)] =
1146
- MakeEntry(1, len, offset_high);
1147
- assigned++;
1148
- }
1149
- }
1150
-
1151
- // COPY_2_BYTE_OFFSET.
1152
- // Tag contains len-1 in top 6 bits, and offset in next two bytes.
1153
- for (uint8_t len = 1; len <= 64; ++len) {
1154
- dst[COPY_2_BYTE_OFFSET | ((len - 1) << 2)] = MakeEntry(2, len, 0);
1155
- assigned++;
1156
- }
1157
-
1158
- // COPY_4_BYTE_OFFSET.
1159
- // Tag contents len-1 in top 6 bits, and offset in next four bytes.
1160
- for (uint8_t len = 1; len <= 64; ++len) {
1161
- dst[COPY_4_BYTE_OFFSET | ((len - 1) << 2)] = MakeEntry(4, len, 0);
1162
- assigned++;
1163
- }
1164
-
1165
- // Check that each entry was initialized exactly once.
1166
- EXPECT_EQ(256, assigned) << "Assigned only " << assigned << " of 256";
1167
- for (int i = 0; i < 256; ++i) {
1168
- EXPECT_NE(0xffff, dst[i]) << "Did not assign byte " << i;
1169
- }
1170
-
1171
- if (FLAGS_snappy_dump_decompression_table) {
1172
- std::printf("static const uint16_t char_table[256] = {\n ");
1173
- for (int i = 0; i < 256; ++i) {
1174
- std::printf("0x%04x%s",
1175
- dst[i],
1176
- ((i == 255) ? "\n" : (((i % 8) == 7) ? ",\n " : ", ")));
1177
- }
1178
- std::printf("};\n");
1179
- }
1180
-
1181
- // Check that computed table matched recorded table.
1182
- for (int i = 0; i < 256; ++i) {
1183
- EXPECT_EQ(dst[i], char_table[i]) << "Mismatch in byte " << i;
1184
- }
1185
- }
1186
-
1187
- static void CompressFile(const char* fname) {
1188
- std::string fullinput;
1189
- CHECK_OK(file::GetContents(fname, &fullinput, file::Defaults()));
1190
-
1191
- std::string compressed;
1192
- Compress(fullinput.data(), fullinput.size(), SNAPPY, &compressed, false);
1193
-
1194
- CHECK_OK(file::SetContents(std::string(fname).append(".comp"), compressed,
1195
- file::Defaults()));
1196
- }
1197
-
1198
- static void UncompressFile(const char* fname) {
1199
- std::string fullinput;
1200
- CHECK_OK(file::GetContents(fname, &fullinput, file::Defaults()));
1201
-
1202
- size_t uncompLength;
1203
- CHECK(CheckUncompressedLength(fullinput, &uncompLength));
1204
-
1205
- std::string uncompressed;
1206
- uncompressed.resize(uncompLength);
1207
- CHECK(snappy::Uncompress(fullinput.data(), fullinput.size(), &uncompressed));
1208
-
1209
- CHECK_OK(file::SetContents(std::string(fname).append(".uncomp"), uncompressed,
1210
- file::Defaults()));
1211
- }
1212
-
1213
- static void MeasureFile(const char* fname) {
1214
- std::string fullinput;
1215
- CHECK_OK(file::GetContents(fname, &fullinput, file::Defaults()));
1216
- std::printf("%-40s :\n", fname);
1217
-
1218
- int start_len = (FLAGS_start_len < 0) ? fullinput.size() : FLAGS_start_len;
1219
- int end_len = fullinput.size();
1220
- if (FLAGS_end_len >= 0) {
1221
- end_len = std::min<int>(fullinput.size(), FLAGS_end_len);
1222
- }
1223
- for (int len = start_len; len <= end_len; ++len) {
1224
- const char* const input = fullinput.data();
1225
- int repeats = (FLAGS_bytes + len) / (len + 1);
1226
- if (FLAGS_zlib) Measure(input, len, ZLIB, repeats, 1024<<10);
1227
- if (FLAGS_lzo) Measure(input, len, LZO, repeats, 1024<<10);
1228
- if (FLAGS_snappy) Measure(input, len, SNAPPY, repeats, 4096<<10);
1229
-
1230
- // For block-size based measurements
1231
- if (0 && FLAGS_snappy) {
1232
- Measure(input, len, SNAPPY, repeats, 8<<10);
1233
- Measure(input, len, SNAPPY, repeats, 16<<10);
1234
- Measure(input, len, SNAPPY, repeats, 32<<10);
1235
- Measure(input, len, SNAPPY, repeats, 64<<10);
1236
- Measure(input, len, SNAPPY, repeats, 256<<10);
1237
- Measure(input, len, SNAPPY, repeats, 1024<<10);
1238
- }
1239
- }
1240
- }
1241
-
1242
- static struct {
1243
- const char* label;
1244
- const char* filename;
1245
- size_t size_limit;
1246
- } files[] = {
1247
- { "html", "html", 0 },
1248
- { "urls", "urls.10K", 0 },
1249
- { "jpg", "fireworks.jpeg", 0 },
1250
- { "jpg_200", "fireworks.jpeg", 200 },
1251
- { "pdf", "paper-100k.pdf", 0 },
1252
- { "html4", "html_x_4", 0 },
1253
- { "txt1", "alice29.txt", 0 },
1254
- { "txt2", "asyoulik.txt", 0 },
1255
- { "txt3", "lcet10.txt", 0 },
1256
- { "txt4", "plrabn12.txt", 0 },
1257
- { "pb", "geo.protodata", 0 },
1258
- { "gaviota", "kppkn.gtb", 0 },
1259
- };
1260
-
1261
- static void BM_UFlat(int iters, int arg) {
1262
- StopBenchmarkTiming();
1263
-
1264
- // Pick file to process based on "arg"
1265
- CHECK_GE(arg, 0);
1266
- CHECK_LT(arg, ARRAYSIZE(files));
1267
- std::string contents =
1268
- ReadTestDataFile(files[arg].filename, files[arg].size_limit);
1269
-
1270
- std::string zcontents;
1271
- snappy::Compress(contents.data(), contents.size(), &zcontents);
1272
- char* dst = new char[contents.size()];
1273
-
1274
- SetBenchmarkBytesProcessed(static_cast<int64_t>(iters) *
1275
- static_cast<int64_t>(contents.size()));
1276
- SetBenchmarkLabel(files[arg].label);
1277
- StartBenchmarkTiming();
1278
- while (iters-- > 0) {
1279
- CHECK(snappy::RawUncompress(zcontents.data(), zcontents.size(), dst));
1280
- }
1281
- StopBenchmarkTiming();
1282
-
1283
- delete[] dst;
1284
- }
1285
- BENCHMARK(BM_UFlat)->DenseRange(0, ARRAYSIZE(files) - 1);
1286
-
1287
- static void BM_UValidate(int iters, int arg) {
1288
- StopBenchmarkTiming();
1289
-
1290
- // Pick file to process based on "arg"
1291
- CHECK_GE(arg, 0);
1292
- CHECK_LT(arg, ARRAYSIZE(files));
1293
- std::string contents =
1294
- ReadTestDataFile(files[arg].filename, files[arg].size_limit);
1295
-
1296
- std::string zcontents;
1297
- snappy::Compress(contents.data(), contents.size(), &zcontents);
1298
-
1299
- SetBenchmarkBytesProcessed(static_cast<int64_t>(iters) *
1300
- static_cast<int64_t>(contents.size()));
1301
- SetBenchmarkLabel(files[arg].label);
1302
- StartBenchmarkTiming();
1303
- while (iters-- > 0) {
1304
- CHECK(snappy::IsValidCompressedBuffer(zcontents.data(), zcontents.size()));
1305
- }
1306
- StopBenchmarkTiming();
1307
- }
1308
- BENCHMARK(BM_UValidate)->DenseRange(0, 4);
1309
-
1310
- static void BM_UIOVec(int iters, int arg) {
1311
- StopBenchmarkTiming();
1312
-
1313
- // Pick file to process based on "arg"
1314
- CHECK_GE(arg, 0);
1315
- CHECK_LT(arg, ARRAYSIZE(files));
1316
- std::string contents =
1317
- ReadTestDataFile(files[arg].filename, files[arg].size_limit);
1318
-
1319
- std::string zcontents;
1320
- snappy::Compress(contents.data(), contents.size(), &zcontents);
1321
-
1322
- // Uncompress into an iovec containing ten entries.
1323
- const int kNumEntries = 10;
1324
- struct iovec iov[kNumEntries];
1325
- char *dst = new char[contents.size()];
1326
- size_t used_so_far = 0;
1327
- for (int i = 0; i < kNumEntries; ++i) {
1328
- iov[i].iov_base = dst + used_so_far;
1329
- if (used_so_far == contents.size()) {
1330
- iov[i].iov_len = 0;
1331
- continue;
1332
- }
1333
-
1334
- if (i == kNumEntries - 1) {
1335
- iov[i].iov_len = contents.size() - used_so_far;
1336
- } else {
1337
- iov[i].iov_len = contents.size() / kNumEntries;
1338
- }
1339
- used_so_far += iov[i].iov_len;
1340
- }
1341
-
1342
- SetBenchmarkBytesProcessed(static_cast<int64_t>(iters) *
1343
- static_cast<int64_t>(contents.size()));
1344
- SetBenchmarkLabel(files[arg].label);
1345
- StartBenchmarkTiming();
1346
- while (iters-- > 0) {
1347
- CHECK(snappy::RawUncompressToIOVec(zcontents.data(), zcontents.size(), iov,
1348
- kNumEntries));
1349
- }
1350
- StopBenchmarkTiming();
1351
-
1352
- delete[] dst;
1353
- }
1354
- BENCHMARK(BM_UIOVec)->DenseRange(0, 4);
1355
-
1356
- static void BM_UFlatSink(int iters, int arg) {
1357
- StopBenchmarkTiming();
1358
-
1359
- // Pick file to process based on "arg"
1360
- CHECK_GE(arg, 0);
1361
- CHECK_LT(arg, ARRAYSIZE(files));
1362
- std::string contents =
1363
- ReadTestDataFile(files[arg].filename, files[arg].size_limit);
1364
-
1365
- std::string zcontents;
1366
- snappy::Compress(contents.data(), contents.size(), &zcontents);
1367
- char* dst = new char[contents.size()];
1368
-
1369
- SetBenchmarkBytesProcessed(static_cast<int64_t>(iters) *
1370
- static_cast<int64_t>(contents.size()));
1371
- SetBenchmarkLabel(files[arg].label);
1372
- StartBenchmarkTiming();
1373
- while (iters-- > 0) {
1374
- snappy::ByteArraySource source(zcontents.data(), zcontents.size());
1375
- snappy::UncheckedByteArraySink sink(dst);
1376
- CHECK(snappy::Uncompress(&source, &sink));
1377
- }
1378
- StopBenchmarkTiming();
1379
-
1380
- std::string s(dst, contents.size());
1381
- CHECK_EQ(contents, s);
1382
-
1383
- delete[] dst;
1384
- }
1385
-
1386
- BENCHMARK(BM_UFlatSink)->DenseRange(0, ARRAYSIZE(files) - 1);
1387
-
1388
- static void BM_ZFlat(int iters, int arg) {
1389
- StopBenchmarkTiming();
1390
-
1391
- // Pick file to process based on "arg"
1392
- CHECK_GE(arg, 0);
1393
- CHECK_LT(arg, ARRAYSIZE(files));
1394
- std::string contents =
1395
- ReadTestDataFile(files[arg].filename, files[arg].size_limit);
1396
-
1397
- char* dst = new char[snappy::MaxCompressedLength(contents.size())];
1398
-
1399
- SetBenchmarkBytesProcessed(static_cast<int64_t>(iters) *
1400
- static_cast<int64_t>(contents.size()));
1401
- StartBenchmarkTiming();
1402
-
1403
- size_t zsize = 0;
1404
- while (iters-- > 0) {
1405
- snappy::RawCompress(contents.data(), contents.size(), dst, &zsize);
1406
- }
1407
- StopBenchmarkTiming();
1408
- const double compression_ratio =
1409
- static_cast<double>(zsize) / std::max<size_t>(1, contents.size());
1410
- SetBenchmarkLabel(StrFormat("%s (%.2f %%)", files[arg].label,
1411
- 100.0 * compression_ratio));
1412
- VLOG(0) << StrFormat("compression for %s: %zd -> %zd bytes",
1413
- files[arg].label, static_cast<int>(contents.size()),
1414
- static_cast<int>(zsize));
1415
- delete[] dst;
1416
- }
1417
- BENCHMARK(BM_ZFlat)->DenseRange(0, ARRAYSIZE(files) - 1);
1418
-
1419
- static void BM_ZFlatAll(int iters, int arg) {
1420
- StopBenchmarkTiming();
1421
-
1422
- CHECK_EQ(arg, 0);
1423
- const int num_files = ARRAYSIZE(files);
1424
-
1425
- std::vector<std::string> contents(num_files);
1426
- std::vector<char*> dst(num_files);
1427
-
1428
- int64_t total_contents_size = 0;
1429
- for (int i = 0; i < num_files; ++i) {
1430
- contents[i] = ReadTestDataFile(files[i].filename, files[i].size_limit);
1431
- dst[i] = new char[snappy::MaxCompressedLength(contents[i].size())];
1432
- total_contents_size += contents[i].size();
1433
- }
1434
-
1435
- SetBenchmarkBytesProcessed(static_cast<int64_t>(iters) * total_contents_size);
1436
- StartBenchmarkTiming();
1437
-
1438
- size_t zsize = 0;
1439
- while (iters-- > 0) {
1440
- for (int i = 0; i < num_files; ++i) {
1441
- snappy::RawCompress(contents[i].data(), contents[i].size(), dst[i],
1442
- &zsize);
1443
- }
1444
- }
1445
- StopBenchmarkTiming();
1446
-
1447
- for (char* dst_item : dst) {
1448
- delete[] dst_item;
1449
- }
1450
- SetBenchmarkLabel(StrFormat("%d files", num_files));
1451
- }
1452
- BENCHMARK(BM_ZFlatAll)->DenseRange(0, 0);
1453
-
1454
- static void BM_ZFlatIncreasingTableSize(int iters, int arg) {
1455
- StopBenchmarkTiming();
1456
-
1457
- CHECK_EQ(arg, 0);
1458
- CHECK_GT(ARRAYSIZE(files), 0);
1459
- const std::string base_content =
1460
- ReadTestDataFile(files[0].filename, files[0].size_limit);
1461
-
1462
- std::vector<std::string> contents;
1463
- std::vector<char*> dst;
1464
- int64_t total_contents_size = 0;
1465
- for (int table_bits = kMinHashTableBits; table_bits <= kMaxHashTableBits;
1466
- ++table_bits) {
1467
- std::string content = base_content;
1468
- content.resize(1 << table_bits);
1469
- dst.push_back(new char[snappy::MaxCompressedLength(content.size())]);
1470
- total_contents_size += content.size();
1471
- contents.push_back(std::move(content));
1472
- }
1473
-
1474
- size_t zsize = 0;
1475
- SetBenchmarkBytesProcessed(static_cast<int64_t>(iters) * total_contents_size);
1476
- StartBenchmarkTiming();
1477
- while (iters-- > 0) {
1478
- for (size_t i = 0; i < contents.size(); ++i) {
1479
- snappy::RawCompress(contents[i].data(), contents[i].size(), dst[i],
1480
- &zsize);
1481
- }
1482
- }
1483
- StopBenchmarkTiming();
1484
-
1485
- for (char* dst_item : dst) {
1486
- delete[] dst_item;
1487
- }
1488
- SetBenchmarkLabel(StrFormat("%zd tables", contents.size()));
1489
- }
1490
- BENCHMARK(BM_ZFlatIncreasingTableSize)->DenseRange(0, 0);
1491
-
1492
- } // namespace snappy
1493
-
1494
- int main(int argc, char** argv) {
1495
- InitGoogle(argv[0], &argc, &argv, true);
1496
- RunSpecifiedBenchmarks();
1497
-
1498
- if (argc >= 2) {
1499
- for (int arg = 1; arg < argc; ++arg) {
1500
- if (FLAGS_write_compressed) {
1501
- snappy::CompressFile(argv[arg]);
1502
- } else if (FLAGS_write_uncompressed) {
1503
- snappy::UncompressFile(argv[arg]);
1504
- } else {
1505
- snappy::MeasureFile(argv[arg]);
1506
- }
1507
- }
1508
- return 0;
1509
- }
1510
-
1511
- return RUN_ALL_TESTS();
1512
- }