couchbase 3.0.3-universal-darwin-20

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1353) hide show
  1. checksums.yaml +7 -0
  2. data/LICENSE.txt +202 -0
  3. data/README.md +131 -0
  4. data/ext/CMakeLists.txt +130 -0
  5. data/ext/LICENSE.txt +202 -0
  6. data/ext/build_config.hxx.in +22 -0
  7. data/ext/build_version.hxx.in +30 -0
  8. data/ext/cmake/Backtrace.cmake +35 -0
  9. data/ext/cmake/BuildTracing.cmake +6 -0
  10. data/ext/cmake/Cache.cmake +29 -0
  11. data/ext/cmake/CompilerWarnings.cmake +84 -0
  12. data/ext/cmake/PreventInSourceBuilds.cmake +21 -0
  13. data/ext/cmake/Sanitizers.cmake +66 -0
  14. data/ext/cmake/StandardProjectSettings.cmake +40 -0
  15. data/ext/cmake/StaticAnalyzers.cmake +37 -0
  16. data/ext/cmake/Testing.cmake +49 -0
  17. data/ext/cmake/ThirdPartyDependencies.cmake +20 -0
  18. data/ext/cmake/VersionInfo.cmake +37 -0
  19. data/ext/couchbase/bucket.hxx +372 -0
  20. data/ext/couchbase/capabilities.hxx +117 -0
  21. data/ext/couchbase/cbcrypto/cbcrypto.cc +888 -0
  22. data/ext/couchbase/cbcrypto/cbcrypto.h +89 -0
  23. data/ext/couchbase/cbsasl/client.cc +48 -0
  24. data/ext/couchbase/cbsasl/client.h +127 -0
  25. data/ext/couchbase/cbsasl/context.cc +33 -0
  26. data/ext/couchbase/cbsasl/context.h +52 -0
  27. data/ext/couchbase/cbsasl/error.h +72 -0
  28. data/ext/couchbase/cbsasl/mechanism.cc +48 -0
  29. data/ext/couchbase/cbsasl/mechanism.h +55 -0
  30. data/ext/couchbase/cbsasl/plain/plain.cc +36 -0
  31. data/ext/couchbase/cbsasl/plain/plain.h +53 -0
  32. data/ext/couchbase/cbsasl/scram-sha/scram-sha.cc +390 -0
  33. data/ext/couchbase/cbsasl/scram-sha/scram-sha.h +185 -0
  34. data/ext/couchbase/cbsasl/scram-sha/stringutils.cc +81 -0
  35. data/ext/couchbase/cbsasl/scram-sha/stringutils.h +48 -0
  36. data/ext/couchbase/cluster.hxx +356 -0
  37. data/ext/couchbase/cluster_options.hxx +54 -0
  38. data/ext/couchbase/collections_manifest.hxx +88 -0
  39. data/ext/couchbase/configuration.hxx +652 -0
  40. data/ext/couchbase/couchbase.cxx +8015 -0
  41. data/ext/couchbase/diagnostics.hxx +248 -0
  42. data/ext/couchbase/document_id.hxx +40 -0
  43. data/ext/couchbase/error_context/analytics.hxx +46 -0
  44. data/ext/couchbase/error_context/http.hxx +44 -0
  45. data/ext/couchbase/error_context/key_value.hxx +47 -0
  46. data/ext/couchbase/error_context/query.hxx +46 -0
  47. data/ext/couchbase/error_context/search.hxx +47 -0
  48. data/ext/couchbase/error_context/view.hxx +47 -0
  49. data/ext/couchbase/error_map.hxx +261 -0
  50. data/ext/couchbase/errors.hxx +706 -0
  51. data/ext/couchbase/io/dns_client.hxx +217 -0
  52. data/ext/couchbase/io/dns_codec.hxx +206 -0
  53. data/ext/couchbase/io/dns_config.hxx +116 -0
  54. data/ext/couchbase/io/dns_message.hxx +555 -0
  55. data/ext/couchbase/io/http_command.hxx +111 -0
  56. data/ext/couchbase/io/http_context.hxx +37 -0
  57. data/ext/couchbase/io/http_message.hxx +47 -0
  58. data/ext/couchbase/io/http_parser.hxx +176 -0
  59. data/ext/couchbase/io/http_session.hxx +444 -0
  60. data/ext/couchbase/io/http_session_manager.hxx +264 -0
  61. data/ext/couchbase/io/mcbp_command.hxx +249 -0
  62. data/ext/couchbase/io/mcbp_context.hxx +37 -0
  63. data/ext/couchbase/io/mcbp_message.hxx +63 -0
  64. data/ext/couchbase/io/mcbp_parser.hxx +101 -0
  65. data/ext/couchbase/io/mcbp_session.hxx +1350 -0
  66. data/ext/couchbase/io/query_cache.hxx +61 -0
  67. data/ext/couchbase/io/retry_action.hxx +30 -0
  68. data/ext/couchbase/io/retry_context.hxx +38 -0
  69. data/ext/couchbase/io/retry_orchestrator.hxx +112 -0
  70. data/ext/couchbase/io/retry_reason.hxx +235 -0
  71. data/ext/couchbase/io/retry_strategy.hxx +156 -0
  72. data/ext/couchbase/io/streams.hxx +216 -0
  73. data/ext/couchbase/mutation_token.hxx +38 -0
  74. data/ext/couchbase/operations.hxx +109 -0
  75. data/ext/couchbase/operations/analytics_dataset_create.hxx +125 -0
  76. data/ext/couchbase/operations/analytics_dataset_drop.hxx +112 -0
  77. data/ext/couchbase/operations/analytics_dataset_get_all.hxx +114 -0
  78. data/ext/couchbase/operations/analytics_dataverse_create.hxx +112 -0
  79. data/ext/couchbase/operations/analytics_dataverse_drop.hxx +111 -0
  80. data/ext/couchbase/operations/analytics_get_pending_mutations.hxx +99 -0
  81. data/ext/couchbase/operations/analytics_index_create.hxx +135 -0
  82. data/ext/couchbase/operations/analytics_index_drop.hxx +117 -0
  83. data/ext/couchbase/operations/analytics_index_get_all.hxx +113 -0
  84. data/ext/couchbase/operations/analytics_link_connect.hxx +109 -0
  85. data/ext/couchbase/operations/analytics_link_disconnect.hxx +108 -0
  86. data/ext/couchbase/operations/bucket_create.hxx +171 -0
  87. data/ext/couchbase/operations/bucket_drop.hxx +70 -0
  88. data/ext/couchbase/operations/bucket_flush.hxx +69 -0
  89. data/ext/couchbase/operations/bucket_get.hxx +78 -0
  90. data/ext/couchbase/operations/bucket_get_all.hxx +73 -0
  91. data/ext/couchbase/operations/bucket_settings.hxx +166 -0
  92. data/ext/couchbase/operations/bucket_update.hxx +147 -0
  93. data/ext/couchbase/operations/cluster_developer_preview_enable.hxx +64 -0
  94. data/ext/couchbase/operations/collection_create.hxx +102 -0
  95. data/ext/couchbase/operations/collection_drop.hxx +92 -0
  96. data/ext/couchbase/operations/collections_manifest_get.hxx +66 -0
  97. data/ext/couchbase/operations/design_document.hxx +59 -0
  98. data/ext/couchbase/operations/document_analytics.hxx +316 -0
  99. data/ext/couchbase/operations/document_append.hxx +72 -0
  100. data/ext/couchbase/operations/document_decrement.hxx +83 -0
  101. data/ext/couchbase/operations/document_exists.hxx +83 -0
  102. data/ext/couchbase/operations/document_get.hxx +66 -0
  103. data/ext/couchbase/operations/document_get_and_lock.hxx +67 -0
  104. data/ext/couchbase/operations/document_get_and_touch.hxx +67 -0
  105. data/ext/couchbase/operations/document_get_projected.hxx +257 -0
  106. data/ext/couchbase/operations/document_increment.hxx +85 -0
  107. data/ext/couchbase/operations/document_insert.hxx +77 -0
  108. data/ext/couchbase/operations/document_lookup_in.hxx +112 -0
  109. data/ext/couchbase/operations/document_mutate_in.hxx +151 -0
  110. data/ext/couchbase/operations/document_prepend.hxx +72 -0
  111. data/ext/couchbase/operations/document_query.hxx +440 -0
  112. data/ext/couchbase/operations/document_remove.hxx +72 -0
  113. data/ext/couchbase/operations/document_replace.hxx +79 -0
  114. data/ext/couchbase/operations/document_search.hxx +392 -0
  115. data/ext/couchbase/operations/document_touch.hxx +63 -0
  116. data/ext/couchbase/operations/document_unlock.hxx +63 -0
  117. data/ext/couchbase/operations/document_upsert.hxx +77 -0
  118. data/ext/couchbase/operations/document_view.hxx +245 -0
  119. data/ext/couchbase/operations/group_drop.hxx +72 -0
  120. data/ext/couchbase/operations/group_get.hxx +80 -0
  121. data/ext/couchbase/operations/group_get_all.hxx +77 -0
  122. data/ext/couchbase/operations/group_upsert.hxx +125 -0
  123. data/ext/couchbase/operations/http_noop.hxx +78 -0
  124. data/ext/couchbase/operations/mcbp_noop.hxx +55 -0
  125. data/ext/couchbase/operations/query_index_build_deferred.hxx +93 -0
  126. data/ext/couchbase/operations/query_index_create.hxx +152 -0
  127. data/ext/couchbase/operations/query_index_drop.hxx +126 -0
  128. data/ext/couchbase/operations/query_index_get_all.hxx +124 -0
  129. data/ext/couchbase/operations/rbac.hxx +276 -0
  130. data/ext/couchbase/operations/role_get_all.hxx +77 -0
  131. data/ext/couchbase/operations/scope_create.hxx +95 -0
  132. data/ext/couchbase/operations/scope_drop.hxx +89 -0
  133. data/ext/couchbase/operations/scope_get_all.hxx +82 -0
  134. data/ext/couchbase/operations/search_get_stats.hxx +60 -0
  135. data/ext/couchbase/operations/search_index.hxx +79 -0
  136. data/ext/couchbase/operations/search_index_analyze_document.hxx +105 -0
  137. data/ext/couchbase/operations/search_index_control_ingest.hxx +93 -0
  138. data/ext/couchbase/operations/search_index_control_plan_freeze.hxx +93 -0
  139. data/ext/couchbase/operations/search_index_control_query.hxx +93 -0
  140. data/ext/couchbase/operations/search_index_drop.hxx +90 -0
  141. data/ext/couchbase/operations/search_index_get.hxx +93 -0
  142. data/ext/couchbase/operations/search_index_get_all.hxx +89 -0
  143. data/ext/couchbase/operations/search_index_get_documents_count.hxx +101 -0
  144. data/ext/couchbase/operations/search_index_get_stats.hxx +88 -0
  145. data/ext/couchbase/operations/search_index_upsert.hxx +119 -0
  146. data/ext/couchbase/operations/user_drop.hxx +73 -0
  147. data/ext/couchbase/operations/user_get.hxx +81 -0
  148. data/ext/couchbase/operations/user_get_all.hxx +78 -0
  149. data/ext/couchbase/operations/user_upsert.hxx +132 -0
  150. data/ext/couchbase/operations/view_index_drop.hxx +68 -0
  151. data/ext/couchbase/operations/view_index_get.hxx +97 -0
  152. data/ext/couchbase/operations/view_index_get_all.hxx +132 -0
  153. data/ext/couchbase/operations/view_index_upsert.hxx +88 -0
  154. data/ext/couchbase/origin.hxx +179 -0
  155. data/ext/couchbase/platform/backtrace.c +189 -0
  156. data/ext/couchbase/platform/backtrace.h +54 -0
  157. data/ext/couchbase/platform/base64.cc +234 -0
  158. data/ext/couchbase/platform/base64.h +47 -0
  159. data/ext/couchbase/platform/random.cc +119 -0
  160. data/ext/couchbase/platform/random.h +39 -0
  161. data/ext/couchbase/platform/string_hex.cc +99 -0
  162. data/ext/couchbase/platform/string_hex.h +50 -0
  163. data/ext/couchbase/platform/terminate_handler.cc +130 -0
  164. data/ext/couchbase/platform/terminate_handler.h +36 -0
  165. data/ext/couchbase/platform/uuid.cc +96 -0
  166. data/ext/couchbase/platform/uuid.h +56 -0
  167. data/ext/couchbase/protocol/client_opcode.hxx +632 -0
  168. data/ext/couchbase/protocol/client_request.hxx +161 -0
  169. data/ext/couchbase/protocol/client_response.hxx +221 -0
  170. data/ext/couchbase/protocol/cmd_append.hxx +145 -0
  171. data/ext/couchbase/protocol/cmd_cluster_map_change_notification.hxx +79 -0
  172. data/ext/couchbase/protocol/cmd_decrement.hxx +187 -0
  173. data/ext/couchbase/protocol/cmd_exists.hxx +172 -0
  174. data/ext/couchbase/protocol/cmd_get.hxx +122 -0
  175. data/ext/couchbase/protocol/cmd_get_and_lock.hxx +142 -0
  176. data/ext/couchbase/protocol/cmd_get_and_touch.hxx +142 -0
  177. data/ext/couchbase/protocol/cmd_get_cluster_config.hxx +126 -0
  178. data/ext/couchbase/protocol/cmd_get_collection_id.hxx +117 -0
  179. data/ext/couchbase/protocol/cmd_get_collections_manifest.hxx +99 -0
  180. data/ext/couchbase/protocol/cmd_get_error_map.hxx +126 -0
  181. data/ext/couchbase/protocol/cmd_hello.hxx +157 -0
  182. data/ext/couchbase/protocol/cmd_increment.hxx +187 -0
  183. data/ext/couchbase/protocol/cmd_info.hxx +25 -0
  184. data/ext/couchbase/protocol/cmd_insert.hxx +172 -0
  185. data/ext/couchbase/protocol/cmd_lookup_in.hxx +227 -0
  186. data/ext/couchbase/protocol/cmd_mutate_in.hxx +406 -0
  187. data/ext/couchbase/protocol/cmd_noop.hxx +82 -0
  188. data/ext/couchbase/protocol/cmd_prepend.hxx +145 -0
  189. data/ext/couchbase/protocol/cmd_remove.hxx +134 -0
  190. data/ext/couchbase/protocol/cmd_replace.hxx +172 -0
  191. data/ext/couchbase/protocol/cmd_sasl_auth.hxx +106 -0
  192. data/ext/couchbase/protocol/cmd_sasl_list_mechs.hxx +100 -0
  193. data/ext/couchbase/protocol/cmd_sasl_step.hxx +104 -0
  194. data/ext/couchbase/protocol/cmd_select_bucket.hxx +85 -0
  195. data/ext/couchbase/protocol/cmd_touch.hxx +102 -0
  196. data/ext/couchbase/protocol/cmd_unlock.hxx +95 -0
  197. data/ext/couchbase/protocol/cmd_upsert.hxx +172 -0
  198. data/ext/couchbase/protocol/datatype.hxx +48 -0
  199. data/ext/couchbase/protocol/durability_level.hxx +83 -0
  200. data/ext/couchbase/protocol/enhanced_error_info.hxx +28 -0
  201. data/ext/couchbase/protocol/frame_info_id.hxx +187 -0
  202. data/ext/couchbase/protocol/hello_feature.hxx +264 -0
  203. data/ext/couchbase/protocol/magic.hxx +83 -0
  204. data/ext/couchbase/protocol/server_opcode.hxx +57 -0
  205. data/ext/couchbase/protocol/server_request.hxx +122 -0
  206. data/ext/couchbase/protocol/status.hxx +343 -0
  207. data/ext/couchbase/protocol/unsigned_leb128.h +195 -0
  208. data/ext/couchbase/service_type.hxx +60 -0
  209. data/ext/couchbase/timeout_defaults.hxx +41 -0
  210. data/ext/couchbase/utils/byteswap.hxx +33 -0
  211. data/ext/couchbase/utils/connection_string.hxx +379 -0
  212. data/ext/couchbase/utils/crc32.hxx +48 -0
  213. data/ext/couchbase/utils/url_codec.hxx +225 -0
  214. data/ext/couchbase/version.hxx +38 -0
  215. data/ext/extconf.rb +98 -0
  216. data/ext/test/CMakeLists.txt +5 -0
  217. data/ext/test/test_helper.hxx +141 -0
  218. data/ext/test/test_helper_native.hxx +56 -0
  219. data/ext/test/test_helper_ruby.hxx +72 -0
  220. data/ext/test/test_native_binary_operations.cxx +186 -0
  221. data/ext/test/test_native_diagnostics.cxx +436 -0
  222. data/ext/test/test_native_trivial_crud.cxx +83 -0
  223. data/ext/test/test_ruby_trivial_crud.cxx +35 -0
  224. data/ext/test/test_ruby_trivial_query.cxx +34 -0
  225. data/ext/third_party/asio/asio/include/asio.hpp +182 -0
  226. data/ext/third_party/asio/asio/include/asio/any_io_executor.hpp +71 -0
  227. data/ext/third_party/asio/asio/include/asio/associated_allocator.hpp +125 -0
  228. data/ext/third_party/asio/asio/include/asio/associated_executor.hpp +166 -0
  229. data/ext/third_party/asio/asio/include/asio/async_result.hpp +582 -0
  230. data/ext/third_party/asio/asio/include/asio/awaitable.hpp +133 -0
  231. data/ext/third_party/asio/asio/include/asio/basic_datagram_socket.hpp +1215 -0
  232. data/ext/third_party/asio/asio/include/asio/basic_deadline_timer.hpp +693 -0
  233. data/ext/third_party/asio/asio/include/asio/basic_io_object.hpp +290 -0
  234. data/ext/third_party/asio/asio/include/asio/basic_raw_socket.hpp +1206 -0
  235. data/ext/third_party/asio/asio/include/asio/basic_seq_packet_socket.hpp +761 -0
  236. data/ext/third_party/asio/asio/include/asio/basic_serial_port.hpp +907 -0
  237. data/ext/third_party/asio/asio/include/asio/basic_signal_set.hpp +568 -0
  238. data/ext/third_party/asio/asio/include/asio/basic_socket.hpp +1894 -0
  239. data/ext/third_party/asio/asio/include/asio/basic_socket_acceptor.hpp +2501 -0
  240. data/ext/third_party/asio/asio/include/asio/basic_socket_iostream.hpp +407 -0
  241. data/ext/third_party/asio/asio/include/asio/basic_socket_streambuf.hpp +687 -0
  242. data/ext/third_party/asio/asio/include/asio/basic_stream_socket.hpp +1053 -0
  243. data/ext/third_party/asio/asio/include/asio/basic_streambuf.hpp +452 -0
  244. data/ext/third_party/asio/asio/include/asio/basic_streambuf_fwd.hpp +36 -0
  245. data/ext/third_party/asio/asio/include/asio/basic_waitable_timer.hpp +811 -0
  246. data/ext/third_party/asio/asio/include/asio/bind_executor.hpp +575 -0
  247. data/ext/third_party/asio/asio/include/asio/buffer.hpp +2496 -0
  248. data/ext/third_party/asio/asio/include/asio/buffered_read_stream.hpp +253 -0
  249. data/ext/third_party/asio/asio/include/asio/buffered_read_stream_fwd.hpp +25 -0
  250. data/ext/third_party/asio/asio/include/asio/buffered_stream.hpp +279 -0
  251. data/ext/third_party/asio/asio/include/asio/buffered_stream_fwd.hpp +25 -0
  252. data/ext/third_party/asio/asio/include/asio/buffered_write_stream.hpp +245 -0
  253. data/ext/third_party/asio/asio/include/asio/buffered_write_stream_fwd.hpp +25 -0
  254. data/ext/third_party/asio/asio/include/asio/buffers_iterator.hpp +521 -0
  255. data/ext/third_party/asio/asio/include/asio/co_spawn.hpp +471 -0
  256. data/ext/third_party/asio/asio/include/asio/completion_condition.hpp +218 -0
  257. data/ext/third_party/asio/asio/include/asio/compose.hpp +136 -0
  258. data/ext/third_party/asio/asio/include/asio/connect.hpp +1076 -0
  259. data/ext/third_party/asio/asio/include/asio/coroutine.hpp +328 -0
  260. data/ext/third_party/asio/asio/include/asio/deadline_timer.hpp +38 -0
  261. data/ext/third_party/asio/asio/include/asio/defer.hpp +130 -0
  262. data/ext/third_party/asio/asio/include/asio/detached.hpp +112 -0
  263. data/ext/third_party/asio/asio/include/asio/detail/array.hpp +38 -0
  264. data/ext/third_party/asio/asio/include/asio/detail/array_fwd.hpp +34 -0
  265. data/ext/third_party/asio/asio/include/asio/detail/assert.hpp +32 -0
  266. data/ext/third_party/asio/asio/include/asio/detail/atomic_count.hpp +64 -0
  267. data/ext/third_party/asio/asio/include/asio/detail/base_from_completion_cond.hpp +69 -0
  268. data/ext/third_party/asio/asio/include/asio/detail/bind_handler.hpp +934 -0
  269. data/ext/third_party/asio/asio/include/asio/detail/blocking_executor_op.hpp +107 -0
  270. data/ext/third_party/asio/asio/include/asio/detail/buffer_resize_guard.hpp +66 -0
  271. data/ext/third_party/asio/asio/include/asio/detail/buffer_sequence_adapter.hpp +650 -0
  272. data/ext/third_party/asio/asio/include/asio/detail/buffered_stream_storage.hpp +126 -0
  273. data/ext/third_party/asio/asio/include/asio/detail/bulk_executor_op.hpp +88 -0
  274. data/ext/third_party/asio/asio/include/asio/detail/call_stack.hpp +125 -0
  275. data/ext/third_party/asio/asio/include/asio/detail/chrono.hpp +66 -0
  276. data/ext/third_party/asio/asio/include/asio/detail/chrono_time_traits.hpp +190 -0
  277. data/ext/third_party/asio/asio/include/asio/detail/completion_handler.hpp +88 -0
  278. data/ext/third_party/asio/asio/include/asio/detail/concurrency_hint.hpp +94 -0
  279. data/ext/third_party/asio/asio/include/asio/detail/conditionally_enabled_event.hpp +120 -0
  280. data/ext/third_party/asio/asio/include/asio/detail/conditionally_enabled_mutex.hpp +149 -0
  281. data/ext/third_party/asio/asio/include/asio/detail/config.hpp +1822 -0
  282. data/ext/third_party/asio/asio/include/asio/detail/consuming_buffers.hpp +414 -0
  283. data/ext/third_party/asio/asio/include/asio/detail/cstddef.hpp +31 -0
  284. data/ext/third_party/asio/asio/include/asio/detail/cstdint.hpp +60 -0
  285. data/ext/third_party/asio/asio/include/asio/detail/date_time_fwd.hpp +34 -0
  286. data/ext/third_party/asio/asio/include/asio/detail/deadline_timer_service.hpp +295 -0
  287. data/ext/third_party/asio/asio/include/asio/detail/dependent_type.hpp +36 -0
  288. data/ext/third_party/asio/asio/include/asio/detail/descriptor_ops.hpp +139 -0
  289. data/ext/third_party/asio/asio/include/asio/detail/descriptor_read_op.hpp +148 -0
  290. data/ext/third_party/asio/asio/include/asio/detail/descriptor_write_op.hpp +148 -0
  291. data/ext/third_party/asio/asio/include/asio/detail/dev_poll_reactor.hpp +218 -0
  292. data/ext/third_party/asio/asio/include/asio/detail/epoll_reactor.hpp +266 -0
  293. data/ext/third_party/asio/asio/include/asio/detail/event.hpp +48 -0
  294. data/ext/third_party/asio/asio/include/asio/detail/eventfd_select_interrupter.hpp +83 -0
  295. data/ext/third_party/asio/asio/include/asio/detail/executor_function.hpp +203 -0
  296. data/ext/third_party/asio/asio/include/asio/detail/executor_op.hpp +84 -0
  297. data/ext/third_party/asio/asio/include/asio/detail/fd_set_adapter.hpp +39 -0
  298. data/ext/third_party/asio/asio/include/asio/detail/fenced_block.hpp +80 -0
  299. data/ext/third_party/asio/asio/include/asio/detail/functional.hpp +38 -0
  300. data/ext/third_party/asio/asio/include/asio/detail/future.hpp +33 -0
  301. data/ext/third_party/asio/asio/include/asio/detail/gcc_arm_fenced_block.hpp +91 -0
  302. data/ext/third_party/asio/asio/include/asio/detail/gcc_hppa_fenced_block.hpp +68 -0
  303. data/ext/third_party/asio/asio/include/asio/detail/gcc_sync_fenced_block.hpp +65 -0
  304. data/ext/third_party/asio/asio/include/asio/detail/gcc_x86_fenced_block.hpp +99 -0
  305. data/ext/third_party/asio/asio/include/asio/detail/global.hpp +52 -0
  306. data/ext/third_party/asio/asio/include/asio/detail/handler_alloc_helpers.hpp +284 -0
  307. data/ext/third_party/asio/asio/include/asio/detail/handler_cont_helpers.hpp +45 -0
  308. data/ext/third_party/asio/asio/include/asio/detail/handler_invoke_helpers.hpp +80 -0
  309. data/ext/third_party/asio/asio/include/asio/detail/handler_tracking.hpp +264 -0
  310. data/ext/third_party/asio/asio/include/asio/detail/handler_type_requirements.hpp +556 -0
  311. data/ext/third_party/asio/asio/include/asio/detail/handler_work.hpp +438 -0
  312. data/ext/third_party/asio/asio/include/asio/detail/hash_map.hpp +331 -0
  313. data/ext/third_party/asio/asio/include/asio/detail/impl/buffer_sequence_adapter.ipp +118 -0
  314. data/ext/third_party/asio/asio/include/asio/detail/impl/descriptor_ops.ipp +608 -0
  315. data/ext/third_party/asio/asio/include/asio/detail/impl/dev_poll_reactor.hpp +91 -0
  316. data/ext/third_party/asio/asio/include/asio/detail/impl/dev_poll_reactor.ipp +446 -0
  317. data/ext/third_party/asio/asio/include/asio/detail/impl/epoll_reactor.hpp +89 -0
  318. data/ext/third_party/asio/asio/include/asio/detail/impl/epoll_reactor.ipp +787 -0
  319. data/ext/third_party/asio/asio/include/asio/detail/impl/eventfd_select_interrupter.ipp +169 -0
  320. data/ext/third_party/asio/asio/include/asio/detail/impl/handler_tracking.ipp +396 -0
  321. data/ext/third_party/asio/asio/include/asio/detail/impl/kqueue_reactor.hpp +93 -0
  322. data/ext/third_party/asio/asio/include/asio/detail/impl/kqueue_reactor.ipp +570 -0
  323. data/ext/third_party/asio/asio/include/asio/detail/impl/null_event.ipp +74 -0
  324. data/ext/third_party/asio/asio/include/asio/detail/impl/pipe_select_interrupter.ipp +129 -0
  325. data/ext/third_party/asio/asio/include/asio/detail/impl/posix_event.ipp +59 -0
  326. data/ext/third_party/asio/asio/include/asio/detail/impl/posix_mutex.ipp +46 -0
  327. data/ext/third_party/asio/asio/include/asio/detail/impl/posix_thread.ipp +84 -0
  328. data/ext/third_party/asio/asio/include/asio/detail/impl/posix_tss_ptr.ipp +46 -0
  329. data/ext/third_party/asio/asio/include/asio/detail/impl/reactive_descriptor_service.ipp +223 -0
  330. data/ext/third_party/asio/asio/include/asio/detail/impl/reactive_serial_port_service.ipp +149 -0
  331. data/ext/third_party/asio/asio/include/asio/detail/impl/reactive_socket_service_base.ipp +300 -0
  332. data/ext/third_party/asio/asio/include/asio/detail/impl/resolver_service_base.ipp +158 -0
  333. data/ext/third_party/asio/asio/include/asio/detail/impl/scheduler.ipp +654 -0
  334. data/ext/third_party/asio/asio/include/asio/detail/impl/select_reactor.hpp +100 -0
  335. data/ext/third_party/asio/asio/include/asio/detail/impl/select_reactor.ipp +338 -0
  336. data/ext/third_party/asio/asio/include/asio/detail/impl/service_registry.hpp +94 -0
  337. data/ext/third_party/asio/asio/include/asio/detail/impl/service_registry.ipp +197 -0
  338. data/ext/third_party/asio/asio/include/asio/detail/impl/signal_set_service.ipp +668 -0
  339. data/ext/third_party/asio/asio/include/asio/detail/impl/socket_ops.ipp +3962 -0
  340. data/ext/third_party/asio/asio/include/asio/detail/impl/socket_select_interrupter.ipp +185 -0
  341. data/ext/third_party/asio/asio/include/asio/detail/impl/strand_executor_service.hpp +385 -0
  342. data/ext/third_party/asio/asio/include/asio/detail/impl/strand_executor_service.ipp +134 -0
  343. data/ext/third_party/asio/asio/include/asio/detail/impl/strand_service.hpp +117 -0
  344. data/ext/third_party/asio/asio/include/asio/detail/impl/strand_service.ipp +178 -0
  345. data/ext/third_party/asio/asio/include/asio/detail/impl/throw_error.ipp +60 -0
  346. data/ext/third_party/asio/asio/include/asio/detail/impl/timer_queue_ptime.ipp +91 -0
  347. data/ext/third_party/asio/asio/include/asio/detail/impl/timer_queue_set.ipp +101 -0
  348. data/ext/third_party/asio/asio/include/asio/detail/impl/win_event.ipp +76 -0
  349. data/ext/third_party/asio/asio/include/asio/detail/impl/win_iocp_handle_service.ipp +525 -0
  350. data/ext/third_party/asio/asio/include/asio/detail/impl/win_iocp_io_context.hpp +103 -0
  351. data/ext/third_party/asio/asio/include/asio/detail/impl/win_iocp_io_context.ipp +603 -0
  352. data/ext/third_party/asio/asio/include/asio/detail/impl/win_iocp_serial_port_service.ipp +192 -0
  353. data/ext/third_party/asio/asio/include/asio/detail/impl/win_iocp_socket_service_base.ipp +801 -0
  354. data/ext/third_party/asio/asio/include/asio/detail/impl/win_mutex.ipp +84 -0
  355. data/ext/third_party/asio/asio/include/asio/detail/impl/win_object_handle_service.ipp +448 -0
  356. data/ext/third_party/asio/asio/include/asio/detail/impl/win_static_mutex.ipp +136 -0
  357. data/ext/third_party/asio/asio/include/asio/detail/impl/win_thread.ipp +150 -0
  358. data/ext/third_party/asio/asio/include/asio/detail/impl/win_tss_ptr.ipp +57 -0
  359. data/ext/third_party/asio/asio/include/asio/detail/impl/winrt_ssocket_service_base.ipp +626 -0
  360. data/ext/third_party/asio/asio/include/asio/detail/impl/winrt_timer_scheduler.hpp +92 -0
  361. data/ext/third_party/asio/asio/include/asio/detail/impl/winrt_timer_scheduler.ipp +121 -0
  362. data/ext/third_party/asio/asio/include/asio/detail/impl/winsock_init.ipp +82 -0
  363. data/ext/third_party/asio/asio/include/asio/detail/io_control.hpp +84 -0
  364. data/ext/third_party/asio/asio/include/asio/detail/io_object_impl.hpp +175 -0
  365. data/ext/third_party/asio/asio/include/asio/detail/is_buffer_sequence.hpp +312 -0
  366. data/ext/third_party/asio/asio/include/asio/detail/is_executor.hpp +126 -0
  367. data/ext/third_party/asio/asio/include/asio/detail/keyword_tss_ptr.hpp +70 -0
  368. data/ext/third_party/asio/asio/include/asio/detail/kqueue_reactor.hpp +242 -0
  369. data/ext/third_party/asio/asio/include/asio/detail/limits.hpp +26 -0
  370. data/ext/third_party/asio/asio/include/asio/detail/local_free_on_block_exit.hpp +59 -0
  371. data/ext/third_party/asio/asio/include/asio/detail/macos_fenced_block.hpp +62 -0
  372. data/ext/third_party/asio/asio/include/asio/detail/memory.hpp +73 -0
  373. data/ext/third_party/asio/asio/include/asio/detail/mutex.hpp +48 -0
  374. data/ext/third_party/asio/asio/include/asio/detail/non_const_lvalue.hpp +54 -0
  375. data/ext/third_party/asio/asio/include/asio/detail/noncopyable.hpp +43 -0
  376. data/ext/third_party/asio/asio/include/asio/detail/null_event.hpp +106 -0
  377. data/ext/third_party/asio/asio/include/asio/detail/null_fenced_block.hpp +47 -0
  378. data/ext/third_party/asio/asio/include/asio/detail/null_global.hpp +59 -0
  379. data/ext/third_party/asio/asio/include/asio/detail/null_mutex.hpp +64 -0
  380. data/ext/third_party/asio/asio/include/asio/detail/null_reactor.hpp +68 -0
  381. data/ext/third_party/asio/asio/include/asio/detail/null_signal_blocker.hpp +69 -0
  382. data/ext/third_party/asio/asio/include/asio/detail/null_socket_service.hpp +519 -0
  383. data/ext/third_party/asio/asio/include/asio/detail/null_static_mutex.hpp +60 -0
  384. data/ext/third_party/asio/asio/include/asio/detail/null_thread.hpp +67 -0
  385. data/ext/third_party/asio/asio/include/asio/detail/null_tss_ptr.hpp +68 -0
  386. data/ext/third_party/asio/asio/include/asio/detail/object_pool.hpp +171 -0
  387. data/ext/third_party/asio/asio/include/asio/detail/old_win_sdk_compat.hpp +214 -0
  388. data/ext/third_party/asio/asio/include/asio/detail/op_queue.hpp +162 -0
  389. data/ext/third_party/asio/asio/include/asio/detail/operation.hpp +38 -0
  390. data/ext/third_party/asio/asio/include/asio/detail/pipe_select_interrupter.hpp +89 -0
  391. data/ext/third_party/asio/asio/include/asio/detail/pop_options.hpp +141 -0
  392. data/ext/third_party/asio/asio/include/asio/detail/posix_event.hpp +175 -0
  393. data/ext/third_party/asio/asio/include/asio/detail/posix_fd_set_adapter.hpp +118 -0
  394. data/ext/third_party/asio/asio/include/asio/detail/posix_global.hpp +80 -0
  395. data/ext/third_party/asio/asio/include/asio/detail/posix_mutex.hpp +76 -0
  396. data/ext/third_party/asio/asio/include/asio/detail/posix_signal_blocker.hpp +85 -0
  397. data/ext/third_party/asio/asio/include/asio/detail/posix_static_mutex.hpp +64 -0
  398. data/ext/third_party/asio/asio/include/asio/detail/posix_thread.hpp +109 -0
  399. data/ext/third_party/asio/asio/include/asio/detail/posix_tss_ptr.hpp +79 -0
  400. data/ext/third_party/asio/asio/include/asio/detail/push_options.hpp +185 -0
  401. data/ext/third_party/asio/asio/include/asio/detail/reactive_descriptor_service.hpp +416 -0
  402. data/ext/third_party/asio/asio/include/asio/detail/reactive_null_buffers_op.hpp +98 -0
  403. data/ext/third_party/asio/asio/include/asio/detail/reactive_serial_port_service.hpp +237 -0
  404. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_accept_op.hpp +242 -0
  405. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_connect_op.hpp +123 -0
  406. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_recv_op.hpp +159 -0
  407. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_recvfrom_op.hpp +164 -0
  408. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_recvmsg_op.hpp +145 -0
  409. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_send_op.hpp +162 -0
  410. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_sendto_op.hpp +156 -0
  411. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_service.hpp +528 -0
  412. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_service_base.hpp +541 -0
  413. data/ext/third_party/asio/asio/include/asio/detail/reactive_wait_op.hpp +98 -0
  414. data/ext/third_party/asio/asio/include/asio/detail/reactor.hpp +32 -0
  415. data/ext/third_party/asio/asio/include/asio/detail/reactor_fwd.hpp +40 -0
  416. data/ext/third_party/asio/asio/include/asio/detail/reactor_op.hpp +67 -0
  417. data/ext/third_party/asio/asio/include/asio/detail/reactor_op_queue.hpp +168 -0
  418. data/ext/third_party/asio/asio/include/asio/detail/recycling_allocator.hpp +106 -0
  419. data/ext/third_party/asio/asio/include/asio/detail/regex_fwd.hpp +35 -0
  420. data/ext/third_party/asio/asio/include/asio/detail/resolve_endpoint_op.hpp +140 -0
  421. data/ext/third_party/asio/asio/include/asio/detail/resolve_op.hpp +45 -0
  422. data/ext/third_party/asio/asio/include/asio/detail/resolve_query_op.hpp +150 -0
  423. data/ext/third_party/asio/asio/include/asio/detail/resolver_service.hpp +145 -0
  424. data/ext/third_party/asio/asio/include/asio/detail/resolver_service_base.hpp +143 -0
  425. data/ext/third_party/asio/asio/include/asio/detail/scheduler.hpp +232 -0
  426. data/ext/third_party/asio/asio/include/asio/detail/scheduler_operation.hpp +78 -0
  427. data/ext/third_party/asio/asio/include/asio/detail/scheduler_thread_info.hpp +40 -0
  428. data/ext/third_party/asio/asio/include/asio/detail/scoped_lock.hpp +101 -0
  429. data/ext/third_party/asio/asio/include/asio/detail/scoped_ptr.hpp +87 -0
  430. data/ext/third_party/asio/asio/include/asio/detail/select_interrupter.hpp +46 -0
  431. data/ext/third_party/asio/asio/include/asio/detail/select_reactor.hpp +238 -0
  432. data/ext/third_party/asio/asio/include/asio/detail/service_registry.hpp +164 -0
  433. data/ext/third_party/asio/asio/include/asio/detail/signal_blocker.hpp +44 -0
  434. data/ext/third_party/asio/asio/include/asio/detail/signal_handler.hpp +90 -0
  435. data/ext/third_party/asio/asio/include/asio/detail/signal_init.hpp +47 -0
  436. data/ext/third_party/asio/asio/include/asio/detail/signal_op.hpp +49 -0
  437. data/ext/third_party/asio/asio/include/asio/detail/signal_set_service.hpp +229 -0
  438. data/ext/third_party/asio/asio/include/asio/detail/socket_holder.hpp +98 -0
  439. data/ext/third_party/asio/asio/include/asio/detail/socket_ops.hpp +383 -0
  440. data/ext/third_party/asio/asio/include/asio/detail/socket_option.hpp +316 -0
  441. data/ext/third_party/asio/asio/include/asio/detail/socket_select_interrupter.hpp +91 -0
  442. data/ext/third_party/asio/asio/include/asio/detail/socket_types.hpp +416 -0
  443. data/ext/third_party/asio/asio/include/asio/detail/solaris_fenced_block.hpp +62 -0
  444. data/ext/third_party/asio/asio/include/asio/detail/source_location.hpp +45 -0
  445. data/ext/third_party/asio/asio/include/asio/detail/static_mutex.hpp +52 -0
  446. data/ext/third_party/asio/asio/include/asio/detail/std_event.hpp +188 -0
  447. data/ext/third_party/asio/asio/include/asio/detail/std_fenced_block.hpp +62 -0
  448. data/ext/third_party/asio/asio/include/asio/detail/std_global.hpp +70 -0
  449. data/ext/third_party/asio/asio/include/asio/detail/std_mutex.hpp +73 -0
  450. data/ext/third_party/asio/asio/include/asio/detail/std_static_mutex.hpp +81 -0
  451. data/ext/third_party/asio/asio/include/asio/detail/std_thread.hpp +71 -0
  452. data/ext/third_party/asio/asio/include/asio/detail/strand_executor_service.hpp +166 -0
  453. data/ext/third_party/asio/asio/include/asio/detail/strand_service.hpp +145 -0
  454. data/ext/third_party/asio/asio/include/asio/detail/string_view.hpp +47 -0
  455. data/ext/third_party/asio/asio/include/asio/detail/thread.hpp +60 -0
  456. data/ext/third_party/asio/asio/include/asio/detail/thread_context.hpp +42 -0
  457. data/ext/third_party/asio/asio/include/asio/detail/thread_group.hpp +95 -0
  458. data/ext/third_party/asio/asio/include/asio/detail/thread_info_base.hpp +183 -0
  459. data/ext/third_party/asio/asio/include/asio/detail/throw_error.hpp +53 -0
  460. data/ext/third_party/asio/asio/include/asio/detail/throw_exception.hpp +51 -0
  461. data/ext/third_party/asio/asio/include/asio/detail/timer_queue.hpp +360 -0
  462. data/ext/third_party/asio/asio/include/asio/detail/timer_queue_base.hpp +68 -0
  463. data/ext/third_party/asio/asio/include/asio/detail/timer_queue_ptime.hpp +99 -0
  464. data/ext/third_party/asio/asio/include/asio/detail/timer_queue_set.hpp +66 -0
  465. data/ext/third_party/asio/asio/include/asio/detail/timer_scheduler.hpp +35 -0
  466. data/ext/third_party/asio/asio/include/asio/detail/timer_scheduler_fwd.hpp +40 -0
  467. data/ext/third_party/asio/asio/include/asio/detail/tss_ptr.hpp +69 -0
  468. data/ext/third_party/asio/asio/include/asio/detail/type_traits.hpp +148 -0
  469. data/ext/third_party/asio/asio/include/asio/detail/variadic_templates.hpp +294 -0
  470. data/ext/third_party/asio/asio/include/asio/detail/wait_handler.hpp +90 -0
  471. data/ext/third_party/asio/asio/include/asio/detail/wait_op.hpp +45 -0
  472. data/ext/third_party/asio/asio/include/asio/detail/win_event.hpp +164 -0
  473. data/ext/third_party/asio/asio/include/asio/detail/win_fd_set_adapter.hpp +149 -0
  474. data/ext/third_party/asio/asio/include/asio/detail/win_fenced_block.hpp +90 -0
  475. data/ext/third_party/asio/asio/include/asio/detail/win_global.hpp +71 -0
  476. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_handle_read_op.hpp +117 -0
  477. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_handle_service.hpp +335 -0
  478. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_handle_write_op.hpp +110 -0
  479. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_io_context.hpp +342 -0
  480. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_null_buffers_op.hpp +127 -0
  481. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_operation.hpp +96 -0
  482. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_overlapped_op.hpp +96 -0
  483. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_overlapped_ptr.hpp +171 -0
  484. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_serial_port_service.hpp +232 -0
  485. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_accept_op.hpp +312 -0
  486. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_connect_op.hpp +135 -0
  487. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_recv_op.hpp +124 -0
  488. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_recvfrom_op.hpp +133 -0
  489. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_recvmsg_op.hpp +125 -0
  490. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_send_op.hpp +118 -0
  491. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_service.hpp +581 -0
  492. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_service_base.hpp +600 -0
  493. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_thread_info.hpp +34 -0
  494. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_wait_op.hpp +128 -0
  495. data/ext/third_party/asio/asio/include/asio/detail/win_mutex.hpp +78 -0
  496. data/ext/third_party/asio/asio/include/asio/detail/win_object_handle_service.hpp +195 -0
  497. data/ext/third_party/asio/asio/include/asio/detail/win_static_mutex.hpp +74 -0
  498. data/ext/third_party/asio/asio/include/asio/detail/win_thread.hpp +147 -0
  499. data/ext/third_party/asio/asio/include/asio/detail/win_tss_ptr.hpp +79 -0
  500. data/ext/third_party/asio/asio/include/asio/detail/winapp_thread.hpp +124 -0
  501. data/ext/third_party/asio/asio/include/asio/detail/wince_thread.hpp +124 -0
  502. data/ext/third_party/asio/asio/include/asio/detail/winrt_async_manager.hpp +305 -0
  503. data/ext/third_party/asio/asio/include/asio/detail/winrt_async_op.hpp +65 -0
  504. data/ext/third_party/asio/asio/include/asio/detail/winrt_resolve_op.hpp +125 -0
  505. data/ext/third_party/asio/asio/include/asio/detail/winrt_resolver_service.hpp +212 -0
  506. data/ext/third_party/asio/asio/include/asio/detail/winrt_socket_connect_op.hpp +98 -0
  507. data/ext/third_party/asio/asio/include/asio/detail/winrt_socket_recv_op.hpp +119 -0
  508. data/ext/third_party/asio/asio/include/asio/detail/winrt_socket_send_op.hpp +110 -0
  509. data/ext/third_party/asio/asio/include/asio/detail/winrt_ssocket_service.hpp +250 -0
  510. data/ext/third_party/asio/asio/include/asio/detail/winrt_ssocket_service_base.hpp +362 -0
  511. data/ext/third_party/asio/asio/include/asio/detail/winrt_timer_scheduler.hpp +147 -0
  512. data/ext/third_party/asio/asio/include/asio/detail/winrt_utils.hpp +106 -0
  513. data/ext/third_party/asio/asio/include/asio/detail/winsock_init.hpp +128 -0
  514. data/ext/third_party/asio/asio/include/asio/detail/work_dispatcher.hpp +148 -0
  515. data/ext/third_party/asio/asio/include/asio/detail/wrapped_handler.hpp +327 -0
  516. data/ext/third_party/asio/asio/include/asio/dispatch.hpp +121 -0
  517. data/ext/third_party/asio/asio/include/asio/error.hpp +356 -0
  518. data/ext/third_party/asio/asio/include/asio/error_code.hpp +202 -0
  519. data/ext/third_party/asio/asio/include/asio/execution.hpp +48 -0
  520. data/ext/third_party/asio/asio/include/asio/execution/allocator.hpp +249 -0
  521. data/ext/third_party/asio/asio/include/asio/execution/any_executor.hpp +2264 -0
  522. data/ext/third_party/asio/asio/include/asio/execution/bad_executor.hpp +47 -0
  523. data/ext/third_party/asio/asio/include/asio/execution/blocking.hpp +1351 -0
  524. data/ext/third_party/asio/asio/include/asio/execution/blocking_adaptation.hpp +1064 -0
  525. data/ext/third_party/asio/asio/include/asio/execution/bulk_execute.hpp +390 -0
  526. data/ext/third_party/asio/asio/include/asio/execution/bulk_guarantee.hpp +1018 -0
  527. data/ext/third_party/asio/asio/include/asio/execution/connect.hpp +486 -0
  528. data/ext/third_party/asio/asio/include/asio/execution/context.hpp +185 -0
  529. data/ext/third_party/asio/asio/include/asio/execution/context_as.hpp +201 -0
  530. data/ext/third_party/asio/asio/include/asio/execution/detail/as_invocable.hpp +152 -0
  531. data/ext/third_party/asio/asio/include/asio/execution/detail/as_operation.hpp +105 -0
  532. data/ext/third_party/asio/asio/include/asio/execution/detail/as_receiver.hpp +128 -0
  533. data/ext/third_party/asio/asio/include/asio/execution/detail/bulk_sender.hpp +261 -0
  534. data/ext/third_party/asio/asio/include/asio/execution/detail/submit_receiver.hpp +233 -0
  535. data/ext/third_party/asio/asio/include/asio/execution/detail/void_receiver.hpp +90 -0
  536. data/ext/third_party/asio/asio/include/asio/execution/execute.hpp +264 -0
  537. data/ext/third_party/asio/asio/include/asio/execution/executor.hpp +238 -0
  538. data/ext/third_party/asio/asio/include/asio/execution/impl/bad_executor.ipp +40 -0
  539. data/ext/third_party/asio/asio/include/asio/execution/impl/receiver_invocation_error.ipp +36 -0
  540. data/ext/third_party/asio/asio/include/asio/execution/invocable_archetype.hpp +71 -0
  541. data/ext/third_party/asio/asio/include/asio/execution/mapping.hpp +917 -0
  542. data/ext/third_party/asio/asio/include/asio/execution/occupancy.hpp +178 -0
  543. data/ext/third_party/asio/asio/include/asio/execution/operation_state.hpp +94 -0
  544. data/ext/third_party/asio/asio/include/asio/execution/outstanding_work.hpp +721 -0
  545. data/ext/third_party/asio/asio/include/asio/execution/prefer_only.hpp +327 -0
  546. data/ext/third_party/asio/asio/include/asio/execution/receiver.hpp +280 -0
  547. data/ext/third_party/asio/asio/include/asio/execution/receiver_invocation_error.hpp +48 -0
  548. data/ext/third_party/asio/asio/include/asio/execution/relationship.hpp +720 -0
  549. data/ext/third_party/asio/asio/include/asio/execution/schedule.hpp +290 -0
  550. data/ext/third_party/asio/asio/include/asio/execution/scheduler.hpp +86 -0
  551. data/ext/third_party/asio/asio/include/asio/execution/sender.hpp +311 -0
  552. data/ext/third_party/asio/asio/include/asio/execution/set_done.hpp +253 -0
  553. data/ext/third_party/asio/asio/include/asio/execution/set_error.hpp +253 -0
  554. data/ext/third_party/asio/asio/include/asio/execution/set_value.hpp +486 -0
  555. data/ext/third_party/asio/asio/include/asio/execution/start.hpp +250 -0
  556. data/ext/third_party/asio/asio/include/asio/execution/submit.hpp +450 -0
  557. data/ext/third_party/asio/asio/include/asio/execution_context.hpp +412 -0
  558. data/ext/third_party/asio/asio/include/asio/executor.hpp +347 -0
  559. data/ext/third_party/asio/asio/include/asio/executor_work_guard.hpp +287 -0
  560. data/ext/third_party/asio/asio/include/asio/generic/basic_endpoint.hpp +193 -0
  561. data/ext/third_party/asio/asio/include/asio/generic/datagram_protocol.hpp +123 -0
  562. data/ext/third_party/asio/asio/include/asio/generic/detail/endpoint.hpp +133 -0
  563. data/ext/third_party/asio/asio/include/asio/generic/detail/impl/endpoint.ipp +110 -0
  564. data/ext/third_party/asio/asio/include/asio/generic/raw_protocol.hpp +121 -0
  565. data/ext/third_party/asio/asio/include/asio/generic/seq_packet_protocol.hpp +122 -0
  566. data/ext/third_party/asio/asio/include/asio/generic/stream_protocol.hpp +127 -0
  567. data/ext/third_party/asio/asio/include/asio/handler_alloc_hook.hpp +104 -0
  568. data/ext/third_party/asio/asio/include/asio/handler_continuation_hook.hpp +54 -0
  569. data/ext/third_party/asio/asio/include/asio/handler_invoke_hook.hpp +111 -0
  570. data/ext/third_party/asio/asio/include/asio/high_resolution_timer.hpp +44 -0
  571. data/ext/third_party/asio/asio/include/asio/impl/awaitable.hpp +436 -0
  572. data/ext/third_party/asio/asio/include/asio/impl/buffered_read_stream.hpp +527 -0
  573. data/ext/third_party/asio/asio/include/asio/impl/buffered_write_stream.hpp +507 -0
  574. data/ext/third_party/asio/asio/include/asio/impl/co_spawn.hpp +298 -0
  575. data/ext/third_party/asio/asio/include/asio/impl/compose.hpp +635 -0
  576. data/ext/third_party/asio/asio/include/asio/impl/connect.hpp +916 -0
  577. data/ext/third_party/asio/asio/include/asio/impl/defer.hpp +248 -0
  578. data/ext/third_party/asio/asio/include/asio/impl/detached.hpp +130 -0
  579. data/ext/third_party/asio/asio/include/asio/impl/dispatch.hpp +243 -0
  580. data/ext/third_party/asio/asio/include/asio/impl/error.ipp +128 -0
  581. data/ext/third_party/asio/asio/include/asio/impl/error_code.ipp +206 -0
  582. data/ext/third_party/asio/asio/include/asio/impl/execution_context.hpp +109 -0
  583. data/ext/third_party/asio/asio/include/asio/impl/execution_context.ipp +82 -0
  584. data/ext/third_party/asio/asio/include/asio/impl/executor.hpp +301 -0
  585. data/ext/third_party/asio/asio/include/asio/impl/executor.ipp +43 -0
  586. data/ext/third_party/asio/asio/include/asio/impl/handler_alloc_hook.ipp +61 -0
  587. data/ext/third_party/asio/asio/include/asio/impl/io_context.hpp +440 -0
  588. data/ext/third_party/asio/asio/include/asio/impl/io_context.ipp +175 -0
  589. data/ext/third_party/asio/asio/include/asio/impl/multiple_exceptions.ipp +49 -0
  590. data/ext/third_party/asio/asio/include/asio/impl/post.hpp +248 -0
  591. data/ext/third_party/asio/asio/include/asio/impl/read.hpp +1202 -0
  592. data/ext/third_party/asio/asio/include/asio/impl/read_at.hpp +744 -0
  593. data/ext/third_party/asio/asio/include/asio/impl/read_until.hpp +3335 -0
  594. data/ext/third_party/asio/asio/include/asio/impl/redirect_error.hpp +390 -0
  595. data/ext/third_party/asio/asio/include/asio/impl/serial_port_base.hpp +59 -0
  596. data/ext/third_party/asio/asio/include/asio/impl/serial_port_base.ipp +554 -0
  597. data/ext/third_party/asio/asio/include/asio/impl/spawn.hpp +526 -0
  598. data/ext/third_party/asio/asio/include/asio/impl/src.hpp +85 -0
  599. data/ext/third_party/asio/asio/include/asio/impl/system_context.hpp +34 -0
  600. data/ext/third_party/asio/asio/include/asio/impl/system_context.ipp +92 -0
  601. data/ext/third_party/asio/asio/include/asio/impl/system_executor.hpp +186 -0
  602. data/ext/third_party/asio/asio/include/asio/impl/thread_pool.hpp +350 -0
  603. data/ext/third_party/asio/asio/include/asio/impl/thread_pool.ipp +141 -0
  604. data/ext/third_party/asio/asio/include/asio/impl/use_awaitable.hpp +279 -0
  605. data/ext/third_party/asio/asio/include/asio/impl/use_future.hpp +1028 -0
  606. data/ext/third_party/asio/asio/include/asio/impl/write.hpp +1104 -0
  607. data/ext/third_party/asio/asio/include/asio/impl/write_at.hpp +666 -0
  608. data/ext/third_party/asio/asio/include/asio/io_context.hpp +1530 -0
  609. data/ext/third_party/asio/asio/include/asio/io_context_strand.hpp +376 -0
  610. data/ext/third_party/asio/asio/include/asio/io_service.hpp +33 -0
  611. data/ext/third_party/asio/asio/include/asio/io_service_strand.hpp +20 -0
  612. data/ext/third_party/asio/asio/include/asio/ip/address.hpp +268 -0
  613. data/ext/third_party/asio/asio/include/asio/ip/address_v4.hpp +335 -0
  614. data/ext/third_party/asio/asio/include/asio/ip/address_v4_iterator.hpp +162 -0
  615. data/ext/third_party/asio/asio/include/asio/ip/address_v4_range.hpp +134 -0
  616. data/ext/third_party/asio/asio/include/asio/ip/address_v6.hpp +341 -0
  617. data/ext/third_party/asio/asio/include/asio/ip/address_v6_iterator.hpp +183 -0
  618. data/ext/third_party/asio/asio/include/asio/ip/address_v6_range.hpp +129 -0
  619. data/ext/third_party/asio/asio/include/asio/ip/bad_address_cast.hpp +53 -0
  620. data/ext/third_party/asio/asio/include/asio/ip/basic_endpoint.hpp +264 -0
  621. data/ext/third_party/asio/asio/include/asio/ip/basic_resolver.hpp +1030 -0
  622. data/ext/third_party/asio/asio/include/asio/ip/basic_resolver_entry.hpp +113 -0
  623. data/ext/third_party/asio/asio/include/asio/ip/basic_resolver_iterator.hpp +192 -0
  624. data/ext/third_party/asio/asio/include/asio/ip/basic_resolver_query.hpp +244 -0
  625. data/ext/third_party/asio/asio/include/asio/ip/basic_resolver_results.hpp +311 -0
  626. data/ext/third_party/asio/asio/include/asio/ip/detail/endpoint.hpp +141 -0
  627. data/ext/third_party/asio/asio/include/asio/ip/detail/impl/endpoint.ipp +199 -0
  628. data/ext/third_party/asio/asio/include/asio/ip/detail/socket_option.hpp +566 -0
  629. data/ext/third_party/asio/asio/include/asio/ip/host_name.hpp +42 -0
  630. data/ext/third_party/asio/asio/include/asio/ip/icmp.hpp +115 -0
  631. data/ext/third_party/asio/asio/include/asio/ip/impl/address.hpp +67 -0
  632. data/ext/third_party/asio/asio/include/asio/ip/impl/address.ipp +239 -0
  633. data/ext/third_party/asio/asio/include/asio/ip/impl/address_v4.hpp +67 -0
  634. data/ext/third_party/asio/asio/include/asio/ip/impl/address_v4.ipp +210 -0
  635. data/ext/third_party/asio/asio/include/asio/ip/impl/address_v6.hpp +67 -0
  636. data/ext/third_party/asio/asio/include/asio/ip/impl/address_v6.ipp +350 -0
  637. data/ext/third_party/asio/asio/include/asio/ip/impl/basic_endpoint.hpp +43 -0
  638. data/ext/third_party/asio/asio/include/asio/ip/impl/host_name.ipp +54 -0
  639. data/ext/third_party/asio/asio/include/asio/ip/impl/network_v4.hpp +54 -0
  640. data/ext/third_party/asio/asio/include/asio/ip/impl/network_v4.ipp +216 -0
  641. data/ext/third_party/asio/asio/include/asio/ip/impl/network_v6.hpp +53 -0
  642. data/ext/third_party/asio/asio/include/asio/ip/impl/network_v6.ipp +185 -0
  643. data/ext/third_party/asio/asio/include/asio/ip/multicast.hpp +191 -0
  644. data/ext/third_party/asio/asio/include/asio/ip/network_v4.hpp +261 -0
  645. data/ext/third_party/asio/asio/include/asio/ip/network_v6.hpp +235 -0
  646. data/ext/third_party/asio/asio/include/asio/ip/resolver_base.hpp +129 -0
  647. data/ext/third_party/asio/asio/include/asio/ip/resolver_query_base.hpp +43 -0
  648. data/ext/third_party/asio/asio/include/asio/ip/tcp.hpp +155 -0
  649. data/ext/third_party/asio/asio/include/asio/ip/udp.hpp +111 -0
  650. data/ext/third_party/asio/asio/include/asio/ip/unicast.hpp +70 -0
  651. data/ext/third_party/asio/asio/include/asio/ip/v6_only.hpp +69 -0
  652. data/ext/third_party/asio/asio/include/asio/is_applicable_property.hpp +61 -0
  653. data/ext/third_party/asio/asio/include/asio/is_executor.hpp +46 -0
  654. data/ext/third_party/asio/asio/include/asio/is_read_buffered.hpp +59 -0
  655. data/ext/third_party/asio/asio/include/asio/is_write_buffered.hpp +59 -0
  656. data/ext/third_party/asio/asio/include/asio/local/basic_endpoint.hpp +247 -0
  657. data/ext/third_party/asio/asio/include/asio/local/connect_pair.hpp +101 -0
  658. data/ext/third_party/asio/asio/include/asio/local/datagram_protocol.hpp +80 -0
  659. data/ext/third_party/asio/asio/include/asio/local/detail/endpoint.hpp +139 -0
  660. data/ext/third_party/asio/asio/include/asio/local/detail/impl/endpoint.ipp +136 -0
  661. data/ext/third_party/asio/asio/include/asio/local/stream_protocol.hpp +90 -0
  662. data/ext/third_party/asio/asio/include/asio/multiple_exceptions.hpp +58 -0
  663. data/ext/third_party/asio/asio/include/asio/packaged_task.hpp +126 -0
  664. data/ext/third_party/asio/asio/include/asio/placeholders.hpp +151 -0
  665. data/ext/third_party/asio/asio/include/asio/posix/basic_descriptor.hpp +697 -0
  666. data/ext/third_party/asio/asio/include/asio/posix/basic_stream_descriptor.hpp +470 -0
  667. data/ext/third_party/asio/asio/include/asio/posix/descriptor.hpp +37 -0
  668. data/ext/third_party/asio/asio/include/asio/posix/descriptor_base.hpp +90 -0
  669. data/ext/third_party/asio/asio/include/asio/posix/stream_descriptor.hpp +37 -0
  670. data/ext/third_party/asio/asio/include/asio/post.hpp +126 -0
  671. data/ext/third_party/asio/asio/include/asio/prefer.hpp +656 -0
  672. data/ext/third_party/asio/asio/include/asio/query.hpp +296 -0
  673. data/ext/third_party/asio/asio/include/asio/read.hpp +1288 -0
  674. data/ext/third_party/asio/asio/include/asio/read_at.hpp +694 -0
  675. data/ext/third_party/asio/asio/include/asio/read_until.hpp +2863 -0
  676. data/ext/third_party/asio/asio/include/asio/redirect_error.hpp +66 -0
  677. data/ext/third_party/asio/asio/include/asio/require.hpp +524 -0
  678. data/ext/third_party/asio/asio/include/asio/require_concept.hpp +310 -0
  679. data/ext/third_party/asio/asio/include/asio/serial_port.hpp +36 -0
  680. data/ext/third_party/asio/asio/include/asio/serial_port_base.hpp +167 -0
  681. data/ext/third_party/asio/asio/include/asio/signal_set.hpp +28 -0
  682. data/ext/third_party/asio/asio/include/asio/socket_base.hpp +559 -0
  683. data/ext/third_party/asio/asio/include/asio/spawn.hpp +344 -0
  684. data/ext/third_party/asio/asio/include/asio/ssl.hpp +28 -0
  685. data/ext/third_party/asio/asio/include/asio/ssl/context.hpp +761 -0
  686. data/ext/third_party/asio/asio/include/asio/ssl/context_base.hpp +209 -0
  687. data/ext/third_party/asio/asio/include/asio/ssl/detail/buffered_handshake_op.hpp +119 -0
  688. data/ext/third_party/asio/asio/include/asio/ssl/detail/engine.hpp +165 -0
  689. data/ext/third_party/asio/asio/include/asio/ssl/detail/handshake_op.hpp +67 -0
  690. data/ext/third_party/asio/asio/include/asio/ssl/detail/impl/engine.ipp +349 -0
  691. data/ext/third_party/asio/asio/include/asio/ssl/detail/impl/openssl_init.ipp +165 -0
  692. data/ext/third_party/asio/asio/include/asio/ssl/detail/io.hpp +415 -0
  693. data/ext/third_party/asio/asio/include/asio/ssl/detail/openssl_init.hpp +101 -0
  694. data/ext/third_party/asio/asio/include/asio/ssl/detail/openssl_types.hpp +34 -0
  695. data/ext/third_party/asio/asio/include/asio/ssl/detail/password_callback.hpp +66 -0
  696. data/ext/third_party/asio/asio/include/asio/ssl/detail/read_op.hpp +72 -0
  697. data/ext/third_party/asio/asio/include/asio/ssl/detail/shutdown_op.hpp +69 -0
  698. data/ext/third_party/asio/asio/include/asio/ssl/detail/stream_core.hpp +169 -0
  699. data/ext/third_party/asio/asio/include/asio/ssl/detail/verify_callback.hpp +62 -0
  700. data/ext/third_party/asio/asio/include/asio/ssl/detail/write_op.hpp +76 -0
  701. data/ext/third_party/asio/asio/include/asio/ssl/error.hpp +125 -0
  702. data/ext/third_party/asio/asio/include/asio/ssl/host_name_verification.hpp +90 -0
  703. data/ext/third_party/asio/asio/include/asio/ssl/impl/context.hpp +67 -0
  704. data/ext/third_party/asio/asio/include/asio/ssl/impl/context.ipp +1238 -0
  705. data/ext/third_party/asio/asio/include/asio/ssl/impl/error.ipp +102 -0
  706. data/ext/third_party/asio/asio/include/asio/ssl/impl/host_name_verification.ipp +73 -0
  707. data/ext/third_party/asio/asio/include/asio/ssl/impl/rfc2818_verification.ipp +164 -0
  708. data/ext/third_party/asio/asio/include/asio/ssl/impl/src.hpp +29 -0
  709. data/ext/third_party/asio/asio/include/asio/ssl/rfc2818_verification.hpp +98 -0
  710. data/ext/third_party/asio/asio/include/asio/ssl/stream.hpp +900 -0
  711. data/ext/third_party/asio/asio/include/asio/ssl/stream_base.hpp +52 -0
  712. data/ext/third_party/asio/asio/include/asio/ssl/verify_context.hpp +67 -0
  713. data/ext/third_party/asio/asio/include/asio/ssl/verify_mode.hpp +63 -0
  714. data/ext/third_party/asio/asio/include/asio/static_thread_pool.hpp +31 -0
  715. data/ext/third_party/asio/asio/include/asio/steady_timer.hpp +42 -0
  716. data/ext/third_party/asio/asio/include/asio/strand.hpp +537 -0
  717. data/ext/third_party/asio/asio/include/asio/streambuf.hpp +33 -0
  718. data/ext/third_party/asio/asio/include/asio/system_context.hpp +90 -0
  719. data/ext/third_party/asio/asio/include/asio/system_error.hpp +131 -0
  720. data/ext/third_party/asio/asio/include/asio/system_executor.hpp +662 -0
  721. data/ext/third_party/asio/asio/include/asio/system_timer.hpp +42 -0
  722. data/ext/third_party/asio/asio/include/asio/this_coro.hpp +45 -0
  723. data/ext/third_party/asio/asio/include/asio/thread.hpp +92 -0
  724. data/ext/third_party/asio/asio/include/asio/thread_pool.hpp +1111 -0
  725. data/ext/third_party/asio/asio/include/asio/time_traits.hpp +86 -0
  726. data/ext/third_party/asio/asio/include/asio/traits/bulk_execute_free.hpp +114 -0
  727. data/ext/third_party/asio/asio/include/asio/traits/bulk_execute_member.hpp +114 -0
  728. data/ext/third_party/asio/asio/include/asio/traits/connect_free.hpp +112 -0
  729. data/ext/third_party/asio/asio/include/asio/traits/connect_member.hpp +112 -0
  730. data/ext/third_party/asio/asio/include/asio/traits/equality_comparable.hpp +100 -0
  731. data/ext/third_party/asio/asio/include/asio/traits/execute_free.hpp +108 -0
  732. data/ext/third_party/asio/asio/include/asio/traits/execute_member.hpp +108 -0
  733. data/ext/third_party/asio/asio/include/asio/traits/prefer_free.hpp +108 -0
  734. data/ext/third_party/asio/asio/include/asio/traits/prefer_member.hpp +108 -0
  735. data/ext/third_party/asio/asio/include/asio/traits/query_free.hpp +108 -0
  736. data/ext/third_party/asio/asio/include/asio/traits/query_member.hpp +108 -0
  737. data/ext/third_party/asio/asio/include/asio/traits/query_static_constexpr_member.hpp +108 -0
  738. data/ext/third_party/asio/asio/include/asio/traits/require_concept_free.hpp +108 -0
  739. data/ext/third_party/asio/asio/include/asio/traits/require_concept_member.hpp +108 -0
  740. data/ext/third_party/asio/asio/include/asio/traits/require_free.hpp +108 -0
  741. data/ext/third_party/asio/asio/include/asio/traits/require_member.hpp +108 -0
  742. data/ext/third_party/asio/asio/include/asio/traits/schedule_free.hpp +108 -0
  743. data/ext/third_party/asio/asio/include/asio/traits/schedule_member.hpp +108 -0
  744. data/ext/third_party/asio/asio/include/asio/traits/set_done_free.hpp +108 -0
  745. data/ext/third_party/asio/asio/include/asio/traits/set_done_member.hpp +108 -0
  746. data/ext/third_party/asio/asio/include/asio/traits/set_error_free.hpp +112 -0
  747. data/ext/third_party/asio/asio/include/asio/traits/set_error_member.hpp +112 -0
  748. data/ext/third_party/asio/asio/include/asio/traits/set_value_free.hpp +234 -0
  749. data/ext/third_party/asio/asio/include/asio/traits/set_value_member.hpp +234 -0
  750. data/ext/third_party/asio/asio/include/asio/traits/start_free.hpp +108 -0
  751. data/ext/third_party/asio/asio/include/asio/traits/start_member.hpp +108 -0
  752. data/ext/third_party/asio/asio/include/asio/traits/static_query.hpp +108 -0
  753. data/ext/third_party/asio/asio/include/asio/traits/static_require.hpp +123 -0
  754. data/ext/third_party/asio/asio/include/asio/traits/static_require_concept.hpp +123 -0
  755. data/ext/third_party/asio/asio/include/asio/traits/submit_free.hpp +112 -0
  756. data/ext/third_party/asio/asio/include/asio/traits/submit_member.hpp +112 -0
  757. data/ext/third_party/asio/asio/include/asio/ts/buffer.hpp +24 -0
  758. data/ext/third_party/asio/asio/include/asio/ts/executor.hpp +35 -0
  759. data/ext/third_party/asio/asio/include/asio/ts/internet.hpp +40 -0
  760. data/ext/third_party/asio/asio/include/asio/ts/io_context.hpp +20 -0
  761. data/ext/third_party/asio/asio/include/asio/ts/net.hpp +26 -0
  762. data/ext/third_party/asio/asio/include/asio/ts/netfwd.hpp +262 -0
  763. data/ext/third_party/asio/asio/include/asio/ts/socket.hpp +27 -0
  764. data/ext/third_party/asio/asio/include/asio/ts/timer.hpp +26 -0
  765. data/ext/third_party/asio/asio/include/asio/unyield.hpp +21 -0
  766. data/ext/third_party/asio/asio/include/asio/use_awaitable.hpp +169 -0
  767. data/ext/third_party/asio/asio/include/asio/use_future.hpp +160 -0
  768. data/ext/third_party/asio/asio/include/asio/uses_executor.hpp +71 -0
  769. data/ext/third_party/asio/asio/include/asio/version.hpp +23 -0
  770. data/ext/third_party/asio/asio/include/asio/wait_traits.hpp +56 -0
  771. data/ext/third_party/asio/asio/include/asio/windows/basic_object_handle.hpp +435 -0
  772. data/ext/third_party/asio/asio/include/asio/windows/basic_overlapped_handle.hpp +361 -0
  773. data/ext/third_party/asio/asio/include/asio/windows/basic_random_access_handle.hpp +490 -0
  774. data/ext/third_party/asio/asio/include/asio/windows/basic_stream_handle.hpp +474 -0
  775. data/ext/third_party/asio/asio/include/asio/windows/object_handle.hpp +38 -0
  776. data/ext/third_party/asio/asio/include/asio/windows/overlapped_handle.hpp +39 -0
  777. data/ext/third_party/asio/asio/include/asio/windows/overlapped_ptr.hpp +145 -0
  778. data/ext/third_party/asio/asio/include/asio/windows/random_access_handle.hpp +37 -0
  779. data/ext/third_party/asio/asio/include/asio/windows/stream_handle.hpp +37 -0
  780. data/ext/third_party/asio/asio/include/asio/write.hpp +1246 -0
  781. data/ext/third_party/asio/asio/include/asio/write_at.hpp +702 -0
  782. data/ext/third_party/asio/asio/include/asio/yield.hpp +23 -0
  783. data/ext/third_party/gsl/CMakeLists.txt +127 -0
  784. data/ext/third_party/gsl/LICENSE +21 -0
  785. data/ext/third_party/gsl/ThirdPartyNotices.txt +41 -0
  786. data/ext/third_party/gsl/include/gsl/gsl +29 -0
  787. data/ext/third_party/gsl/include/gsl/gsl_algorithm +61 -0
  788. data/ext/third_party/gsl/include/gsl/gsl_assert +133 -0
  789. data/ext/third_party/gsl/include/gsl/gsl_byte +209 -0
  790. data/ext/third_party/gsl/include/gsl/gsl_narrow +52 -0
  791. data/ext/third_party/gsl/include/gsl/gsl_util +129 -0
  792. data/ext/third_party/gsl/include/gsl/multi_span +2263 -0
  793. data/ext/third_party/gsl/include/gsl/pointers +287 -0
  794. data/ext/third_party/gsl/include/gsl/span +816 -0
  795. data/ext/third_party/gsl/include/gsl/span_ext +198 -0
  796. data/ext/third_party/gsl/include/gsl/string_span +706 -0
  797. data/ext/third_party/http_parser/LICENSE-MIT +19 -0
  798. data/ext/third_party/http_parser/http_parser.c +2575 -0
  799. data/ext/third_party/http_parser/http_parser.h +449 -0
  800. data/ext/third_party/json/CMakeLists.txt +44 -0
  801. data/ext/third_party/json/LICENSE +21 -0
  802. data/ext/third_party/json/LICENSE.double-conversion +32 -0
  803. data/ext/third_party/json/LICENSE.itoa +19 -0
  804. data/ext/third_party/json/LICENSE.ryu +201 -0
  805. data/ext/third_party/json/include/tao/json.hpp +45 -0
  806. data/ext/third_party/json/include/tao/json/basic_value.hpp +942 -0
  807. data/ext/third_party/json/include/tao/json/binary.hpp +103 -0
  808. data/ext/third_party/json/include/tao/json/binary_view.hpp +31 -0
  809. data/ext/third_party/json/include/tao/json/binding.hpp +71 -0
  810. data/ext/third_party/json/include/tao/json/binding/constant.hpp +232 -0
  811. data/ext/third_party/json/include/tao/json/binding/element.hpp +182 -0
  812. data/ext/third_party/json/include/tao/json/binding/factory.hpp +251 -0
  813. data/ext/third_party/json/include/tao/json/binding/for_nothing_value.hpp +17 -0
  814. data/ext/third_party/json/include/tao/json/binding/for_unknown_key.hpp +17 -0
  815. data/ext/third_party/json/include/tao/json/binding/inherit.hpp +14 -0
  816. data/ext/third_party/json/include/tao/json/binding/internal/array.hpp +104 -0
  817. data/ext/third_party/json/include/tao/json/binding/internal/inherit.hpp +45 -0
  818. data/ext/third_party/json/include/tao/json/binding/internal/object.hpp +268 -0
  819. data/ext/third_party/json/include/tao/json/binding/internal/type_key.hpp +54 -0
  820. data/ext/third_party/json/include/tao/json/binding/member.hpp +32 -0
  821. data/ext/third_party/json/include/tao/json/binding/member_kind.hpp +17 -0
  822. data/ext/third_party/json/include/tao/json/binding/versions.hpp +129 -0
  823. data/ext/third_party/json/include/tao/json/cbor.hpp +19 -0
  824. data/ext/third_party/json/include/tao/json/cbor/consume_file.hpp +34 -0
  825. data/ext/third_party/json/include/tao/json/cbor/consume_string.hpp +32 -0
  826. data/ext/third_party/json/include/tao/json/cbor/events/from_binary.hpp +43 -0
  827. data/ext/third_party/json/include/tao/json/cbor/events/from_file.hpp +27 -0
  828. data/ext/third_party/json/include/tao/json/cbor/events/from_input.hpp +43 -0
  829. data/ext/third_party/json/include/tao/json/cbor/events/from_string.hpp +37 -0
  830. data/ext/third_party/json/include/tao/json/cbor/events/to_stream.hpp +161 -0
  831. data/ext/third_party/json/include/tao/json/cbor/events/to_string.hpp +31 -0
  832. data/ext/third_party/json/include/tao/json/cbor/from_binary.hpp +32 -0
  833. data/ext/third_party/json/include/tao/json/cbor/from_file.hpp +33 -0
  834. data/ext/third_party/json/include/tao/json/cbor/from_input.hpp +33 -0
  835. data/ext/third_party/json/include/tao/json/cbor/from_string.hpp +32 -0
  836. data/ext/third_party/json/include/tao/json/cbor/internal/grammar.hpp +418 -0
  837. data/ext/third_party/json/include/tao/json/cbor/internal/major.hpp +28 -0
  838. data/ext/third_party/json/include/tao/json/cbor/parts_parser.hpp +392 -0
  839. data/ext/third_party/json/include/tao/json/cbor/to_stream.hpp +27 -0
  840. data/ext/third_party/json/include/tao/json/cbor/to_string.hpp +28 -0
  841. data/ext/third_party/json/include/tao/json/consume.hpp +43 -0
  842. data/ext/third_party/json/include/tao/json/consume_file.hpp +33 -0
  843. data/ext/third_party/json/include/tao/json/consume_string.hpp +31 -0
  844. data/ext/third_party/json/include/tao/json/contrib/array_traits.hpp +43 -0
  845. data/ext/third_party/json/include/tao/json/contrib/deque_traits.hpp +41 -0
  846. data/ext/third_party/json/include/tao/json/contrib/diff.hpp +106 -0
  847. data/ext/third_party/json/include/tao/json/contrib/get.hpp +152 -0
  848. data/ext/third_party/json/include/tao/json/contrib/internal/array_traits.hpp +92 -0
  849. data/ext/third_party/json/include/tao/json/contrib/internal/indirect_traits.hpp +76 -0
  850. data/ext/third_party/json/include/tao/json/contrib/internal/object_traits.hpp +105 -0
  851. data/ext/third_party/json/include/tao/json/contrib/internal/type_traits.hpp +36 -0
  852. data/ext/third_party/json/include/tao/json/contrib/list_traits.hpp +41 -0
  853. data/ext/third_party/json/include/tao/json/contrib/map_traits.hpp +43 -0
  854. data/ext/third_party/json/include/tao/json/contrib/multimap_traits.hpp +43 -0
  855. data/ext/third_party/json/include/tao/json/contrib/multiset_traits.hpp +41 -0
  856. data/ext/third_party/json/include/tao/json/contrib/pair_traits.hpp +21 -0
  857. data/ext/third_party/json/include/tao/json/contrib/patch.hpp +105 -0
  858. data/ext/third_party/json/include/tao/json/contrib/pointer_traits.hpp +59 -0
  859. data/ext/third_party/json/include/tao/json/contrib/position.hpp +166 -0
  860. data/ext/third_party/json/include/tao/json/contrib/reference.hpp +113 -0
  861. data/ext/third_party/json/include/tao/json/contrib/schema.hpp +1874 -0
  862. data/ext/third_party/json/include/tao/json/contrib/set_traits.hpp +41 -0
  863. data/ext/third_party/json/include/tao/json/contrib/shared_ptr_traits.hpp +98 -0
  864. data/ext/third_party/json/include/tao/json/contrib/traits.hpp +121 -0
  865. data/ext/third_party/json/include/tao/json/contrib/tuple_traits.hpp +51 -0
  866. data/ext/third_party/json/include/tao/json/contrib/unique_ptr_traits.hpp +97 -0
  867. data/ext/third_party/json/include/tao/json/contrib/unordered_map_traits.hpp +43 -0
  868. data/ext/third_party/json/include/tao/json/contrib/unordered_set_traits.hpp +41 -0
  869. data/ext/third_party/json/include/tao/json/contrib/vector_bool_traits.hpp +45 -0
  870. data/ext/third_party/json/include/tao/json/contrib/vector_traits.hpp +51 -0
  871. data/ext/third_party/json/include/tao/json/events.hpp +47 -0
  872. data/ext/third_party/json/include/tao/json/events/apply.hpp +20 -0
  873. data/ext/third_party/json/include/tao/json/events/binary_to_base64.hpp +26 -0
  874. data/ext/third_party/json/include/tao/json/events/binary_to_base64url.hpp +28 -0
  875. data/ext/third_party/json/include/tao/json/events/binary_to_exception.hpp +27 -0
  876. data/ext/third_party/json/include/tao/json/events/binary_to_hex.hpp +26 -0
  877. data/ext/third_party/json/include/tao/json/events/compare.hpp +255 -0
  878. data/ext/third_party/json/include/tao/json/events/debug.hpp +145 -0
  879. data/ext/third_party/json/include/tao/json/events/discard.hpp +43 -0
  880. data/ext/third_party/json/include/tao/json/events/from_file.hpp +28 -0
  881. data/ext/third_party/json/include/tao/json/events/from_input.hpp +45 -0
  882. data/ext/third_party/json/include/tao/json/events/from_stream.hpp +33 -0
  883. data/ext/third_party/json/include/tao/json/events/from_string.hpp +38 -0
  884. data/ext/third_party/json/include/tao/json/events/from_value.hpp +202 -0
  885. data/ext/third_party/json/include/tao/json/events/hash.hpp +174 -0
  886. data/ext/third_party/json/include/tao/json/events/invalid_string_to_binary.hpp +50 -0
  887. data/ext/third_party/json/include/tao/json/events/invalid_string_to_exception.hpp +49 -0
  888. data/ext/third_party/json/include/tao/json/events/invalid_string_to_hex.hpp +48 -0
  889. data/ext/third_party/json/include/tao/json/events/key_camel_case_to_snake_case.hpp +62 -0
  890. data/ext/third_party/json/include/tao/json/events/key_snake_case_to_camel_case.hpp +57 -0
  891. data/ext/third_party/json/include/tao/json/events/limit_nesting_depth.hpp +82 -0
  892. data/ext/third_party/json/include/tao/json/events/limit_value_count.hpp +46 -0
  893. data/ext/third_party/json/include/tao/json/events/non_finite_to_exception.hpp +31 -0
  894. data/ext/third_party/json/include/tao/json/events/non_finite_to_null.hpp +32 -0
  895. data/ext/third_party/json/include/tao/json/events/non_finite_to_string.hpp +40 -0
  896. data/ext/third_party/json/include/tao/json/events/prefer_signed.hpp +32 -0
  897. data/ext/third_party/json/include/tao/json/events/prefer_unsigned.hpp +32 -0
  898. data/ext/third_party/json/include/tao/json/events/produce.hpp +22 -0
  899. data/ext/third_party/json/include/tao/json/events/ref.hpp +111 -0
  900. data/ext/third_party/json/include/tao/json/events/statistics.hpp +112 -0
  901. data/ext/third_party/json/include/tao/json/events/tee.hpp +386 -0
  902. data/ext/third_party/json/include/tao/json/events/to_pretty_stream.hpp +172 -0
  903. data/ext/third_party/json/include/tao/json/events/to_stream.hpp +142 -0
  904. data/ext/third_party/json/include/tao/json/events/to_string.hpp +33 -0
  905. data/ext/third_party/json/include/tao/json/events/to_value.hpp +137 -0
  906. data/ext/third_party/json/include/tao/json/events/transformer.hpp +70 -0
  907. data/ext/third_party/json/include/tao/json/events/validate_event_order.hpp +411 -0
  908. data/ext/third_party/json/include/tao/json/events/validate_keys.hpp +51 -0
  909. data/ext/third_party/json/include/tao/json/events/virtual_base.hpp +192 -0
  910. data/ext/third_party/json/include/tao/json/events/virtual_ref.hpp +176 -0
  911. data/ext/third_party/json/include/tao/json/external/double.hpp +1313 -0
  912. data/ext/third_party/json/include/tao/json/external/itoa.hpp +149 -0
  913. data/ext/third_party/json/include/tao/json/external/pegtl.hpp +44 -0
  914. data/ext/third_party/json/include/tao/json/external/pegtl/apply_mode.hpp +19 -0
  915. data/ext/third_party/json/include/tao/json/external/pegtl/argv_input.hpp +49 -0
  916. data/ext/third_party/json/include/tao/json/external/pegtl/ascii.hpp +54 -0
  917. data/ext/third_party/json/include/tao/json/external/pegtl/buffer_input.hpp +212 -0
  918. data/ext/third_party/json/include/tao/json/external/pegtl/change_action.hpp +38 -0
  919. data/ext/third_party/json/include/tao/json/external/pegtl/change_action_and_state.hpp +53 -0
  920. data/ext/third_party/json/include/tao/json/external/pegtl/change_action_and_states.hpp +62 -0
  921. data/ext/third_party/json/include/tao/json/external/pegtl/change_control.hpp +36 -0
  922. data/ext/third_party/json/include/tao/json/external/pegtl/change_state.hpp +50 -0
  923. data/ext/third_party/json/include/tao/json/external/pegtl/change_states.hpp +61 -0
  924. data/ext/third_party/json/include/tao/json/external/pegtl/config.hpp +11 -0
  925. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/abnf.hpp +35 -0
  926. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/alphabet.hpp +67 -0
  927. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/analyze.hpp +176 -0
  928. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/analyze_traits.hpp +275 -0
  929. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/control_action.hpp +77 -0
  930. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/coverage.hpp +151 -0
  931. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/forward.hpp +16 -0
  932. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/http.hpp +272 -0
  933. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/icu/internal.hpp +66 -0
  934. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/icu/utf16.hpp +196 -0
  935. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/icu/utf32.hpp +196 -0
  936. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/icu/utf8.hpp +103 -0
  937. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/if_then.hpp +56 -0
  938. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/integer.hpp +431 -0
  939. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/internal/endian.hpp +62 -0
  940. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/internal/endian_gcc.hpp +206 -0
  941. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/internal/endian_win.hpp +106 -0
  942. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/internal/peek_mask_uint.hpp +54 -0
  943. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/internal/peek_mask_uint8.hpp +33 -0
  944. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/internal/peek_uint.hpp +45 -0
  945. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/internal/peek_uint8.hpp +32 -0
  946. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/internal/peek_utf16.hpp +54 -0
  947. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/internal/peek_utf32.hpp +43 -0
  948. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/internal/read_uint.hpp +77 -0
  949. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/internal/set_stack_guard.hpp +52 -0
  950. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/json.hpp +88 -0
  951. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/json_pointer.hpp +33 -0
  952. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/parse_tree.hpp +440 -0
  953. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/parse_tree_to_dot.hpp +105 -0
  954. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/print.hpp +75 -0
  955. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/print_coverage.hpp +53 -0
  956. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/raw_string.hpp +234 -0
  957. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/remove_first_state.hpp +69 -0
  958. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/remove_last_states.hpp +117 -0
  959. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/rep_one_min_max.hpp +94 -0
  960. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/rep_string.hpp +43 -0
  961. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/shuffle_states.hpp +193 -0
  962. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/state_control.hpp +118 -0
  963. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/to_string.hpp +38 -0
  964. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/trace.hpp +227 -0
  965. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/uint16.hpp +62 -0
  966. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/uint32.hpp +62 -0
  967. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/uint64.hpp +63 -0
  968. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/uint8.hpp +36 -0
  969. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/unescape.hpp +199 -0
  970. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/uri.hpp +106 -0
  971. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/utf16.hpp +49 -0
  972. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/utf32.hpp +49 -0
  973. data/ext/third_party/json/include/tao/json/external/pegtl/cstream_input.hpp +32 -0
  974. data/ext/third_party/json/include/tao/json/external/pegtl/demangle.hpp +138 -0
  975. data/ext/third_party/json/include/tao/json/external/pegtl/disable_action.hpp +35 -0
  976. data/ext/third_party/json/include/tao/json/external/pegtl/discard_input.hpp +37 -0
  977. data/ext/third_party/json/include/tao/json/external/pegtl/discard_input_on_failure.hpp +39 -0
  978. data/ext/third_party/json/include/tao/json/external/pegtl/discard_input_on_success.hpp +39 -0
  979. data/ext/third_party/json/include/tao/json/external/pegtl/enable_action.hpp +35 -0
  980. data/ext/third_party/json/include/tao/json/external/pegtl/eol.hpp +37 -0
  981. data/ext/third_party/json/include/tao/json/external/pegtl/eol_pair.hpp +18 -0
  982. data/ext/third_party/json/include/tao/json/external/pegtl/file_input.hpp +44 -0
  983. data/ext/third_party/json/include/tao/json/external/pegtl/internal/action.hpp +54 -0
  984. data/ext/third_party/json/include/tao/json/external/pegtl/internal/action_input.hpp +106 -0
  985. data/ext/third_party/json/include/tao/json/external/pegtl/internal/any.hpp +58 -0
  986. data/ext/third_party/json/include/tao/json/external/pegtl/internal/apply.hpp +53 -0
  987. data/ext/third_party/json/include/tao/json/external/pegtl/internal/apply0.hpp +51 -0
  988. data/ext/third_party/json/include/tao/json/external/pegtl/internal/apply0_single.hpp +34 -0
  989. data/ext/third_party/json/include/tao/json/external/pegtl/internal/apply_single.hpp +34 -0
  990. data/ext/third_party/json/include/tao/json/external/pegtl/internal/at.hpp +55 -0
  991. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bof.hpp +32 -0
  992. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bol.hpp +31 -0
  993. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bump.hpp +45 -0
  994. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bump_help.hpp +29 -0
  995. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bytes.hpp +43 -0
  996. data/ext/third_party/json/include/tao/json/external/pegtl/internal/control.hpp +54 -0
  997. data/ext/third_party/json/include/tao/json/external/pegtl/internal/cr_crlf_eol.hpp +32 -0
  998. data/ext/third_party/json/include/tao/json/external/pegtl/internal/cr_eol.hpp +32 -0
  999. data/ext/third_party/json/include/tao/json/external/pegtl/internal/crlf_eol.hpp +32 -0
  1000. data/ext/third_party/json/include/tao/json/external/pegtl/internal/cstream_reader.hpp +49 -0
  1001. data/ext/third_party/json/include/tao/json/external/pegtl/internal/cstring_reader.hpp +40 -0
  1002. data/ext/third_party/json/include/tao/json/external/pegtl/internal/dependent_false.hpp +16 -0
  1003. data/ext/third_party/json/include/tao/json/external/pegtl/internal/disable.hpp +54 -0
  1004. data/ext/third_party/json/include/tao/json/external/pegtl/internal/discard.hpp +34 -0
  1005. data/ext/third_party/json/include/tao/json/external/pegtl/internal/enable.hpp +54 -0
  1006. data/ext/third_party/json/include/tao/json/external/pegtl/internal/enable_control.hpp +25 -0
  1007. data/ext/third_party/json/include/tao/json/external/pegtl/internal/eof.hpp +32 -0
  1008. data/ext/third_party/json/include/tao/json/external/pegtl/internal/eol.hpp +32 -0
  1009. data/ext/third_party/json/include/tao/json/external/pegtl/internal/eolf.hpp +33 -0
  1010. data/ext/third_party/json/include/tao/json/external/pegtl/internal/failure.hpp +32 -0
  1011. data/ext/third_party/json/include/tao/json/external/pegtl/internal/file_mapper_posix.hpp +134 -0
  1012. data/ext/third_party/json/include/tao/json/external/pegtl/internal/file_mapper_win32.hpp +213 -0
  1013. data/ext/third_party/json/include/tao/json/external/pegtl/internal/file_reader.hpp +113 -0
  1014. data/ext/third_party/json/include/tao/json/external/pegtl/internal/has_apply.hpp +21 -0
  1015. data/ext/third_party/json/include/tao/json/external/pegtl/internal/has_apply0.hpp +21 -0
  1016. data/ext/third_party/json/include/tao/json/external/pegtl/internal/has_match.hpp +40 -0
  1017. data/ext/third_party/json/include/tao/json/external/pegtl/internal/has_unwind.hpp +21 -0
  1018. data/ext/third_party/json/include/tao/json/external/pegtl/internal/identifier.hpp +22 -0
  1019. data/ext/third_party/json/include/tao/json/external/pegtl/internal/if_apply.hpp +54 -0
  1020. data/ext/third_party/json/include/tao/json/external/pegtl/internal/if_must.hpp +47 -0
  1021. data/ext/third_party/json/include/tao/json/external/pegtl/internal/if_must_else.hpp +21 -0
  1022. data/ext/third_party/json/include/tao/json/external/pegtl/internal/if_then_else.hpp +51 -0
  1023. data/ext/third_party/json/include/tao/json/external/pegtl/internal/input_pair.hpp +29 -0
  1024. data/ext/third_party/json/include/tao/json/external/pegtl/internal/istream_reader.hpp +39 -0
  1025. data/ext/third_party/json/include/tao/json/external/pegtl/internal/istring.hpp +72 -0
  1026. data/ext/third_party/json/include/tao/json/external/pegtl/internal/iterator.hpp +49 -0
  1027. data/ext/third_party/json/include/tao/json/external/pegtl/internal/lf_crlf_eol.hpp +37 -0
  1028. data/ext/third_party/json/include/tao/json/external/pegtl/internal/lf_eol.hpp +32 -0
  1029. data/ext/third_party/json/include/tao/json/external/pegtl/internal/list.hpp +19 -0
  1030. data/ext/third_party/json/include/tao/json/external/pegtl/internal/list_must.hpp +20 -0
  1031. data/ext/third_party/json/include/tao/json/external/pegtl/internal/list_tail.hpp +22 -0
  1032. data/ext/third_party/json/include/tao/json/external/pegtl/internal/list_tail_pad.hpp +22 -0
  1033. data/ext/third_party/json/include/tao/json/external/pegtl/internal/marker.hpp +80 -0
  1034. data/ext/third_party/json/include/tao/json/external/pegtl/internal/minus.hpp +21 -0
  1035. data/ext/third_party/json/include/tao/json/external/pegtl/internal/missing_apply.hpp +28 -0
  1036. data/ext/third_party/json/include/tao/json/external/pegtl/internal/missing_apply0.hpp +26 -0
  1037. data/ext/third_party/json/include/tao/json/external/pegtl/internal/must.hpp +64 -0
  1038. data/ext/third_party/json/include/tao/json/external/pegtl/internal/not_at.hpp +55 -0
  1039. data/ext/third_party/json/include/tao/json/external/pegtl/internal/one.hpp +55 -0
  1040. data/ext/third_party/json/include/tao/json/external/pegtl/internal/opt.hpp +57 -0
  1041. data/ext/third_party/json/include/tao/json/external/pegtl/internal/pad.hpp +19 -0
  1042. data/ext/third_party/json/include/tao/json/external/pegtl/internal/pad_opt.hpp +20 -0
  1043. data/ext/third_party/json/include/tao/json/external/pegtl/internal/path_to_string.hpp +26 -0
  1044. data/ext/third_party/json/include/tao/json/external/pegtl/internal/peek_char.hpp +32 -0
  1045. data/ext/third_party/json/include/tao/json/external/pegtl/internal/peek_utf8.hpp +89 -0
  1046. data/ext/third_party/json/include/tao/json/external/pegtl/internal/pegtl_string.hpp +90 -0
  1047. data/ext/third_party/json/include/tao/json/external/pegtl/internal/plus.hpp +60 -0
  1048. data/ext/third_party/json/include/tao/json/external/pegtl/internal/raise.hpp +44 -0
  1049. data/ext/third_party/json/include/tao/json/external/pegtl/internal/range.hpp +56 -0
  1050. data/ext/third_party/json/include/tao/json/external/pegtl/internal/ranges.hpp +103 -0
  1051. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rematch.hpp +72 -0
  1052. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rep.hpp +67 -0
  1053. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rep_min.hpp +20 -0
  1054. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rep_min_max.hpp +81 -0
  1055. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rep_opt.hpp +61 -0
  1056. data/ext/third_party/json/include/tao/json/external/pegtl/internal/require.hpp +42 -0
  1057. data/ext/third_party/json/include/tao/json/external/pegtl/internal/result_on_found.hpp +19 -0
  1058. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rules.hpp +61 -0
  1059. data/ext/third_party/json/include/tao/json/external/pegtl/internal/seq.hpp +58 -0
  1060. data/ext/third_party/json/include/tao/json/external/pegtl/internal/sor.hpp +67 -0
  1061. data/ext/third_party/json/include/tao/json/external/pegtl/internal/star.hpp +52 -0
  1062. data/ext/third_party/json/include/tao/json/external/pegtl/internal/star_must.hpp +19 -0
  1063. data/ext/third_party/json/include/tao/json/external/pegtl/internal/state.hpp +59 -0
  1064. data/ext/third_party/json/include/tao/json/external/pegtl/internal/string.hpp +58 -0
  1065. data/ext/third_party/json/include/tao/json/external/pegtl/internal/success.hpp +32 -0
  1066. data/ext/third_party/json/include/tao/json/external/pegtl/internal/try_catch_type.hpp +64 -0
  1067. data/ext/third_party/json/include/tao/json/external/pegtl/internal/until.hpp +88 -0
  1068. data/ext/third_party/json/include/tao/json/external/pegtl/istream_input.hpp +32 -0
  1069. data/ext/third_party/json/include/tao/json/external/pegtl/match.hpp +169 -0
  1070. data/ext/third_party/json/include/tao/json/external/pegtl/memory_input.hpp +365 -0
  1071. data/ext/third_party/json/include/tao/json/external/pegtl/mmap_input.hpp +79 -0
  1072. data/ext/third_party/json/include/tao/json/external/pegtl/must_if.hpp +64 -0
  1073. data/ext/third_party/json/include/tao/json/external/pegtl/normal.hpp +87 -0
  1074. data/ext/third_party/json/include/tao/json/external/pegtl/nothing.hpp +19 -0
  1075. data/ext/third_party/json/include/tao/json/external/pegtl/parse.hpp +51 -0
  1076. data/ext/third_party/json/include/tao/json/external/pegtl/parse_error.hpp +114 -0
  1077. data/ext/third_party/json/include/tao/json/external/pegtl/position.hpp +83 -0
  1078. data/ext/third_party/json/include/tao/json/external/pegtl/read_input.hpp +54 -0
  1079. data/ext/third_party/json/include/tao/json/external/pegtl/require_apply.hpp +16 -0
  1080. data/ext/third_party/json/include/tao/json/external/pegtl/require_apply0.hpp +16 -0
  1081. data/ext/third_party/json/include/tao/json/external/pegtl/rewind_mode.hpp +20 -0
  1082. data/ext/third_party/json/include/tao/json/external/pegtl/rules.hpp +68 -0
  1083. data/ext/third_party/json/include/tao/json/external/pegtl/string_input.hpp +64 -0
  1084. data/ext/third_party/json/include/tao/json/external/pegtl/tracking_mode.hpp +19 -0
  1085. data/ext/third_party/json/include/tao/json/external/pegtl/type_list.hpp +46 -0
  1086. data/ext/third_party/json/include/tao/json/external/pegtl/utf8.hpp +28 -0
  1087. data/ext/third_party/json/include/tao/json/external/pegtl/version.hpp +13 -0
  1088. data/ext/third_party/json/include/tao/json/external/pegtl/visit.hpp +66 -0
  1089. data/ext/third_party/json/include/tao/json/external/ryu.hpp +1216 -0
  1090. data/ext/third_party/json/include/tao/json/forward.hpp +44 -0
  1091. data/ext/third_party/json/include/tao/json/from_file.hpp +32 -0
  1092. data/ext/third_party/json/include/tao/json/from_input.hpp +32 -0
  1093. data/ext/third_party/json/include/tao/json/from_stream.hpp +45 -0
  1094. data/ext/third_party/json/include/tao/json/from_string.hpp +41 -0
  1095. data/ext/third_party/json/include/tao/json/internal/action.hpp +268 -0
  1096. data/ext/third_party/json/include/tao/json/internal/base64.hpp +55 -0
  1097. data/ext/third_party/json/include/tao/json/internal/base64url.hpp +53 -0
  1098. data/ext/third_party/json/include/tao/json/internal/dependent_false.hpp +14 -0
  1099. data/ext/third_party/json/include/tao/json/internal/endian.hpp +60 -0
  1100. data/ext/third_party/json/include/tao/json/internal/endian_gcc.hpp +198 -0
  1101. data/ext/third_party/json/include/tao/json/internal/endian_win.hpp +103 -0
  1102. data/ext/third_party/json/include/tao/json/internal/errors.hpp +85 -0
  1103. data/ext/third_party/json/include/tao/json/internal/escape.hpp +77 -0
  1104. data/ext/third_party/json/include/tao/json/internal/format.hpp +57 -0
  1105. data/ext/third_party/json/include/tao/json/internal/grammar.hpp +229 -0
  1106. data/ext/third_party/json/include/tao/json/internal/hexdump.hpp +31 -0
  1107. data/ext/third_party/json/include/tao/json/internal/identity.hpp +22 -0
  1108. data/ext/third_party/json/include/tao/json/internal/number_state.hpp +80 -0
  1109. data/ext/third_party/json/include/tao/json/internal/number_traits.hpp +267 -0
  1110. data/ext/third_party/json/include/tao/json/internal/pair.hpp +42 -0
  1111. data/ext/third_party/json/include/tao/json/internal/parse_util.hpp +112 -0
  1112. data/ext/third_party/json/include/tao/json/internal/sha256.hpp +218 -0
  1113. data/ext/third_party/json/include/tao/json/internal/single.hpp +40 -0
  1114. data/ext/third_party/json/include/tao/json/internal/string_t.hpp +35 -0
  1115. data/ext/third_party/json/include/tao/json/internal/type_traits.hpp +96 -0
  1116. data/ext/third_party/json/include/tao/json/internal/unescape_action.hpp +24 -0
  1117. data/ext/third_party/json/include/tao/json/internal/uri_fragment.hpp +182 -0
  1118. data/ext/third_party/json/include/tao/json/jaxn.hpp +19 -0
  1119. data/ext/third_party/json/include/tao/json/jaxn/consume_file.hpp +34 -0
  1120. data/ext/third_party/json/include/tao/json/jaxn/consume_string.hpp +32 -0
  1121. data/ext/third_party/json/include/tao/json/jaxn/events/from_file.hpp +28 -0
  1122. data/ext/third_party/json/include/tao/json/jaxn/events/from_input.hpp +45 -0
  1123. data/ext/third_party/json/include/tao/json/jaxn/events/from_stream.hpp +33 -0
  1124. data/ext/third_party/json/include/tao/json/jaxn/events/from_string.hpp +39 -0
  1125. data/ext/third_party/json/include/tao/json/jaxn/events/to_pretty_stream.hpp +69 -0
  1126. data/ext/third_party/json/include/tao/json/jaxn/events/to_stream.hpp +67 -0
  1127. data/ext/third_party/json/include/tao/json/jaxn/events/to_string.hpp +33 -0
  1128. data/ext/third_party/json/include/tao/json/jaxn/from_file.hpp +33 -0
  1129. data/ext/third_party/json/include/tao/json/jaxn/from_input.hpp +33 -0
  1130. data/ext/third_party/json/include/tao/json/jaxn/from_stream.hpp +48 -0
  1131. data/ext/third_party/json/include/tao/json/jaxn/from_string.hpp +42 -0
  1132. data/ext/third_party/json/include/tao/json/jaxn/internal/action.hpp +355 -0
  1133. data/ext/third_party/json/include/tao/json/jaxn/internal/bunescape_action.hpp +114 -0
  1134. data/ext/third_party/json/include/tao/json/jaxn/internal/errors.hpp +108 -0
  1135. data/ext/third_party/json/include/tao/json/jaxn/internal/grammar.hpp +375 -0
  1136. data/ext/third_party/json/include/tao/json/jaxn/internal/integer.hpp +255 -0
  1137. data/ext/third_party/json/include/tao/json/jaxn/internal/unescape_action.hpp +28 -0
  1138. data/ext/third_party/json/include/tao/json/jaxn/is_identifier.hpp +27 -0
  1139. data/ext/third_party/json/include/tao/json/jaxn/parts_parser.hpp +261 -0
  1140. data/ext/third_party/json/include/tao/json/jaxn/to_stream.hpp +36 -0
  1141. data/ext/third_party/json/include/tao/json/jaxn/to_string.hpp +33 -0
  1142. data/ext/third_party/json/include/tao/json/message_extension.hpp +49 -0
  1143. data/ext/third_party/json/include/tao/json/msgpack.hpp +19 -0
  1144. data/ext/third_party/json/include/tao/json/msgpack/consume_file.hpp +34 -0
  1145. data/ext/third_party/json/include/tao/json/msgpack/consume_string.hpp +32 -0
  1146. data/ext/third_party/json/include/tao/json/msgpack/events/from_binary.hpp +43 -0
  1147. data/ext/third_party/json/include/tao/json/msgpack/events/from_file.hpp +27 -0
  1148. data/ext/third_party/json/include/tao/json/msgpack/events/from_input.hpp +43 -0
  1149. data/ext/third_party/json/include/tao/json/msgpack/events/from_string.hpp +37 -0
  1150. data/ext/third_party/json/include/tao/json/msgpack/events/to_stream.hpp +214 -0
  1151. data/ext/third_party/json/include/tao/json/msgpack/events/to_string.hpp +31 -0
  1152. data/ext/third_party/json/include/tao/json/msgpack/from_binary.hpp +32 -0
  1153. data/ext/third_party/json/include/tao/json/msgpack/from_file.hpp +33 -0
  1154. data/ext/third_party/json/include/tao/json/msgpack/from_input.hpp +33 -0
  1155. data/ext/third_party/json/include/tao/json/msgpack/from_string.hpp +32 -0
  1156. data/ext/third_party/json/include/tao/json/msgpack/internal/format.hpp +57 -0
  1157. data/ext/third_party/json/include/tao/json/msgpack/internal/grammar.hpp +250 -0
  1158. data/ext/third_party/json/include/tao/json/msgpack/parts_parser.hpp +311 -0
  1159. data/ext/third_party/json/include/tao/json/msgpack/to_stream.hpp +27 -0
  1160. data/ext/third_party/json/include/tao/json/msgpack/to_string.hpp +28 -0
  1161. data/ext/third_party/json/include/tao/json/operators.hpp +490 -0
  1162. data/ext/third_party/json/include/tao/json/parts_parser.hpp +302 -0
  1163. data/ext/third_party/json/include/tao/json/pointer.hpp +432 -0
  1164. data/ext/third_party/json/include/tao/json/produce.hpp +61 -0
  1165. data/ext/third_party/json/include/tao/json/self_contained.hpp +131 -0
  1166. data/ext/third_party/json/include/tao/json/span.hpp +496 -0
  1167. data/ext/third_party/json/include/tao/json/stream.hpp +38 -0
  1168. data/ext/third_party/json/include/tao/json/to_stream.hpp +42 -0
  1169. data/ext/third_party/json/include/tao/json/to_string.hpp +23 -0
  1170. data/ext/third_party/json/include/tao/json/traits.hpp +971 -0
  1171. data/ext/third_party/json/include/tao/json/type.hpp +112 -0
  1172. data/ext/third_party/json/include/tao/json/ubjson.hpp +19 -0
  1173. data/ext/third_party/json/include/tao/json/ubjson/consume_file.hpp +34 -0
  1174. data/ext/third_party/json/include/tao/json/ubjson/consume_string.hpp +32 -0
  1175. data/ext/third_party/json/include/tao/json/ubjson/events/from_binary.hpp +43 -0
  1176. data/ext/third_party/json/include/tao/json/ubjson/events/from_file.hpp +27 -0
  1177. data/ext/third_party/json/include/tao/json/ubjson/events/from_input.hpp +43 -0
  1178. data/ext/third_party/json/include/tao/json/ubjson/events/from_string.hpp +37 -0
  1179. data/ext/third_party/json/include/tao/json/ubjson/events/to_stream.hpp +174 -0
  1180. data/ext/third_party/json/include/tao/json/ubjson/events/to_string.hpp +31 -0
  1181. data/ext/third_party/json/include/tao/json/ubjson/from_binary.hpp +32 -0
  1182. data/ext/third_party/json/include/tao/json/ubjson/from_file.hpp +33 -0
  1183. data/ext/third_party/json/include/tao/json/ubjson/from_input.hpp +33 -0
  1184. data/ext/third_party/json/include/tao/json/ubjson/from_string.hpp +32 -0
  1185. data/ext/third_party/json/include/tao/json/ubjson/internal/grammar.hpp +415 -0
  1186. data/ext/third_party/json/include/tao/json/ubjson/internal/marker.hpp +46 -0
  1187. data/ext/third_party/json/include/tao/json/ubjson/parts_parser.hpp +393 -0
  1188. data/ext/third_party/json/include/tao/json/ubjson/to_stream.hpp +28 -0
  1189. data/ext/third_party/json/include/tao/json/ubjson/to_string.hpp +29 -0
  1190. data/ext/third_party/json/include/tao/json/utf8.hpp +57 -0
  1191. data/ext/third_party/json/include/tao/json/value.hpp +12 -0
  1192. data/ext/third_party/snappy/CMakeLists.txt +345 -0
  1193. data/ext/third_party/snappy/COPYING +54 -0
  1194. data/ext/third_party/snappy/cmake/SnappyConfig.cmake.in +33 -0
  1195. data/ext/third_party/snappy/cmake/config.h.in +59 -0
  1196. data/ext/third_party/snappy/snappy-c.cc +90 -0
  1197. data/ext/third_party/snappy/snappy-c.h +138 -0
  1198. data/ext/third_party/snappy/snappy-internal.h +315 -0
  1199. data/ext/third_party/snappy/snappy-sinksource.cc +121 -0
  1200. data/ext/third_party/snappy/snappy-sinksource.h +182 -0
  1201. data/ext/third_party/snappy/snappy-stubs-internal.cc +42 -0
  1202. data/ext/third_party/snappy/snappy-stubs-internal.h +493 -0
  1203. data/ext/third_party/snappy/snappy-stubs-public.h.in +63 -0
  1204. data/ext/third_party/snappy/snappy.cc +1774 -0
  1205. data/ext/third_party/snappy/snappy.h +209 -0
  1206. data/ext/third_party/spdlog/CMakeLists.txt +291 -0
  1207. data/ext/third_party/spdlog/LICENSE +26 -0
  1208. data/ext/third_party/spdlog/cmake/ide.cmake +18 -0
  1209. data/ext/third_party/spdlog/cmake/pch.h.in +258 -0
  1210. data/ext/third_party/spdlog/cmake/spdlog.pc.in +13 -0
  1211. data/ext/third_party/spdlog/cmake/spdlogCPack.cmake +46 -0
  1212. data/ext/third_party/spdlog/cmake/spdlogConfig.cmake.in +15 -0
  1213. data/ext/third_party/spdlog/cmake/utils.cmake +61 -0
  1214. data/ext/third_party/spdlog/cmake/version.rc.in +42 -0
  1215. data/ext/third_party/spdlog/include/spdlog/async.h +93 -0
  1216. data/ext/third_party/spdlog/include/spdlog/async_logger-inl.h +92 -0
  1217. data/ext/third_party/spdlog/include/spdlog/async_logger.h +68 -0
  1218. data/ext/third_party/spdlog/include/spdlog/cfg/argv.h +44 -0
  1219. data/ext/third_party/spdlog/include/spdlog/cfg/env.h +38 -0
  1220. data/ext/third_party/spdlog/include/spdlog/cfg/helpers-inl.h +119 -0
  1221. data/ext/third_party/spdlog/include/spdlog/cfg/helpers.h +29 -0
  1222. data/ext/third_party/spdlog/include/spdlog/common-inl.h +76 -0
  1223. data/ext/third_party/spdlog/include/spdlog/common.h +245 -0
  1224. data/ext/third_party/spdlog/include/spdlog/details/backtracer-inl.h +69 -0
  1225. data/ext/third_party/spdlog/include/spdlog/details/backtracer.h +45 -0
  1226. data/ext/third_party/spdlog/include/spdlog/details/circular_q.h +141 -0
  1227. data/ext/third_party/spdlog/include/spdlog/details/console_globals.h +32 -0
  1228. data/ext/third_party/spdlog/include/spdlog/details/file_helper-inl.h +132 -0
  1229. data/ext/third_party/spdlog/include/spdlog/details/file_helper.h +59 -0
  1230. data/ext/third_party/spdlog/include/spdlog/details/fmt_helper.h +116 -0
  1231. data/ext/third_party/spdlog/include/spdlog/details/log_msg-inl.h +37 -0
  1232. data/ext/third_party/spdlog/include/spdlog/details/log_msg.h +36 -0
  1233. data/ext/third_party/spdlog/include/spdlog/details/log_msg_buffer-inl.h +58 -0
  1234. data/ext/third_party/spdlog/include/spdlog/details/log_msg_buffer.h +33 -0
  1235. data/ext/third_party/spdlog/include/spdlog/details/mpmc_blocking_q.h +120 -0
  1236. data/ext/third_party/spdlog/include/spdlog/details/null_mutex.h +49 -0
  1237. data/ext/third_party/spdlog/include/spdlog/details/os-inl.h +554 -0
  1238. data/ext/third_party/spdlog/include/spdlog/details/os.h +111 -0
  1239. data/ext/third_party/spdlog/include/spdlog/details/periodic_worker-inl.h +49 -0
  1240. data/ext/third_party/spdlog/include/spdlog/details/periodic_worker.h +40 -0
  1241. data/ext/third_party/spdlog/include/spdlog/details/registry-inl.h +313 -0
  1242. data/ext/third_party/spdlog/include/spdlog/details/registry.h +115 -0
  1243. data/ext/third_party/spdlog/include/spdlog/details/synchronous_factory.h +24 -0
  1244. data/ext/third_party/spdlog/include/spdlog/details/tcp_client-windows.h +175 -0
  1245. data/ext/third_party/spdlog/include/spdlog/details/tcp_client.h +146 -0
  1246. data/ext/third_party/spdlog/include/spdlog/details/thread_pool-inl.h +124 -0
  1247. data/ext/third_party/spdlog/include/spdlog/details/thread_pool.h +120 -0
  1248. data/ext/third_party/spdlog/include/spdlog/details/windows_include.h +11 -0
  1249. data/ext/third_party/spdlog/include/spdlog/fmt/bin_to_hex.h +216 -0
  1250. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/LICENSE.rst +27 -0
  1251. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/chrono.h +1123 -0
  1252. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/color.h +566 -0
  1253. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/compile.h +665 -0
  1254. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/core.h +1882 -0
  1255. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/format-inl.h +1453 -0
  1256. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/format.h +3729 -0
  1257. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/locale.h +78 -0
  1258. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/os.h +450 -0
  1259. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/ostream.h +167 -0
  1260. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/posix.h +2 -0
  1261. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/printf.h +751 -0
  1262. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/ranges.h +386 -0
  1263. data/ext/third_party/spdlog/include/spdlog/fmt/chrono.h +20 -0
  1264. data/ext/third_party/spdlog/include/spdlog/fmt/fmt.h +27 -0
  1265. data/ext/third_party/spdlog/include/spdlog/fmt/ostr.h +20 -0
  1266. data/ext/third_party/spdlog/include/spdlog/formatter.h +18 -0
  1267. data/ext/third_party/spdlog/include/spdlog/fwd.h +14 -0
  1268. data/ext/third_party/spdlog/include/spdlog/logger-inl.h +257 -0
  1269. data/ext/third_party/spdlog/include/spdlog/logger.h +366 -0
  1270. data/ext/third_party/spdlog/include/spdlog/pattern_formatter-inl.h +1373 -0
  1271. data/ext/third_party/spdlog/include/spdlog/pattern_formatter.h +126 -0
  1272. data/ext/third_party/spdlog/include/spdlog/sinks/android_sink.h +119 -0
  1273. data/ext/third_party/spdlog/include/spdlog/sinks/ansicolor_sink-inl.h +143 -0
  1274. data/ext/third_party/spdlog/include/spdlog/sinks/ansicolor_sink.h +118 -0
  1275. data/ext/third_party/spdlog/include/spdlog/sinks/base_sink-inl.h +63 -0
  1276. data/ext/third_party/spdlog/include/spdlog/sinks/base_sink.h +52 -0
  1277. data/ext/third_party/spdlog/include/spdlog/sinks/basic_file_sink-inl.h +43 -0
  1278. data/ext/third_party/spdlog/include/spdlog/sinks/basic_file_sink.h +58 -0
  1279. data/ext/third_party/spdlog/include/spdlog/sinks/daily_file_sink.h +204 -0
  1280. data/ext/third_party/spdlog/include/spdlog/sinks/dist_sink.h +97 -0
  1281. data/ext/third_party/spdlog/include/spdlog/sinks/dup_filter_sink.h +90 -0
  1282. data/ext/third_party/spdlog/include/spdlog/sinks/msvc_sink.h +49 -0
  1283. data/ext/third_party/spdlog/include/spdlog/sinks/null_sink.h +44 -0
  1284. data/ext/third_party/spdlog/include/spdlog/sinks/ostream_sink.h +50 -0
  1285. data/ext/third_party/spdlog/include/spdlog/sinks/ringbuffer_sink.h +74 -0
  1286. data/ext/third_party/spdlog/include/spdlog/sinks/rotating_file_sink-inl.h +131 -0
  1287. data/ext/third_party/spdlog/include/spdlog/sinks/rotating_file_sink.h +78 -0
  1288. data/ext/third_party/spdlog/include/spdlog/sinks/sink-inl.h +25 -0
  1289. data/ext/third_party/spdlog/include/spdlog/sinks/sink.h +35 -0
  1290. data/ext/third_party/spdlog/include/spdlog/sinks/stdout_color_sinks-inl.h +38 -0
  1291. data/ext/third_party/spdlog/include/spdlog/sinks/stdout_color_sinks.h +45 -0
  1292. data/ext/third_party/spdlog/include/spdlog/sinks/stdout_sinks-inl.h +123 -0
  1293. data/ext/third_party/spdlog/include/spdlog/sinks/stdout_sinks.h +87 -0
  1294. data/ext/third_party/spdlog/include/spdlog/sinks/syslog_sink.h +109 -0
  1295. data/ext/third_party/spdlog/include/spdlog/sinks/systemd_sink.h +103 -0
  1296. data/ext/third_party/spdlog/include/spdlog/sinks/tcp_sink.h +81 -0
  1297. data/ext/third_party/spdlog/include/spdlog/sinks/win_eventlog_sink.h +266 -0
  1298. data/ext/third_party/spdlog/include/spdlog/sinks/wincolor_sink-inl.h +170 -0
  1299. data/ext/third_party/spdlog/include/spdlog/sinks/wincolor_sink.h +94 -0
  1300. data/ext/third_party/spdlog/include/spdlog/spdlog-inl.h +125 -0
  1301. data/ext/third_party/spdlog/include/spdlog/spdlog.h +295 -0
  1302. data/ext/third_party/spdlog/include/spdlog/stopwatch.h +61 -0
  1303. data/ext/third_party/spdlog/include/spdlog/tweakme.h +116 -0
  1304. data/ext/third_party/spdlog/include/spdlog/version.h +10 -0
  1305. data/ext/third_party/spdlog/src/async.cpp +13 -0
  1306. data/ext/third_party/spdlog/src/cfg.cpp +8 -0
  1307. data/ext/third_party/spdlog/src/color_sinks.cpp +51 -0
  1308. data/ext/third_party/spdlog/src/file_sinks.cpp +20 -0
  1309. data/ext/third_party/spdlog/src/fmt.cpp +63 -0
  1310. data/ext/third_party/spdlog/src/spdlog.cpp +26 -0
  1311. data/ext/third_party/spdlog/src/stdout_sinks.cpp +29 -0
  1312. data/lib/active_support/cache/couchbase_store.rb +362 -0
  1313. data/lib/couchbase.rb +20 -0
  1314. data/lib/couchbase/analytics_options.rb +107 -0
  1315. data/lib/couchbase/authenticator.rb +65 -0
  1316. data/lib/couchbase/binary_collection.rb +128 -0
  1317. data/lib/couchbase/binary_collection_options.rb +24 -0
  1318. data/lib/couchbase/bucket.rb +144 -0
  1319. data/lib/couchbase/cluster.rb +430 -0
  1320. data/lib/couchbase/collection.rb +562 -0
  1321. data/lib/couchbase/collection_options.rb +324 -0
  1322. data/lib/couchbase/configuration.rb +57 -0
  1323. data/lib/couchbase/datastructures.rb +24 -0
  1324. data/lib/couchbase/datastructures/couchbase_list.rb +160 -0
  1325. data/lib/couchbase/datastructures/couchbase_map.rb +194 -0
  1326. data/lib/couchbase/datastructures/couchbase_queue.rb +134 -0
  1327. data/lib/couchbase/datastructures/couchbase_set.rb +128 -0
  1328. data/lib/couchbase/diagnostics.rb +181 -0
  1329. data/lib/couchbase/errors.rb +345 -0
  1330. data/lib/couchbase/json_transcoder.rb +32 -0
  1331. data/lib/couchbase/libcouchbase.bundle +0 -0
  1332. data/lib/couchbase/logger.rb +42 -0
  1333. data/lib/couchbase/management.rb +27 -0
  1334. data/lib/couchbase/management/analytics_index_manager.rb +433 -0
  1335. data/lib/couchbase/management/bucket_manager.rb +292 -0
  1336. data/lib/couchbase/management/collection_manager.rb +202 -0
  1337. data/lib/couchbase/management/query_index_manager.rb +342 -0
  1338. data/lib/couchbase/management/search_index_manager.rb +408 -0
  1339. data/lib/couchbase/management/user_manager.rb +449 -0
  1340. data/lib/couchbase/management/view_index_manager.rb +237 -0
  1341. data/lib/couchbase/mutation_state.rb +63 -0
  1342. data/lib/couchbase/options.rb +2104 -0
  1343. data/lib/couchbase/query_options.rb +120 -0
  1344. data/lib/couchbase/railtie.rb +45 -0
  1345. data/lib/couchbase/scope.rb +127 -0
  1346. data/lib/couchbase/search_options.rb +1487 -0
  1347. data/lib/couchbase/subdoc.rb +290 -0
  1348. data/lib/couchbase/utils.rb +21 -0
  1349. data/lib/couchbase/utils/time.rb +52 -0
  1350. data/lib/couchbase/version.rb +37 -0
  1351. data/lib/couchbase/view_options.rb +65 -0
  1352. data/lib/rails/generators/couchbase/config/config_generator.rb +27 -0
  1353. metadata +1403 -0
@@ -0,0 +1,63 @@
1
+ // Copyright 2011 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
+ // Various type stubs for the open-source version of Snappy.
30
+ //
31
+ // This file cannot include config.h, as it is included from snappy.h,
32
+ // which is a public header. Instead, snappy-stubs-public.h is generated by
33
+ // from snappy-stubs-public.h.in at configure time.
34
+
35
+ #ifndef THIRD_PARTY_SNAPPY_OPENSOURCE_SNAPPY_STUBS_PUBLIC_H_
36
+ #define THIRD_PARTY_SNAPPY_OPENSOURCE_SNAPPY_STUBS_PUBLIC_H_
37
+
38
+ #include <cstddef>
39
+
40
+ #if ${HAVE_SYS_UIO_H_01} // HAVE_SYS_UIO_H
41
+ #include <sys/uio.h>
42
+ #endif // HAVE_SYS_UIO_H
43
+
44
+ #define SNAPPY_MAJOR ${PROJECT_VERSION_MAJOR}
45
+ #define SNAPPY_MINOR ${PROJECT_VERSION_MINOR}
46
+ #define SNAPPY_PATCHLEVEL ${PROJECT_VERSION_PATCH}
47
+ #define SNAPPY_VERSION \
48
+ ((SNAPPY_MAJOR << 16) | (SNAPPY_MINOR << 8) | SNAPPY_PATCHLEVEL)
49
+
50
+ namespace snappy {
51
+
52
+ #if !${HAVE_SYS_UIO_H_01} // !HAVE_SYS_UIO_H
53
+ // Windows does not have an iovec type, yet the concept is universally useful.
54
+ // It is simple to define it ourselves, so we put it inside our own namespace.
55
+ struct iovec {
56
+ void* iov_base;
57
+ size_t iov_len;
58
+ };
59
+ #endif // !HAVE_SYS_UIO_H
60
+
61
+ } // namespace snappy
62
+
63
+ #endif // THIRD_PARTY_SNAPPY_OPENSOURCE_SNAPPY_STUBS_PUBLIC_H_
@@ -0,0 +1,1774 @@
1
+ // Copyright 2005 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
+ #include "snappy.h"
30
+ #include "snappy-internal.h"
31
+ #include "snappy-sinksource.h"
32
+
33
+ #if !defined(SNAPPY_HAVE_SSSE3)
34
+ // __SSSE3__ is defined by GCC and Clang. Visual Studio doesn't target SIMD
35
+ // support between SSE2 and AVX (so SSSE3 instructions require AVX support), and
36
+ // defines __AVX__ when AVX support is available.
37
+ #if defined(__SSSE3__) || defined(__AVX__)
38
+ #define SNAPPY_HAVE_SSSE3 1
39
+ #else
40
+ #define SNAPPY_HAVE_SSSE3 0
41
+ #endif
42
+ #endif // !defined(SNAPPY_HAVE_SSSE3)
43
+
44
+ #if !defined(SNAPPY_HAVE_BMI2)
45
+ // __BMI2__ is defined by GCC and Clang. Visual Studio doesn't target BMI2
46
+ // specifically, but it does define __AVX2__ when AVX2 support is available.
47
+ // Fortunately, AVX2 was introduced in Haswell, just like BMI2.
48
+ //
49
+ // BMI2 is not defined as a subset of AVX2 (unlike SSSE3 and AVX above). So,
50
+ // GCC and Clang can build code with AVX2 enabled but BMI2 disabled, in which
51
+ // case issuing BMI2 instructions results in a compiler error.
52
+ #if defined(__BMI2__) || (defined(_MSC_VER) && defined(__AVX2__))
53
+ #define SNAPPY_HAVE_BMI2 1
54
+ #else
55
+ #define SNAPPY_HAVE_BMI2 0
56
+ #endif
57
+ #endif // !defined(SNAPPY_HAVE_BMI2)
58
+
59
+ #if SNAPPY_HAVE_SSSE3
60
+ // Please do not replace with <x86intrin.h>. or with headers that assume more
61
+ // advanced SSE versions without checking with all the OWNERS.
62
+ #include <tmmintrin.h>
63
+ #endif
64
+
65
+ #if SNAPPY_HAVE_BMI2
66
+ // Please do not replace with <x86intrin.h>. or with headers that assume more
67
+ // advanced SSE versions without checking with all the OWNERS.
68
+ #include <immintrin.h>
69
+ #endif
70
+
71
+ #include <algorithm>
72
+ #include <cstdio>
73
+ #include <cstring>
74
+ #include <string>
75
+ #include <vector>
76
+
77
+ namespace snappy {
78
+
79
+ // The amount of slop bytes writers are using for unconditional copies.
80
+ constexpr int kSlopBytes = 64;
81
+
82
+ using internal::char_table;
83
+ using internal::COPY_1_BYTE_OFFSET;
84
+ using internal::COPY_2_BYTE_OFFSET;
85
+ using internal::COPY_4_BYTE_OFFSET;
86
+ using internal::kMaximumTagLength;
87
+ using internal::LITERAL;
88
+
89
+ // Any hash function will produce a valid compressed bitstream, but a good
90
+ // hash function reduces the number of collisions and thus yields better
91
+ // compression for compressible input, and more speed for incompressible
92
+ // input. Of course, it doesn't hurt if the hash function is reasonably fast
93
+ // either, as it gets called a lot.
94
+ static inline uint32_t HashBytes(uint32_t bytes, int shift) {
95
+ uint32_t kMul = 0x1e35a7bd;
96
+ return (bytes * kMul) >> shift;
97
+ }
98
+
99
+ size_t MaxCompressedLength(size_t source_bytes) {
100
+ // Compressed data can be defined as:
101
+ // compressed := item* literal*
102
+ // item := literal* copy
103
+ //
104
+ // The trailing literal sequence has a space blowup of at most 62/60
105
+ // since a literal of length 60 needs one tag byte + one extra byte
106
+ // for length information.
107
+ //
108
+ // Item blowup is trickier to measure. Suppose the "copy" op copies
109
+ // 4 bytes of data. Because of a special check in the encoding code,
110
+ // we produce a 4-byte copy only if the offset is < 65536. Therefore
111
+ // the copy op takes 3 bytes to encode, and this type of item leads
112
+ // to at most the 62/60 blowup for representing literals.
113
+ //
114
+ // Suppose the "copy" op copies 5 bytes of data. If the offset is big
115
+ // enough, it will take 5 bytes to encode the copy op. Therefore the
116
+ // worst case here is a one-byte literal followed by a five-byte copy.
117
+ // I.e., 6 bytes of input turn into 7 bytes of "compressed" data.
118
+ //
119
+ // This last factor dominates the blowup, so the final estimate is:
120
+ return 32 + source_bytes + source_bytes / 6;
121
+ }
122
+
123
+ namespace {
124
+
125
+ void UnalignedCopy64(const void* src, void* dst) {
126
+ char tmp[8];
127
+ std::memcpy(tmp, src, 8);
128
+ std::memcpy(dst, tmp, 8);
129
+ }
130
+
131
+ void UnalignedCopy128(const void* src, void* dst) {
132
+ // std::memcpy() gets vectorized when the appropriate compiler options are
133
+ // used. For example, x86 compilers targeting SSE2+ will optimize to an SSE2
134
+ // load and store.
135
+ char tmp[16];
136
+ std::memcpy(tmp, src, 16);
137
+ std::memcpy(dst, tmp, 16);
138
+ }
139
+
140
+ // Copy [src, src+(op_limit-op)) to [op, (op_limit-op)) a byte at a time. Used
141
+ // for handling COPY operations where the input and output regions may overlap.
142
+ // For example, suppose:
143
+ // src == "ab"
144
+ // op == src + 2
145
+ // op_limit == op + 20
146
+ // After IncrementalCopySlow(src, op, op_limit), the result will have eleven
147
+ // copies of "ab"
148
+ // ababababababababababab
149
+ // Note that this does not match the semantics of either std::memcpy() or
150
+ // std::memmove().
151
+ inline char* IncrementalCopySlow(const char* src, char* op,
152
+ char* const op_limit) {
153
+ // TODO: Remove pragma when LLVM is aware this
154
+ // function is only called in cold regions and when cold regions don't get
155
+ // vectorized or unrolled.
156
+ #ifdef __clang__
157
+ #pragma clang loop unroll(disable)
158
+ #endif
159
+ while (op < op_limit) {
160
+ *op++ = *src++;
161
+ }
162
+ return op_limit;
163
+ }
164
+
165
+ #if SNAPPY_HAVE_SSSE3
166
+
167
+ // This is a table of shuffle control masks that can be used as the source
168
+ // operand for PSHUFB to permute the contents of the destination XMM register
169
+ // into a repeating byte pattern.
170
+ alignas(16) const char pshufb_fill_patterns[7][16] = {
171
+ {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
172
+ {0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1},
173
+ {0, 1, 2, 0, 1, 2, 0, 1, 2, 0, 1, 2, 0, 1, 2, 0},
174
+ {0, 1, 2, 3, 0, 1, 2, 3, 0, 1, 2, 3, 0, 1, 2, 3},
175
+ {0, 1, 2, 3, 4, 0, 1, 2, 3, 4, 0, 1, 2, 3, 4, 0},
176
+ {0, 1, 2, 3, 4, 5, 0, 1, 2, 3, 4, 5, 0, 1, 2, 3},
177
+ {0, 1, 2, 3, 4, 5, 6, 0, 1, 2, 3, 4, 5, 6, 0, 1},
178
+ };
179
+
180
+ // j * (16 / j) for all j from 0 to 7. 0 is not actually used.
181
+ const uint8_t pattern_size_table[8] = {0, 16, 16, 15, 16, 15, 12, 14};
182
+
183
+ #endif // SNAPPY_HAVE_SSSE3
184
+
185
+ // Copy [src, src+(op_limit-op)) to [op, (op_limit-op)) but faster than
186
+ // IncrementalCopySlow. buf_limit is the address past the end of the writable
187
+ // region of the buffer.
188
+ inline char* IncrementalCopy(const char* src, char* op, char* const op_limit,
189
+ char* const buf_limit) {
190
+ // Terminology:
191
+ //
192
+ // slop = buf_limit - op
193
+ // pat = op - src
194
+ // len = limit - op
195
+ assert(src < op);
196
+ assert(op <= op_limit);
197
+ assert(op_limit <= buf_limit);
198
+ // NOTE: The copy tags use 3 or 6 bits to store the copy length, so len <= 64.
199
+ assert(op_limit - op <= 64);
200
+ // NOTE: In practice the compressor always emits len >= 4, so it is ok to
201
+ // assume that to optimize this function, but this is not guaranteed by the
202
+ // compression format, so we have to also handle len < 4 in case the input
203
+ // does not satisfy these conditions.
204
+
205
+ size_t pattern_size = op - src;
206
+ // The cases are split into different branches to allow the branch predictor,
207
+ // FDO, and static prediction hints to work better. For each input we list the
208
+ // ratio of invocations that match each condition.
209
+ //
210
+ // input slop < 16 pat < 8 len > 16
211
+ // ------------------------------------------
212
+ // html|html4|cp 0% 1.01% 27.73%
213
+ // urls 0% 0.88% 14.79%
214
+ // jpg 0% 64.29% 7.14%
215
+ // pdf 0% 2.56% 58.06%
216
+ // txt[1-4] 0% 0.23% 0.97%
217
+ // pb 0% 0.96% 13.88%
218
+ // bin 0.01% 22.27% 41.17%
219
+ //
220
+ // It is very rare that we don't have enough slop for doing block copies. It
221
+ // is also rare that we need to expand a pattern. Small patterns are common
222
+ // for incompressible formats and for those we are plenty fast already.
223
+ // Lengths are normally not greater than 16 but they vary depending on the
224
+ // input. In general if we always predict len <= 16 it would be an ok
225
+ // prediction.
226
+ //
227
+ // In order to be fast we want a pattern >= 8 bytes and an unrolled loop
228
+ // copying 2x 8 bytes at a time.
229
+
230
+ // Handle the uncommon case where pattern is less than 8 bytes.
231
+ if (SNAPPY_PREDICT_FALSE(pattern_size < 8)) {
232
+ #if SNAPPY_HAVE_SSSE3
233
+ // Load the first eight bytes into an 128-bit XMM register, then use PSHUFB
234
+ // to permute the register's contents in-place into a repeating sequence of
235
+ // the first "pattern_size" bytes.
236
+ // For example, suppose:
237
+ // src == "abc"
238
+ // op == op + 3
239
+ // After _mm_shuffle_epi8(), "pattern" will have five copies of "abc"
240
+ // followed by one byte of slop: abcabcabcabcabca.
241
+ //
242
+ // The non-SSE fallback implementation suffers from store-forwarding stalls
243
+ // because its loads and stores partly overlap. By expanding the pattern
244
+ // in-place, we avoid the penalty.
245
+ if (SNAPPY_PREDICT_TRUE(op <= buf_limit - 16)) {
246
+ const __m128i shuffle_mask = _mm_load_si128(
247
+ reinterpret_cast<const __m128i*>(pshufb_fill_patterns)
248
+ + pattern_size - 1);
249
+ const __m128i pattern = _mm_shuffle_epi8(
250
+ _mm_loadl_epi64(reinterpret_cast<const __m128i*>(src)), shuffle_mask);
251
+ // Uninitialized bytes are masked out by the shuffle mask.
252
+ // TODO: remove annotation and macro defs once MSan is fixed.
253
+ SNAPPY_ANNOTATE_MEMORY_IS_INITIALIZED(&pattern, sizeof(pattern));
254
+ pattern_size = pattern_size_table[pattern_size];
255
+ char* op_end = std::min(op_limit, buf_limit - 15);
256
+ while (op < op_end) {
257
+ _mm_storeu_si128(reinterpret_cast<__m128i*>(op), pattern);
258
+ op += pattern_size;
259
+ }
260
+ if (SNAPPY_PREDICT_TRUE(op >= op_limit)) return op_limit;
261
+ }
262
+ return IncrementalCopySlow(src, op, op_limit);
263
+ #else // !SNAPPY_HAVE_SSSE3
264
+ // If plenty of buffer space remains, expand the pattern to at least 8
265
+ // bytes. The way the following loop is written, we need 8 bytes of buffer
266
+ // space if pattern_size >= 4, 11 bytes if pattern_size is 1 or 3, and 10
267
+ // bytes if pattern_size is 2. Precisely encoding that is probably not
268
+ // worthwhile; instead, invoke the slow path if we cannot write 11 bytes
269
+ // (because 11 are required in the worst case).
270
+ if (SNAPPY_PREDICT_TRUE(op <= buf_limit - 11)) {
271
+ while (pattern_size < 8) {
272
+ UnalignedCopy64(src, op);
273
+ op += pattern_size;
274
+ pattern_size *= 2;
275
+ }
276
+ if (SNAPPY_PREDICT_TRUE(op >= op_limit)) return op_limit;
277
+ } else {
278
+ return IncrementalCopySlow(src, op, op_limit);
279
+ }
280
+ #endif // SNAPPY_HAVE_SSSE3
281
+ }
282
+ assert(pattern_size >= 8);
283
+
284
+ // Copy 2x 8 bytes at a time. Because op - src can be < 16, a single
285
+ // UnalignedCopy128 might overwrite data in op. UnalignedCopy64 is safe
286
+ // because expanding the pattern to at least 8 bytes guarantees that
287
+ // op - src >= 8.
288
+ //
289
+ // Typically, the op_limit is the gating factor so try to simplify the loop
290
+ // based on that.
291
+ if (SNAPPY_PREDICT_TRUE(op_limit <= buf_limit - 16)) {
292
+ // There is at least one, and at most four 16-byte blocks. Writing four
293
+ // conditionals instead of a loop allows FDO to layout the code with respect
294
+ // to the actual probabilities of each length.
295
+ // TODO: Replace with loop with trip count hint.
296
+ UnalignedCopy64(src, op);
297
+ UnalignedCopy64(src + 8, op + 8);
298
+
299
+ if (op + 16 < op_limit) {
300
+ UnalignedCopy64(src + 16, op + 16);
301
+ UnalignedCopy64(src + 24, op + 24);
302
+ }
303
+ if (op + 32 < op_limit) {
304
+ UnalignedCopy64(src + 32, op + 32);
305
+ UnalignedCopy64(src + 40, op + 40);
306
+ }
307
+ if (op + 48 < op_limit) {
308
+ UnalignedCopy64(src + 48, op + 48);
309
+ UnalignedCopy64(src + 56, op + 56);
310
+ }
311
+ return op_limit;
312
+ }
313
+
314
+ // Fall back to doing as much as we can with the available slop in the
315
+ // buffer. This code path is relatively cold however so we save code size by
316
+ // avoiding unrolling and vectorizing.
317
+ //
318
+ // TODO: Remove pragma when when cold regions don't get vectorized
319
+ // or unrolled.
320
+ #ifdef __clang__
321
+ #pragma clang loop unroll(disable)
322
+ #endif
323
+ for (char *op_end = buf_limit - 16; op < op_end; op += 16, src += 16) {
324
+ UnalignedCopy64(src, op);
325
+ UnalignedCopy64(src + 8, op + 8);
326
+ }
327
+ if (op >= op_limit)
328
+ return op_limit;
329
+
330
+ // We only take this branch if we didn't have enough slop and we can do a
331
+ // single 8 byte copy.
332
+ if (SNAPPY_PREDICT_FALSE(op <= buf_limit - 8)) {
333
+ UnalignedCopy64(src, op);
334
+ src += 8;
335
+ op += 8;
336
+ }
337
+ return IncrementalCopySlow(src, op, op_limit);
338
+ }
339
+
340
+ } // namespace
341
+
342
+ template <bool allow_fast_path>
343
+ static inline char* EmitLiteral(char* op,
344
+ const char* literal,
345
+ int len) {
346
+ // The vast majority of copies are below 16 bytes, for which a
347
+ // call to std::memcpy() is overkill. This fast path can sometimes
348
+ // copy up to 15 bytes too much, but that is okay in the
349
+ // main loop, since we have a bit to go on for both sides:
350
+ //
351
+ // - The input will always have kInputMarginBytes = 15 extra
352
+ // available bytes, as long as we're in the main loop, and
353
+ // if not, allow_fast_path = false.
354
+ // - The output will always have 32 spare bytes (see
355
+ // MaxCompressedLength).
356
+ assert(len > 0); // Zero-length literals are disallowed
357
+ int n = len - 1;
358
+ if (allow_fast_path && len <= 16) {
359
+ // Fits in tag byte
360
+ *op++ = LITERAL | (n << 2);
361
+
362
+ UnalignedCopy128(literal, op);
363
+ return op + len;
364
+ }
365
+
366
+ if (n < 60) {
367
+ // Fits in tag byte
368
+ *op++ = LITERAL | (n << 2);
369
+ } else {
370
+ int count = (Bits::Log2Floor(n) >> 3) + 1;
371
+ assert(count >= 1);
372
+ assert(count <= 4);
373
+ *op++ = LITERAL | ((59 + count) << 2);
374
+ // Encode in upcoming bytes.
375
+ // Write 4 bytes, though we may care about only 1 of them. The output buffer
376
+ // is guaranteed to have at least 3 more spaces left as 'len >= 61' holds
377
+ // here and there is a std::memcpy() of size 'len' below.
378
+ LittleEndian::Store32(op, n);
379
+ op += count;
380
+ }
381
+ std::memcpy(op, literal, len);
382
+ return op + len;
383
+ }
384
+
385
+ template <bool len_less_than_12>
386
+ static inline char* EmitCopyAtMost64(char* op, size_t offset, size_t len) {
387
+ assert(len <= 64);
388
+ assert(len >= 4);
389
+ assert(offset < 65536);
390
+ assert(len_less_than_12 == (len < 12));
391
+
392
+ if (len_less_than_12) {
393
+ uint32_t u = (len << 2) + (offset << 8);
394
+ uint32_t copy1 = COPY_1_BYTE_OFFSET - (4 << 2) + ((offset >> 3) & 0xe0);
395
+ uint32_t copy2 = COPY_2_BYTE_OFFSET - (1 << 2);
396
+ // It turns out that offset < 2048 is a difficult to predict branch.
397
+ // `perf record` shows this is the highest percentage of branch misses in
398
+ // benchmarks. This code produces branch free code, the data dependency
399
+ // chain that bottlenecks the throughput is so long that a few extra
400
+ // instructions are completely free (IPC << 6 because of data deps).
401
+ u += offset < 2048 ? copy1 : copy2;
402
+ LittleEndian::Store32(op, u);
403
+ op += offset < 2048 ? 2 : 3;
404
+ } else {
405
+ // Write 4 bytes, though we only care about 3 of them. The output buffer
406
+ // is required to have some slack, so the extra byte won't overrun it.
407
+ uint32_t u = COPY_2_BYTE_OFFSET + ((len - 1) << 2) + (offset << 8);
408
+ LittleEndian::Store32(op, u);
409
+ op += 3;
410
+ }
411
+ return op;
412
+ }
413
+
414
+ template <bool len_less_than_12>
415
+ static inline char* EmitCopy(char* op, size_t offset, size_t len) {
416
+ assert(len_less_than_12 == (len < 12));
417
+ if (len_less_than_12) {
418
+ return EmitCopyAtMost64</*len_less_than_12=*/true>(op, offset, len);
419
+ } else {
420
+ // A special case for len <= 64 might help, but so far measurements suggest
421
+ // it's in the noise.
422
+
423
+ // Emit 64 byte copies but make sure to keep at least four bytes reserved.
424
+ while (SNAPPY_PREDICT_FALSE(len >= 68)) {
425
+ op = EmitCopyAtMost64</*len_less_than_12=*/false>(op, offset, 64);
426
+ len -= 64;
427
+ }
428
+
429
+ // One or two copies will now finish the job.
430
+ if (len > 64) {
431
+ op = EmitCopyAtMost64</*len_less_than_12=*/false>(op, offset, 60);
432
+ len -= 60;
433
+ }
434
+
435
+ // Emit remainder.
436
+ if (len < 12) {
437
+ op = EmitCopyAtMost64</*len_less_than_12=*/true>(op, offset, len);
438
+ } else {
439
+ op = EmitCopyAtMost64</*len_less_than_12=*/false>(op, offset, len);
440
+ }
441
+ return op;
442
+ }
443
+ }
444
+
445
+ bool GetUncompressedLength(const char* start, size_t n, size_t* result) {
446
+ uint32_t v = 0;
447
+ const char* limit = start + n;
448
+ if (Varint::Parse32WithLimit(start, limit, &v) != NULL) {
449
+ *result = v;
450
+ return true;
451
+ } else {
452
+ return false;
453
+ }
454
+ }
455
+
456
+ namespace {
457
+ uint32_t CalculateTableSize(uint32_t input_size) {
458
+ static_assert(
459
+ kMaxHashTableSize >= kMinHashTableSize,
460
+ "kMaxHashTableSize should be greater or equal to kMinHashTableSize.");
461
+ if (input_size > kMaxHashTableSize) {
462
+ return kMaxHashTableSize;
463
+ }
464
+ if (input_size < kMinHashTableSize) {
465
+ return kMinHashTableSize;
466
+ }
467
+ // This is equivalent to Log2Ceiling(input_size), assuming input_size > 1.
468
+ // 2 << Log2Floor(x - 1) is equivalent to 1 << (1 + Log2Floor(x - 1)).
469
+ return 2u << Bits::Log2Floor(input_size - 1);
470
+ }
471
+ } // namespace
472
+
473
+ namespace internal {
474
+ WorkingMemory::WorkingMemory(size_t input_size) {
475
+ const size_t max_fragment_size = std::min(input_size, kBlockSize);
476
+ const size_t table_size = CalculateTableSize(max_fragment_size);
477
+ size_ = table_size * sizeof(*table_) + max_fragment_size +
478
+ MaxCompressedLength(max_fragment_size);
479
+ mem_ = std::allocator<char>().allocate(size_);
480
+ table_ = reinterpret_cast<uint16_t*>(mem_);
481
+ input_ = mem_ + table_size * sizeof(*table_);
482
+ output_ = input_ + max_fragment_size;
483
+ }
484
+
485
+ WorkingMemory::~WorkingMemory() {
486
+ std::allocator<char>().deallocate(mem_, size_);
487
+ }
488
+
489
+ uint16_t* WorkingMemory::GetHashTable(size_t fragment_size,
490
+ int* table_size) const {
491
+ const size_t htsize = CalculateTableSize(fragment_size);
492
+ memset(table_, 0, htsize * sizeof(*table_));
493
+ *table_size = htsize;
494
+ return table_;
495
+ }
496
+ } // end namespace internal
497
+
498
+ // Flat array compression that does not emit the "uncompressed length"
499
+ // prefix. Compresses "input" string to the "*op" buffer.
500
+ //
501
+ // REQUIRES: "input" is at most "kBlockSize" bytes long.
502
+ // REQUIRES: "op" points to an array of memory that is at least
503
+ // "MaxCompressedLength(input.size())" in size.
504
+ // REQUIRES: All elements in "table[0..table_size-1]" are initialized to zero.
505
+ // REQUIRES: "table_size" is a power of two
506
+ //
507
+ // Returns an "end" pointer into "op" buffer.
508
+ // "end - op" is the compressed size of "input".
509
+ namespace internal {
510
+ char* CompressFragment(const char* input,
511
+ size_t input_size,
512
+ char* op,
513
+ uint16_t* table,
514
+ const int table_size) {
515
+ // "ip" is the input pointer, and "op" is the output pointer.
516
+ const char* ip = input;
517
+ assert(input_size <= kBlockSize);
518
+ assert((table_size & (table_size - 1)) == 0); // table must be power of two
519
+ const int shift = 32 - Bits::Log2Floor(table_size);
520
+ assert(static_cast<int>(kuint32max >> shift) == table_size - 1);
521
+ const char* ip_end = input + input_size;
522
+ const char* base_ip = ip;
523
+
524
+ const size_t kInputMarginBytes = 15;
525
+ if (SNAPPY_PREDICT_TRUE(input_size >= kInputMarginBytes)) {
526
+ const char* ip_limit = input + input_size - kInputMarginBytes;
527
+
528
+ for (uint32_t preload = LittleEndian::Load32(ip + 1);;) {
529
+ // Bytes in [next_emit, ip) will be emitted as literal bytes. Or
530
+ // [next_emit, ip_end) after the main loop.
531
+ const char* next_emit = ip++;
532
+ uint64_t data = LittleEndian::Load64(ip);
533
+ // The body of this loop calls EmitLiteral once and then EmitCopy one or
534
+ // more times. (The exception is that when we're close to exhausting
535
+ // the input we goto emit_remainder.)
536
+ //
537
+ // In the first iteration of this loop we're just starting, so
538
+ // there's nothing to copy, so calling EmitLiteral once is
539
+ // necessary. And we only start a new iteration when the
540
+ // current iteration has determined that a call to EmitLiteral will
541
+ // precede the next call to EmitCopy (if any).
542
+ //
543
+ // Step 1: Scan forward in the input looking for a 4-byte-long match.
544
+ // If we get close to exhausting the input then goto emit_remainder.
545
+ //
546
+ // Heuristic match skipping: If 32 bytes are scanned with no matches
547
+ // found, start looking only at every other byte. If 32 more bytes are
548
+ // scanned (or skipped), look at every third byte, etc.. When a match is
549
+ // found, immediately go back to looking at every byte. This is a small
550
+ // loss (~5% performance, ~0.1% density) for compressible data due to more
551
+ // bookkeeping, but for non-compressible data (such as JPEG) it's a huge
552
+ // win since the compressor quickly "realizes" the data is incompressible
553
+ // and doesn't bother looking for matches everywhere.
554
+ //
555
+ // The "skip" variable keeps track of how many bytes there are since the
556
+ // last match; dividing it by 32 (ie. right-shifting by five) gives the
557
+ // number of bytes to move ahead for each iteration.
558
+ uint32_t skip = 32;
559
+
560
+ const char* candidate;
561
+ if (ip_limit - ip >= 16) {
562
+ auto delta = ip - base_ip;
563
+ for (int j = 0; j < 4; ++j) {
564
+ for (int k = 0; k < 4; ++k) {
565
+ int i = 4 * j + k;
566
+ // These for-loops are meant to be unrolled. So we can freely
567
+ // special case the first iteration to use the value already
568
+ // loaded in preload.
569
+ uint32_t dword = i == 0 ? preload : static_cast<uint32_t>(data);
570
+ assert(dword == LittleEndian::Load32(ip + i));
571
+ uint32_t hash = HashBytes(dword, shift);
572
+ candidate = base_ip + table[hash];
573
+ assert(candidate >= base_ip);
574
+ assert(candidate < ip + i);
575
+ table[hash] = delta + i;
576
+ if (SNAPPY_PREDICT_FALSE(LittleEndian::Load32(candidate) == dword)) {
577
+ *op = LITERAL | (i << 2);
578
+ UnalignedCopy128(next_emit, op + 1);
579
+ ip += i;
580
+ op = op + i + 2;
581
+ goto emit_match;
582
+ }
583
+ data >>= 8;
584
+ }
585
+ data = LittleEndian::Load64(ip + 4 * j + 4);
586
+ }
587
+ ip += 16;
588
+ skip += 16;
589
+ }
590
+ while (true) {
591
+ assert(static_cast<uint32_t>(data) == LittleEndian::Load32(ip));
592
+ uint32_t hash = HashBytes(data, shift);
593
+ uint32_t bytes_between_hash_lookups = skip >> 5;
594
+ skip += bytes_between_hash_lookups;
595
+ const char* next_ip = ip + bytes_between_hash_lookups;
596
+ if (SNAPPY_PREDICT_FALSE(next_ip > ip_limit)) {
597
+ ip = next_emit;
598
+ goto emit_remainder;
599
+ }
600
+ candidate = base_ip + table[hash];
601
+ assert(candidate >= base_ip);
602
+ assert(candidate < ip);
603
+
604
+ table[hash] = ip - base_ip;
605
+ if (SNAPPY_PREDICT_FALSE(static_cast<uint32_t>(data) ==
606
+ LittleEndian::Load32(candidate))) {
607
+ break;
608
+ }
609
+ data = LittleEndian::Load32(next_ip);
610
+ ip = next_ip;
611
+ }
612
+
613
+ // Step 2: A 4-byte match has been found. We'll later see if more
614
+ // than 4 bytes match. But, prior to the match, input
615
+ // bytes [next_emit, ip) are unmatched. Emit them as "literal bytes."
616
+ assert(next_emit + 16 <= ip_end);
617
+ op = EmitLiteral</*allow_fast_path=*/true>(op, next_emit, ip - next_emit);
618
+
619
+ // Step 3: Call EmitCopy, and then see if another EmitCopy could
620
+ // be our next move. Repeat until we find no match for the
621
+ // input immediately after what was consumed by the last EmitCopy call.
622
+ //
623
+ // If we exit this loop normally then we need to call EmitLiteral next,
624
+ // though we don't yet know how big the literal will be. We handle that
625
+ // by proceeding to the next iteration of the main loop. We also can exit
626
+ // this loop via goto if we get close to exhausting the input.
627
+ emit_match:
628
+ do {
629
+ // We have a 4-byte match at ip, and no need to emit any
630
+ // "literal bytes" prior to ip.
631
+ const char* base = ip;
632
+ std::pair<size_t, bool> p =
633
+ FindMatchLength(candidate + 4, ip + 4, ip_end, &data);
634
+ size_t matched = 4 + p.first;
635
+ ip += matched;
636
+ size_t offset = base - candidate;
637
+ assert(0 == memcmp(base, candidate, matched));
638
+ if (p.second) {
639
+ op = EmitCopy</*len_less_than_12=*/true>(op, offset, matched);
640
+ } else {
641
+ op = EmitCopy</*len_less_than_12=*/false>(op, offset, matched);
642
+ }
643
+ if (SNAPPY_PREDICT_FALSE(ip >= ip_limit)) {
644
+ goto emit_remainder;
645
+ }
646
+ // Expect 5 bytes to match
647
+ assert((data & 0xFFFFFFFFFF) ==
648
+ (LittleEndian::Load64(ip) & 0xFFFFFFFFFF));
649
+ // We are now looking for a 4-byte match again. We read
650
+ // table[Hash(ip, shift)] for that. To improve compression,
651
+ // we also update table[Hash(ip - 1, shift)] and table[Hash(ip, shift)].
652
+ table[HashBytes(LittleEndian::Load32(ip - 1), shift)] =
653
+ ip - base_ip - 1;
654
+ uint32_t hash = HashBytes(data, shift);
655
+ candidate = base_ip + table[hash];
656
+ table[hash] = ip - base_ip;
657
+ // Measurements on the benchmarks have shown the following probabilities
658
+ // for the loop to exit (ie. avg. number of iterations is reciprocal).
659
+ // BM_Flat/6 txt1 p = 0.3-0.4
660
+ // BM_Flat/7 txt2 p = 0.35
661
+ // BM_Flat/8 txt3 p = 0.3-0.4
662
+ // BM_Flat/9 txt3 p = 0.34-0.4
663
+ // BM_Flat/10 pb p = 0.4
664
+ // BM_Flat/11 gaviota p = 0.1
665
+ // BM_Flat/12 cp p = 0.5
666
+ // BM_Flat/13 c p = 0.3
667
+ } while (static_cast<uint32_t>(data) == LittleEndian::Load32(candidate));
668
+ // Because the least significant 5 bytes matched, we can utilize data
669
+ // for the next iteration.
670
+ preload = data >> 8;
671
+ }
672
+ }
673
+
674
+ emit_remainder:
675
+ // Emit the remaining bytes as a literal
676
+ if (ip < ip_end) {
677
+ op = EmitLiteral</*allow_fast_path=*/false>(op, ip, ip_end - ip);
678
+ }
679
+
680
+ return op;
681
+ }
682
+ } // end namespace internal
683
+
684
+ // Called back at avery compression call to trace parameters and sizes.
685
+ static inline void Report(const char *algorithm, size_t compressed_size,
686
+ size_t uncompressed_size) {
687
+ // TODO: Switch to [[maybe_unused]] when we can assume C++17.
688
+ (void)algorithm;
689
+ (void)compressed_size;
690
+ (void)uncompressed_size;
691
+ }
692
+
693
+ // Signature of output types needed by decompression code.
694
+ // The decompression code is templatized on a type that obeys this
695
+ // signature so that we do not pay virtual function call overhead in
696
+ // the middle of a tight decompression loop.
697
+ //
698
+ // class DecompressionWriter {
699
+ // public:
700
+ // // Called before decompression
701
+ // void SetExpectedLength(size_t length);
702
+ //
703
+ // // For performance a writer may choose to donate the cursor variable to the
704
+ // // decompression function. The decompression will inject it in all its
705
+ // // function calls to the writer. Keeping the important output cursor as a
706
+ // // function local stack variable allows the compiler to keep it in
707
+ // // register, which greatly aids performance by avoiding loads and stores of
708
+ // // this variable in the fast path loop iterations.
709
+ // T GetOutputPtr() const;
710
+ //
711
+ // // At end of decompression the loop donates the ownership of the cursor
712
+ // // variable back to the writer by calling this function.
713
+ // void SetOutputPtr(T op);
714
+ //
715
+ // // Called after decompression
716
+ // bool CheckLength() const;
717
+ //
718
+ // // Called repeatedly during decompression
719
+ // // Each function get a pointer to the op (output pointer), that the writer
720
+ // // can use and update. Note it's important that these functions get fully
721
+ // // inlined so that no actual address of the local variable needs to be
722
+ // // taken.
723
+ // bool Append(const char* ip, size_t length, T* op);
724
+ // bool AppendFromSelf(uint32_t offset, size_t length, T* op);
725
+ //
726
+ // // The rules for how TryFastAppend differs from Append are somewhat
727
+ // // convoluted:
728
+ // //
729
+ // // - TryFastAppend is allowed to decline (return false) at any
730
+ // // time, for any reason -- just "return false" would be
731
+ // // a perfectly legal implementation of TryFastAppend.
732
+ // // The intention is for TryFastAppend to allow a fast path
733
+ // // in the common case of a small append.
734
+ // // - TryFastAppend is allowed to read up to <available> bytes
735
+ // // from the input buffer, whereas Append is allowed to read
736
+ // // <length>. However, if it returns true, it must leave
737
+ // // at least five (kMaximumTagLength) bytes in the input buffer
738
+ // // afterwards, so that there is always enough space to read the
739
+ // // next tag without checking for a refill.
740
+ // // - TryFastAppend must always return decline (return false)
741
+ // // if <length> is 61 or more, as in this case the literal length is not
742
+ // // decoded fully. In practice, this should not be a big problem,
743
+ // // as it is unlikely that one would implement a fast path accepting
744
+ // // this much data.
745
+ // //
746
+ // bool TryFastAppend(const char* ip, size_t available, size_t length, T* op);
747
+ // };
748
+
749
+ static inline uint32_t ExtractLowBytes(uint32_t v, int n) {
750
+ assert(n >= 0);
751
+ assert(n <= 4);
752
+ #if SNAPPY_HAVE_BMI2
753
+ return _bzhi_u32(v, 8 * n);
754
+ #else
755
+ // This needs to be wider than uint32_t otherwise `mask << 32` will be
756
+ // undefined.
757
+ uint64_t mask = 0xffffffff;
758
+ return v & ~(mask << (8 * n));
759
+ #endif
760
+ }
761
+
762
+ static inline bool LeftShiftOverflows(uint8_t value, uint32_t shift) {
763
+ assert(shift < 32);
764
+ static const uint8_t masks[] = {
765
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, //
766
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, //
767
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, //
768
+ 0x00, 0x80, 0xc0, 0xe0, 0xf0, 0xf8, 0xfc, 0xfe};
769
+ return (value & masks[shift]) != 0;
770
+ }
771
+
772
+ // Helper class for decompression
773
+ class SnappyDecompressor {
774
+ private:
775
+ Source* reader_; // Underlying source of bytes to decompress
776
+ const char* ip_; // Points to next buffered byte
777
+ const char* ip_limit_; // Points just past buffered bytes
778
+ // If ip < ip_limit_min_maxtaglen_ it's safe to read kMaxTagLength from
779
+ // buffer.
780
+ const char* ip_limit_min_maxtaglen_;
781
+ uint32_t peeked_; // Bytes peeked from reader (need to skip)
782
+ bool eof_; // Hit end of input without an error?
783
+ char scratch_[kMaximumTagLength]; // See RefillTag().
784
+
785
+ // Ensure that all of the tag metadata for the next tag is available
786
+ // in [ip_..ip_limit_-1]. Also ensures that [ip,ip+4] is readable even
787
+ // if (ip_limit_ - ip_ < 5).
788
+ //
789
+ // Returns true on success, false on error or end of input.
790
+ bool RefillTag();
791
+
792
+ void ResetLimit(const char* ip) {
793
+ ip_limit_min_maxtaglen_ =
794
+ ip_limit_ - std::min<ptrdiff_t>(ip_limit_ - ip, kMaximumTagLength - 1);
795
+ }
796
+
797
+ public:
798
+ explicit SnappyDecompressor(Source* reader)
799
+ : reader_(reader),
800
+ ip_(NULL),
801
+ ip_limit_(NULL),
802
+ peeked_(0),
803
+ eof_(false) {
804
+ }
805
+
806
+ ~SnappyDecompressor() {
807
+ // Advance past any bytes we peeked at from the reader
808
+ reader_->Skip(peeked_);
809
+ }
810
+
811
+ // Returns true iff we have hit the end of the input without an error.
812
+ bool eof() const {
813
+ return eof_;
814
+ }
815
+
816
+ // Read the uncompressed length stored at the start of the compressed data.
817
+ // On success, stores the length in *result and returns true.
818
+ // On failure, returns false.
819
+ bool ReadUncompressedLength(uint32_t* result) {
820
+ assert(ip_ == NULL); // Must not have read anything yet
821
+ // Length is encoded in 1..5 bytes
822
+ *result = 0;
823
+ uint32_t shift = 0;
824
+ while (true) {
825
+ if (shift >= 32) return false;
826
+ size_t n;
827
+ const char* ip = reader_->Peek(&n);
828
+ if (n == 0) return false;
829
+ const unsigned char c = *(reinterpret_cast<const unsigned char*>(ip));
830
+ reader_->Skip(1);
831
+ uint32_t val = c & 0x7f;
832
+ if (LeftShiftOverflows(static_cast<uint8_t>(val), shift)) return false;
833
+ *result |= val << shift;
834
+ if (c < 128) {
835
+ break;
836
+ }
837
+ shift += 7;
838
+ }
839
+ return true;
840
+ }
841
+
842
+ // Process the next item found in the input.
843
+ // Returns true if successful, false on error or end of input.
844
+ template <class Writer>
845
+ #if defined(__GNUC__) && defined(__x86_64__)
846
+ __attribute__((aligned(32)))
847
+ #endif
848
+ void DecompressAllTags(Writer* writer) {
849
+ const char* ip = ip_;
850
+ ResetLimit(ip);
851
+ auto op = writer->GetOutputPtr();
852
+ // We could have put this refill fragment only at the beginning of the loop.
853
+ // However, duplicating it at the end of each branch gives the compiler more
854
+ // scope to optimize the <ip_limit_ - ip> expression based on the local
855
+ // context, which overall increases speed.
856
+ #define MAYBE_REFILL() \
857
+ if (SNAPPY_PREDICT_FALSE(ip >= ip_limit_min_maxtaglen_)) { \
858
+ ip_ = ip; \
859
+ if (SNAPPY_PREDICT_FALSE(!RefillTag())) goto exit; \
860
+ ip = ip_; \
861
+ ResetLimit(ip); \
862
+ } \
863
+ preload = static_cast<uint8_t>(*ip)
864
+
865
+ // At the start of the for loop below the least significant byte of preload
866
+ // contains the tag.
867
+ uint32_t preload;
868
+ MAYBE_REFILL();
869
+ for ( ;; ) {
870
+ const uint8_t c = static_cast<uint8_t>(preload);
871
+ ip++;
872
+
873
+ // Ratio of iterations that have LITERAL vs non-LITERAL for different
874
+ // inputs.
875
+ //
876
+ // input LITERAL NON_LITERAL
877
+ // -----------------------------------
878
+ // html|html4|cp 23% 77%
879
+ // urls 36% 64%
880
+ // jpg 47% 53%
881
+ // pdf 19% 81%
882
+ // txt[1-4] 25% 75%
883
+ // pb 24% 76%
884
+ // bin 24% 76%
885
+ if (SNAPPY_PREDICT_FALSE((c & 0x3) == LITERAL)) {
886
+ size_t literal_length = (c >> 2) + 1u;
887
+ if (writer->TryFastAppend(ip, ip_limit_ - ip, literal_length, &op)) {
888
+ assert(literal_length < 61);
889
+ ip += literal_length;
890
+ // NOTE: There is no MAYBE_REFILL() here, as TryFastAppend()
891
+ // will not return true unless there's already at least five spare
892
+ // bytes in addition to the literal.
893
+ preload = static_cast<uint8_t>(*ip);
894
+ continue;
895
+ }
896
+ if (SNAPPY_PREDICT_FALSE(literal_length >= 61)) {
897
+ // Long literal.
898
+ const size_t literal_length_length = literal_length - 60;
899
+ literal_length =
900
+ ExtractLowBytes(LittleEndian::Load32(ip), literal_length_length) +
901
+ 1;
902
+ ip += literal_length_length;
903
+ }
904
+
905
+ size_t avail = ip_limit_ - ip;
906
+ while (avail < literal_length) {
907
+ if (!writer->Append(ip, avail, &op)) goto exit;
908
+ literal_length -= avail;
909
+ reader_->Skip(peeked_);
910
+ size_t n;
911
+ ip = reader_->Peek(&n);
912
+ avail = n;
913
+ peeked_ = avail;
914
+ if (avail == 0) goto exit;
915
+ ip_limit_ = ip + avail;
916
+ ResetLimit(ip);
917
+ }
918
+ if (!writer->Append(ip, literal_length, &op)) goto exit;
919
+ ip += literal_length;
920
+ MAYBE_REFILL();
921
+ } else {
922
+ if (SNAPPY_PREDICT_FALSE((c & 3) == COPY_4_BYTE_OFFSET)) {
923
+ const size_t copy_offset = LittleEndian::Load32(ip);
924
+ const size_t length = (c >> 2) + 1;
925
+ ip += 4;
926
+
927
+ if (!writer->AppendFromSelf(copy_offset, length, &op)) goto exit;
928
+ } else {
929
+ const uint32_t entry = char_table[c];
930
+ preload = LittleEndian::Load32(ip);
931
+ const uint32_t trailer = ExtractLowBytes(preload, c & 3);
932
+ const uint32_t length = entry & 0xff;
933
+
934
+ // copy_offset/256 is encoded in bits 8..10. By just fetching
935
+ // those bits, we get copy_offset (since the bit-field starts at
936
+ // bit 8).
937
+ const uint32_t copy_offset = (entry & 0x700) + trailer;
938
+ if (!writer->AppendFromSelf(copy_offset, length, &op)) goto exit;
939
+
940
+ ip += (c & 3);
941
+ // By using the result of the previous load we reduce the critical
942
+ // dependency chain of ip to 4 cycles.
943
+ preload >>= (c & 3) * 8;
944
+ if (ip < ip_limit_min_maxtaglen_) continue;
945
+ }
946
+ MAYBE_REFILL();
947
+ }
948
+ }
949
+ #undef MAYBE_REFILL
950
+ exit:
951
+ writer->SetOutputPtr(op);
952
+ }
953
+ };
954
+
955
+ bool SnappyDecompressor::RefillTag() {
956
+ const char* ip = ip_;
957
+ if (ip == ip_limit_) {
958
+ // Fetch a new fragment from the reader
959
+ reader_->Skip(peeked_); // All peeked bytes are used up
960
+ size_t n;
961
+ ip = reader_->Peek(&n);
962
+ peeked_ = n;
963
+ eof_ = (n == 0);
964
+ if (eof_) return false;
965
+ ip_limit_ = ip + n;
966
+ }
967
+
968
+ // Read the tag character
969
+ assert(ip < ip_limit_);
970
+ const unsigned char c = *(reinterpret_cast<const unsigned char*>(ip));
971
+ const uint32_t entry = char_table[c];
972
+ const uint32_t needed = (entry >> 11) + 1; // +1 byte for 'c'
973
+ assert(needed <= sizeof(scratch_));
974
+
975
+ // Read more bytes from reader if needed
976
+ uint32_t nbuf = ip_limit_ - ip;
977
+ if (nbuf < needed) {
978
+ // Stitch together bytes from ip and reader to form the word
979
+ // contents. We store the needed bytes in "scratch_". They
980
+ // will be consumed immediately by the caller since we do not
981
+ // read more than we need.
982
+ std::memmove(scratch_, ip, nbuf);
983
+ reader_->Skip(peeked_); // All peeked bytes are used up
984
+ peeked_ = 0;
985
+ while (nbuf < needed) {
986
+ size_t length;
987
+ const char* src = reader_->Peek(&length);
988
+ if (length == 0) return false;
989
+ uint32_t to_add = std::min<uint32_t>(needed - nbuf, length);
990
+ std::memcpy(scratch_ + nbuf, src, to_add);
991
+ nbuf += to_add;
992
+ reader_->Skip(to_add);
993
+ }
994
+ assert(nbuf == needed);
995
+ ip_ = scratch_;
996
+ ip_limit_ = scratch_ + needed;
997
+ } else if (nbuf < kMaximumTagLength) {
998
+ // Have enough bytes, but move into scratch_ so that we do not
999
+ // read past end of input
1000
+ std::memmove(scratch_, ip, nbuf);
1001
+ reader_->Skip(peeked_); // All peeked bytes are used up
1002
+ peeked_ = 0;
1003
+ ip_ = scratch_;
1004
+ ip_limit_ = scratch_ + nbuf;
1005
+ } else {
1006
+ // Pass pointer to buffer returned by reader_.
1007
+ ip_ = ip;
1008
+ }
1009
+ return true;
1010
+ }
1011
+
1012
+ template <typename Writer>
1013
+ static bool InternalUncompress(Source* r, Writer* writer) {
1014
+ // Read the uncompressed length from the front of the compressed input
1015
+ SnappyDecompressor decompressor(r);
1016
+ uint32_t uncompressed_len = 0;
1017
+ if (!decompressor.ReadUncompressedLength(&uncompressed_len)) return false;
1018
+
1019
+ return InternalUncompressAllTags(&decompressor, writer, r->Available(),
1020
+ uncompressed_len);
1021
+ }
1022
+
1023
+ template <typename Writer>
1024
+ static bool InternalUncompressAllTags(SnappyDecompressor* decompressor,
1025
+ Writer* writer,
1026
+ uint32_t compressed_len,
1027
+ uint32_t uncompressed_len) {
1028
+ Report("snappy_uncompress", compressed_len, uncompressed_len);
1029
+
1030
+ writer->SetExpectedLength(uncompressed_len);
1031
+
1032
+ // Process the entire input
1033
+ decompressor->DecompressAllTags(writer);
1034
+ writer->Flush();
1035
+ return (decompressor->eof() && writer->CheckLength());
1036
+ }
1037
+
1038
+ bool GetUncompressedLength(Source* source, uint32_t* result) {
1039
+ SnappyDecompressor decompressor(source);
1040
+ return decompressor.ReadUncompressedLength(result);
1041
+ }
1042
+
1043
+ size_t Compress(Source* reader, Sink* writer) {
1044
+ size_t written = 0;
1045
+ size_t N = reader->Available();
1046
+ const size_t uncompressed_size = N;
1047
+ char ulength[Varint::kMax32];
1048
+ char* p = Varint::Encode32(ulength, N);
1049
+ writer->Append(ulength, p-ulength);
1050
+ written += (p - ulength);
1051
+
1052
+ internal::WorkingMemory wmem(N);
1053
+
1054
+ while (N > 0) {
1055
+ // Get next block to compress (without copying if possible)
1056
+ size_t fragment_size;
1057
+ const char* fragment = reader->Peek(&fragment_size);
1058
+ assert(fragment_size != 0); // premature end of input
1059
+ const size_t num_to_read = std::min(N, kBlockSize);
1060
+ size_t bytes_read = fragment_size;
1061
+
1062
+ size_t pending_advance = 0;
1063
+ if (bytes_read >= num_to_read) {
1064
+ // Buffer returned by reader is large enough
1065
+ pending_advance = num_to_read;
1066
+ fragment_size = num_to_read;
1067
+ } else {
1068
+ char* scratch = wmem.GetScratchInput();
1069
+ std::memcpy(scratch, fragment, bytes_read);
1070
+ reader->Skip(bytes_read);
1071
+
1072
+ while (bytes_read < num_to_read) {
1073
+ fragment = reader->Peek(&fragment_size);
1074
+ size_t n = std::min<size_t>(fragment_size, num_to_read - bytes_read);
1075
+ std::memcpy(scratch + bytes_read, fragment, n);
1076
+ bytes_read += n;
1077
+ reader->Skip(n);
1078
+ }
1079
+ assert(bytes_read == num_to_read);
1080
+ fragment = scratch;
1081
+ fragment_size = num_to_read;
1082
+ }
1083
+ assert(fragment_size == num_to_read);
1084
+
1085
+ // Get encoding table for compression
1086
+ int table_size;
1087
+ uint16_t* table = wmem.GetHashTable(num_to_read, &table_size);
1088
+
1089
+ // Compress input_fragment and append to dest
1090
+ const int max_output = MaxCompressedLength(num_to_read);
1091
+
1092
+ // Need a scratch buffer for the output, in case the byte sink doesn't
1093
+ // have room for us directly.
1094
+
1095
+ // Since we encode kBlockSize regions followed by a region
1096
+ // which is <= kBlockSize in length, a previously allocated
1097
+ // scratch_output[] region is big enough for this iteration.
1098
+ char* dest = writer->GetAppendBuffer(max_output, wmem.GetScratchOutput());
1099
+ char* end = internal::CompressFragment(fragment, fragment_size, dest, table,
1100
+ table_size);
1101
+ writer->Append(dest, end - dest);
1102
+ written += (end - dest);
1103
+
1104
+ N -= num_to_read;
1105
+ reader->Skip(pending_advance);
1106
+ }
1107
+
1108
+ Report("snappy_compress", written, uncompressed_size);
1109
+
1110
+ return written;
1111
+ }
1112
+
1113
+ // -----------------------------------------------------------------------
1114
+ // IOVec interfaces
1115
+ // -----------------------------------------------------------------------
1116
+
1117
+ // A type that writes to an iovec.
1118
+ // Note that this is not a "ByteSink", but a type that matches the
1119
+ // Writer template argument to SnappyDecompressor::DecompressAllTags().
1120
+ class SnappyIOVecWriter {
1121
+ private:
1122
+ // output_iov_end_ is set to iov + count and used to determine when
1123
+ // the end of the iovs is reached.
1124
+ const struct iovec* output_iov_end_;
1125
+
1126
+ #if !defined(NDEBUG)
1127
+ const struct iovec* output_iov_;
1128
+ #endif // !defined(NDEBUG)
1129
+
1130
+ // Current iov that is being written into.
1131
+ const struct iovec* curr_iov_;
1132
+
1133
+ // Pointer to current iov's write location.
1134
+ char* curr_iov_output_;
1135
+
1136
+ // Remaining bytes to write into curr_iov_output.
1137
+ size_t curr_iov_remaining_;
1138
+
1139
+ // Total bytes decompressed into output_iov_ so far.
1140
+ size_t total_written_;
1141
+
1142
+ // Maximum number of bytes that will be decompressed into output_iov_.
1143
+ size_t output_limit_;
1144
+
1145
+ static inline char* GetIOVecPointer(const struct iovec* iov, size_t offset) {
1146
+ return reinterpret_cast<char*>(iov->iov_base) + offset;
1147
+ }
1148
+
1149
+ public:
1150
+ // Does not take ownership of iov. iov must be valid during the
1151
+ // entire lifetime of the SnappyIOVecWriter.
1152
+ inline SnappyIOVecWriter(const struct iovec* iov, size_t iov_count)
1153
+ : output_iov_end_(iov + iov_count),
1154
+ #if !defined(NDEBUG)
1155
+ output_iov_(iov),
1156
+ #endif // !defined(NDEBUG)
1157
+ curr_iov_(iov),
1158
+ curr_iov_output_(iov_count ? reinterpret_cast<char*>(iov->iov_base)
1159
+ : nullptr),
1160
+ curr_iov_remaining_(iov_count ? iov->iov_len : 0),
1161
+ total_written_(0),
1162
+ output_limit_(-1) {}
1163
+
1164
+ inline void SetExpectedLength(size_t len) {
1165
+ output_limit_ = len;
1166
+ }
1167
+
1168
+ inline bool CheckLength() const {
1169
+ return total_written_ == output_limit_;
1170
+ }
1171
+
1172
+ inline bool Append(const char* ip, size_t len, char**) {
1173
+ if (total_written_ + len > output_limit_) {
1174
+ return false;
1175
+ }
1176
+
1177
+ return AppendNoCheck(ip, len);
1178
+ }
1179
+
1180
+ char* GetOutputPtr() { return nullptr; }
1181
+ void SetOutputPtr(char* op) {
1182
+ // TODO: Switch to [[maybe_unused]] when we can assume C++17.
1183
+ (void)op;
1184
+ }
1185
+
1186
+ inline bool AppendNoCheck(const char* ip, size_t len) {
1187
+ while (len > 0) {
1188
+ if (curr_iov_remaining_ == 0) {
1189
+ // This iovec is full. Go to the next one.
1190
+ if (curr_iov_ + 1 >= output_iov_end_) {
1191
+ return false;
1192
+ }
1193
+ ++curr_iov_;
1194
+ curr_iov_output_ = reinterpret_cast<char*>(curr_iov_->iov_base);
1195
+ curr_iov_remaining_ = curr_iov_->iov_len;
1196
+ }
1197
+
1198
+ const size_t to_write = std::min(len, curr_iov_remaining_);
1199
+ std::memcpy(curr_iov_output_, ip, to_write);
1200
+ curr_iov_output_ += to_write;
1201
+ curr_iov_remaining_ -= to_write;
1202
+ total_written_ += to_write;
1203
+ ip += to_write;
1204
+ len -= to_write;
1205
+ }
1206
+
1207
+ return true;
1208
+ }
1209
+
1210
+ inline bool TryFastAppend(const char* ip, size_t available, size_t len,
1211
+ char**) {
1212
+ const size_t space_left = output_limit_ - total_written_;
1213
+ if (len <= 16 && available >= 16 + kMaximumTagLength && space_left >= 16 &&
1214
+ curr_iov_remaining_ >= 16) {
1215
+ // Fast path, used for the majority (about 95%) of invocations.
1216
+ UnalignedCopy128(ip, curr_iov_output_);
1217
+ curr_iov_output_ += len;
1218
+ curr_iov_remaining_ -= len;
1219
+ total_written_ += len;
1220
+ return true;
1221
+ }
1222
+
1223
+ return false;
1224
+ }
1225
+
1226
+ inline bool AppendFromSelf(size_t offset, size_t len, char**) {
1227
+ // See SnappyArrayWriter::AppendFromSelf for an explanation of
1228
+ // the "offset - 1u" trick.
1229
+ if (offset - 1u >= total_written_) {
1230
+ return false;
1231
+ }
1232
+ const size_t space_left = output_limit_ - total_written_;
1233
+ if (len > space_left) {
1234
+ return false;
1235
+ }
1236
+
1237
+ // Locate the iovec from which we need to start the copy.
1238
+ const iovec* from_iov = curr_iov_;
1239
+ size_t from_iov_offset = curr_iov_->iov_len - curr_iov_remaining_;
1240
+ while (offset > 0) {
1241
+ if (from_iov_offset >= offset) {
1242
+ from_iov_offset -= offset;
1243
+ break;
1244
+ }
1245
+
1246
+ offset -= from_iov_offset;
1247
+ --from_iov;
1248
+ #if !defined(NDEBUG)
1249
+ assert(from_iov >= output_iov_);
1250
+ #endif // !defined(NDEBUG)
1251
+ from_iov_offset = from_iov->iov_len;
1252
+ }
1253
+
1254
+ // Copy <len> bytes starting from the iovec pointed to by from_iov_index to
1255
+ // the current iovec.
1256
+ while (len > 0) {
1257
+ assert(from_iov <= curr_iov_);
1258
+ if (from_iov != curr_iov_) {
1259
+ const size_t to_copy =
1260
+ std::min(from_iov->iov_len - from_iov_offset, len);
1261
+ AppendNoCheck(GetIOVecPointer(from_iov, from_iov_offset), to_copy);
1262
+ len -= to_copy;
1263
+ if (len > 0) {
1264
+ ++from_iov;
1265
+ from_iov_offset = 0;
1266
+ }
1267
+ } else {
1268
+ size_t to_copy = curr_iov_remaining_;
1269
+ if (to_copy == 0) {
1270
+ // This iovec is full. Go to the next one.
1271
+ if (curr_iov_ + 1 >= output_iov_end_) {
1272
+ return false;
1273
+ }
1274
+ ++curr_iov_;
1275
+ curr_iov_output_ = reinterpret_cast<char*>(curr_iov_->iov_base);
1276
+ curr_iov_remaining_ = curr_iov_->iov_len;
1277
+ continue;
1278
+ }
1279
+ if (to_copy > len) {
1280
+ to_copy = len;
1281
+ }
1282
+
1283
+ IncrementalCopy(GetIOVecPointer(from_iov, from_iov_offset),
1284
+ curr_iov_output_, curr_iov_output_ + to_copy,
1285
+ curr_iov_output_ + curr_iov_remaining_);
1286
+ curr_iov_output_ += to_copy;
1287
+ curr_iov_remaining_ -= to_copy;
1288
+ from_iov_offset += to_copy;
1289
+ total_written_ += to_copy;
1290
+ len -= to_copy;
1291
+ }
1292
+ }
1293
+
1294
+ return true;
1295
+ }
1296
+
1297
+ inline void Flush() {}
1298
+ };
1299
+
1300
+ bool RawUncompressToIOVec(const char* compressed, size_t compressed_length,
1301
+ const struct iovec* iov, size_t iov_cnt) {
1302
+ ByteArraySource reader(compressed, compressed_length);
1303
+ return RawUncompressToIOVec(&reader, iov, iov_cnt);
1304
+ }
1305
+
1306
+ bool RawUncompressToIOVec(Source* compressed, const struct iovec* iov,
1307
+ size_t iov_cnt) {
1308
+ SnappyIOVecWriter output(iov, iov_cnt);
1309
+ return InternalUncompress(compressed, &output);
1310
+ }
1311
+
1312
+ // -----------------------------------------------------------------------
1313
+ // Flat array interfaces
1314
+ // -----------------------------------------------------------------------
1315
+
1316
+ // A type that writes to a flat array.
1317
+ // Note that this is not a "ByteSink", but a type that matches the
1318
+ // Writer template argument to SnappyDecompressor::DecompressAllTags().
1319
+ class SnappyArrayWriter {
1320
+ private:
1321
+ char* base_;
1322
+ char* op_;
1323
+ char* op_limit_;
1324
+ // If op < op_limit_min_slop_ then it's safe to unconditionally write
1325
+ // kSlopBytes starting at op.
1326
+ char* op_limit_min_slop_;
1327
+
1328
+ public:
1329
+ inline explicit SnappyArrayWriter(char* dst)
1330
+ : base_(dst),
1331
+ op_(dst),
1332
+ op_limit_(dst),
1333
+ op_limit_min_slop_(dst) {} // Safe default see invariant.
1334
+
1335
+ inline void SetExpectedLength(size_t len) {
1336
+ op_limit_ = op_ + len;
1337
+ // Prevent pointer from being past the buffer.
1338
+ op_limit_min_slop_ = op_limit_ - std::min<size_t>(kSlopBytes - 1, len);
1339
+ }
1340
+
1341
+ inline bool CheckLength() const {
1342
+ return op_ == op_limit_;
1343
+ }
1344
+
1345
+ char* GetOutputPtr() { return op_; }
1346
+ void SetOutputPtr(char* op) { op_ = op; }
1347
+
1348
+ inline bool Append(const char* ip, size_t len, char** op_p) {
1349
+ char* op = *op_p;
1350
+ const size_t space_left = op_limit_ - op;
1351
+ if (space_left < len) return false;
1352
+ std::memcpy(op, ip, len);
1353
+ *op_p = op + len;
1354
+ return true;
1355
+ }
1356
+
1357
+ inline bool TryFastAppend(const char* ip, size_t available, size_t len,
1358
+ char** op_p) {
1359
+ char* op = *op_p;
1360
+ const size_t space_left = op_limit_ - op;
1361
+ if (len <= 16 && available >= 16 + kMaximumTagLength && space_left >= 16) {
1362
+ // Fast path, used for the majority (about 95%) of invocations.
1363
+ UnalignedCopy128(ip, op);
1364
+ *op_p = op + len;
1365
+ return true;
1366
+ } else {
1367
+ return false;
1368
+ }
1369
+ }
1370
+
1371
+ SNAPPY_ATTRIBUTE_ALWAYS_INLINE
1372
+ inline bool AppendFromSelf(size_t offset, size_t len, char** op_p) {
1373
+ char* const op = *op_p;
1374
+ assert(op >= base_);
1375
+ char* const op_end = op + len;
1376
+
1377
+ // Check if we try to append from before the start of the buffer.
1378
+ if (SNAPPY_PREDICT_FALSE(static_cast<size_t>(op - base_) < offset))
1379
+ return false;
1380
+
1381
+ if (SNAPPY_PREDICT_FALSE((kSlopBytes < 64 && len > kSlopBytes) ||
1382
+ op >= op_limit_min_slop_ || offset < len)) {
1383
+ if (op_end > op_limit_ || offset == 0) return false;
1384
+ *op_p = IncrementalCopy(op - offset, op, op_end, op_limit_);
1385
+ return true;
1386
+ }
1387
+ std::memmove(op, op - offset, kSlopBytes);
1388
+ *op_p = op_end;
1389
+ return true;
1390
+ }
1391
+ inline size_t Produced() const {
1392
+ assert(op_ >= base_);
1393
+ return op_ - base_;
1394
+ }
1395
+ inline void Flush() {}
1396
+ };
1397
+
1398
+ bool RawUncompress(const char* compressed, size_t compressed_length,
1399
+ char* uncompressed) {
1400
+ ByteArraySource reader(compressed, compressed_length);
1401
+ return RawUncompress(&reader, uncompressed);
1402
+ }
1403
+
1404
+ bool RawUncompress(Source* compressed, char* uncompressed) {
1405
+ SnappyArrayWriter output(uncompressed);
1406
+ return InternalUncompress(compressed, &output);
1407
+ }
1408
+
1409
+ bool Uncompress(const char* compressed, size_t compressed_length,
1410
+ std::string* uncompressed) {
1411
+ size_t ulength;
1412
+ if (!GetUncompressedLength(compressed, compressed_length, &ulength)) {
1413
+ return false;
1414
+ }
1415
+ // On 32-bit builds: max_size() < kuint32max. Check for that instead
1416
+ // of crashing (e.g., consider externally specified compressed data).
1417
+ if (ulength > uncompressed->max_size()) {
1418
+ return false;
1419
+ }
1420
+ STLStringResizeUninitialized(uncompressed, ulength);
1421
+ return RawUncompress(compressed, compressed_length,
1422
+ string_as_array(uncompressed));
1423
+ }
1424
+
1425
+ // A Writer that drops everything on the floor and just does validation
1426
+ class SnappyDecompressionValidator {
1427
+ private:
1428
+ size_t expected_;
1429
+ size_t produced_;
1430
+
1431
+ public:
1432
+ inline SnappyDecompressionValidator() : expected_(0), produced_(0) { }
1433
+ inline void SetExpectedLength(size_t len) {
1434
+ expected_ = len;
1435
+ }
1436
+ size_t GetOutputPtr() { return produced_; }
1437
+ void SetOutputPtr(size_t op) { produced_ = op; }
1438
+ inline bool CheckLength() const {
1439
+ return expected_ == produced_;
1440
+ }
1441
+ inline bool Append(const char* ip, size_t len, size_t* produced) {
1442
+ // TODO: Switch to [[maybe_unused]] when we can assume C++17.
1443
+ (void)ip;
1444
+
1445
+ *produced += len;
1446
+ return *produced <= expected_;
1447
+ }
1448
+ inline bool TryFastAppend(const char* ip, size_t available, size_t length,
1449
+ size_t* produced) {
1450
+ // TODO: Switch to [[maybe_unused]] when we can assume C++17.
1451
+ (void)ip;
1452
+ (void)available;
1453
+ (void)length;
1454
+ (void)produced;
1455
+
1456
+ return false;
1457
+ }
1458
+ inline bool AppendFromSelf(size_t offset, size_t len, size_t* produced) {
1459
+ // See SnappyArrayWriter::AppendFromSelf for an explanation of
1460
+ // the "offset - 1u" trick.
1461
+ if (*produced <= offset - 1u) return false;
1462
+ *produced += len;
1463
+ return *produced <= expected_;
1464
+ }
1465
+ inline void Flush() {}
1466
+ };
1467
+
1468
+ bool IsValidCompressedBuffer(const char* compressed, size_t compressed_length) {
1469
+ ByteArraySource reader(compressed, compressed_length);
1470
+ SnappyDecompressionValidator writer;
1471
+ return InternalUncompress(&reader, &writer);
1472
+ }
1473
+
1474
+ bool IsValidCompressed(Source* compressed) {
1475
+ SnappyDecompressionValidator writer;
1476
+ return InternalUncompress(compressed, &writer);
1477
+ }
1478
+
1479
+ void RawCompress(const char* input,
1480
+ size_t input_length,
1481
+ char* compressed,
1482
+ size_t* compressed_length) {
1483
+ ByteArraySource reader(input, input_length);
1484
+ UncheckedByteArraySink writer(compressed);
1485
+ Compress(&reader, &writer);
1486
+
1487
+ // Compute how many bytes were added
1488
+ *compressed_length = (writer.CurrentDestination() - compressed);
1489
+ }
1490
+
1491
+ size_t Compress(const char* input, size_t input_length,
1492
+ std::string* compressed) {
1493
+ // Pre-grow the buffer to the max length of the compressed output
1494
+ STLStringResizeUninitialized(compressed, MaxCompressedLength(input_length));
1495
+
1496
+ size_t compressed_length;
1497
+ RawCompress(input, input_length, string_as_array(compressed),
1498
+ &compressed_length);
1499
+ compressed->resize(compressed_length);
1500
+ return compressed_length;
1501
+ }
1502
+
1503
+ // -----------------------------------------------------------------------
1504
+ // Sink interface
1505
+ // -----------------------------------------------------------------------
1506
+
1507
+ // A type that decompresses into a Sink. The template parameter
1508
+ // Allocator must export one method "char* Allocate(int size);", which
1509
+ // allocates a buffer of "size" and appends that to the destination.
1510
+ template <typename Allocator>
1511
+ class SnappyScatteredWriter {
1512
+ Allocator allocator_;
1513
+
1514
+ // We need random access into the data generated so far. Therefore
1515
+ // we keep track of all of the generated data as an array of blocks.
1516
+ // All of the blocks except the last have length kBlockSize.
1517
+ std::vector<char*> blocks_;
1518
+ size_t expected_;
1519
+
1520
+ // Total size of all fully generated blocks so far
1521
+ size_t full_size_;
1522
+
1523
+ // Pointer into current output block
1524
+ char* op_base_; // Base of output block
1525
+ char* op_ptr_; // Pointer to next unfilled byte in block
1526
+ char* op_limit_; // Pointer just past block
1527
+ // If op < op_limit_min_slop_ then it's safe to unconditionally write
1528
+ // kSlopBytes starting at op.
1529
+ char* op_limit_min_slop_;
1530
+
1531
+ inline size_t Size() const {
1532
+ return full_size_ + (op_ptr_ - op_base_);
1533
+ }
1534
+
1535
+ bool SlowAppend(const char* ip, size_t len);
1536
+ bool SlowAppendFromSelf(size_t offset, size_t len);
1537
+
1538
+ public:
1539
+ inline explicit SnappyScatteredWriter(const Allocator& allocator)
1540
+ : allocator_(allocator),
1541
+ full_size_(0),
1542
+ op_base_(NULL),
1543
+ op_ptr_(NULL),
1544
+ op_limit_(NULL),
1545
+ op_limit_min_slop_(NULL) {
1546
+ }
1547
+ char* GetOutputPtr() { return op_ptr_; }
1548
+ void SetOutputPtr(char* op) { op_ptr_ = op; }
1549
+
1550
+ inline void SetExpectedLength(size_t len) {
1551
+ assert(blocks_.empty());
1552
+ expected_ = len;
1553
+ }
1554
+
1555
+ inline bool CheckLength() const {
1556
+ return Size() == expected_;
1557
+ }
1558
+
1559
+ // Return the number of bytes actually uncompressed so far
1560
+ inline size_t Produced() const {
1561
+ return Size();
1562
+ }
1563
+
1564
+ inline bool Append(const char* ip, size_t len, char** op_p) {
1565
+ char* op = *op_p;
1566
+ size_t avail = op_limit_ - op;
1567
+ if (len <= avail) {
1568
+ // Fast path
1569
+ std::memcpy(op, ip, len);
1570
+ *op_p = op + len;
1571
+ return true;
1572
+ } else {
1573
+ op_ptr_ = op;
1574
+ bool res = SlowAppend(ip, len);
1575
+ *op_p = op_ptr_;
1576
+ return res;
1577
+ }
1578
+ }
1579
+
1580
+ inline bool TryFastAppend(const char* ip, size_t available, size_t length,
1581
+ char** op_p) {
1582
+ char* op = *op_p;
1583
+ const int space_left = op_limit_ - op;
1584
+ if (length <= 16 && available >= 16 + kMaximumTagLength &&
1585
+ space_left >= 16) {
1586
+ // Fast path, used for the majority (about 95%) of invocations.
1587
+ UnalignedCopy128(ip, op);
1588
+ *op_p = op + length;
1589
+ return true;
1590
+ } else {
1591
+ return false;
1592
+ }
1593
+ }
1594
+
1595
+ inline bool AppendFromSelf(size_t offset, size_t len, char** op_p) {
1596
+ char* op = *op_p;
1597
+ assert(op >= op_base_);
1598
+ // Check if we try to append from before the start of the buffer.
1599
+ if (SNAPPY_PREDICT_FALSE((kSlopBytes < 64 && len > kSlopBytes) ||
1600
+ static_cast<size_t>(op - op_base_) < offset ||
1601
+ op >= op_limit_min_slop_ || offset < len)) {
1602
+ if (offset == 0) return false;
1603
+ char* const op_end = op + len;
1604
+ if (SNAPPY_PREDICT_FALSE(static_cast<size_t>(op - op_base_) < offset ||
1605
+ op_end > op_limit_)) {
1606
+ op_ptr_ = op;
1607
+ bool res = SlowAppendFromSelf(offset, len);
1608
+ *op_p = op_ptr_;
1609
+ return res;
1610
+ }
1611
+ *op_p = IncrementalCopy(op - offset, op, op_end, op_limit_);
1612
+ return true;
1613
+ }
1614
+ // Fast path
1615
+ char* const op_end = op + len;
1616
+ std::memmove(op, op - offset, kSlopBytes);
1617
+ *op_p = op_end;
1618
+ return true;
1619
+ }
1620
+
1621
+ // Called at the end of the decompress. We ask the allocator
1622
+ // write all blocks to the sink.
1623
+ inline void Flush() { allocator_.Flush(Produced()); }
1624
+ };
1625
+
1626
+ template<typename Allocator>
1627
+ bool SnappyScatteredWriter<Allocator>::SlowAppend(const char* ip, size_t len) {
1628
+ size_t avail = op_limit_ - op_ptr_;
1629
+ while (len > avail) {
1630
+ // Completely fill this block
1631
+ std::memcpy(op_ptr_, ip, avail);
1632
+ op_ptr_ += avail;
1633
+ assert(op_limit_ - op_ptr_ == 0);
1634
+ full_size_ += (op_ptr_ - op_base_);
1635
+ len -= avail;
1636
+ ip += avail;
1637
+
1638
+ // Bounds check
1639
+ if (full_size_ + len > expected_) return false;
1640
+
1641
+ // Make new block
1642
+ size_t bsize = std::min<size_t>(kBlockSize, expected_ - full_size_);
1643
+ op_base_ = allocator_.Allocate(bsize);
1644
+ op_ptr_ = op_base_;
1645
+ op_limit_ = op_base_ + bsize;
1646
+ op_limit_min_slop_ = op_limit_ - std::min<size_t>(kSlopBytes - 1, bsize);
1647
+
1648
+ blocks_.push_back(op_base_);
1649
+ avail = bsize;
1650
+ }
1651
+
1652
+ std::memcpy(op_ptr_, ip, len);
1653
+ op_ptr_ += len;
1654
+ return true;
1655
+ }
1656
+
1657
+ template<typename Allocator>
1658
+ bool SnappyScatteredWriter<Allocator>::SlowAppendFromSelf(size_t offset,
1659
+ size_t len) {
1660
+ // Overflow check
1661
+ // See SnappyArrayWriter::AppendFromSelf for an explanation of
1662
+ // the "offset - 1u" trick.
1663
+ const size_t cur = Size();
1664
+ if (offset - 1u >= cur) return false;
1665
+ if (expected_ - cur < len) return false;
1666
+
1667
+ // Currently we shouldn't ever hit this path because Compress() chops the
1668
+ // input into blocks and does not create cross-block copies. However, it is
1669
+ // nice if we do not rely on that, since we can get better compression if we
1670
+ // allow cross-block copies and thus might want to change the compressor in
1671
+ // the future.
1672
+ // TODO Replace this with a properly optimized path. This is not
1673
+ // triggered right now. But this is so super slow, that it would regress
1674
+ // performance unacceptably if triggered.
1675
+ size_t src = cur - offset;
1676
+ char* op = op_ptr_;
1677
+ while (len-- > 0) {
1678
+ char c = blocks_[src >> kBlockLog][src & (kBlockSize-1)];
1679
+ if (!Append(&c, 1, &op)) {
1680
+ op_ptr_ = op;
1681
+ return false;
1682
+ }
1683
+ src++;
1684
+ }
1685
+ op_ptr_ = op;
1686
+ return true;
1687
+ }
1688
+
1689
+ class SnappySinkAllocator {
1690
+ public:
1691
+ explicit SnappySinkAllocator(Sink* dest): dest_(dest) {}
1692
+ ~SnappySinkAllocator() {}
1693
+
1694
+ char* Allocate(int size) {
1695
+ Datablock block(new char[size], size);
1696
+ blocks_.push_back(block);
1697
+ return block.data;
1698
+ }
1699
+
1700
+ // We flush only at the end, because the writer wants
1701
+ // random access to the blocks and once we hand the
1702
+ // block over to the sink, we can't access it anymore.
1703
+ // Also we don't write more than has been actually written
1704
+ // to the blocks.
1705
+ void Flush(size_t size) {
1706
+ size_t size_written = 0;
1707
+ for (Datablock& block : blocks_) {
1708
+ size_t block_size = std::min<size_t>(block.size, size - size_written);
1709
+ dest_->AppendAndTakeOwnership(block.data, block_size,
1710
+ &SnappySinkAllocator::Deleter, NULL);
1711
+ size_written += block_size;
1712
+ }
1713
+ blocks_.clear();
1714
+ }
1715
+
1716
+ private:
1717
+ struct Datablock {
1718
+ char* data;
1719
+ size_t size;
1720
+ Datablock(char* p, size_t s) : data(p), size(s) {}
1721
+ };
1722
+
1723
+ static void Deleter(void* arg, const char* bytes, size_t size) {
1724
+ // TODO: Switch to [[maybe_unused]] when we can assume C++17.
1725
+ (void)arg;
1726
+ (void)size;
1727
+
1728
+ delete[] bytes;
1729
+ }
1730
+
1731
+ Sink* dest_;
1732
+ std::vector<Datablock> blocks_;
1733
+
1734
+ // Note: copying this object is allowed
1735
+ };
1736
+
1737
+ size_t UncompressAsMuchAsPossible(Source* compressed, Sink* uncompressed) {
1738
+ SnappySinkAllocator allocator(uncompressed);
1739
+ SnappyScatteredWriter<SnappySinkAllocator> writer(allocator);
1740
+ InternalUncompress(compressed, &writer);
1741
+ return writer.Produced();
1742
+ }
1743
+
1744
+ bool Uncompress(Source* compressed, Sink* uncompressed) {
1745
+ // Read the uncompressed length from the front of the compressed input
1746
+ SnappyDecompressor decompressor(compressed);
1747
+ uint32_t uncompressed_len = 0;
1748
+ if (!decompressor.ReadUncompressedLength(&uncompressed_len)) {
1749
+ return false;
1750
+ }
1751
+
1752
+ char c;
1753
+ size_t allocated_size;
1754
+ char* buf = uncompressed->GetAppendBufferVariable(
1755
+ 1, uncompressed_len, &c, 1, &allocated_size);
1756
+
1757
+ const size_t compressed_len = compressed->Available();
1758
+ // If we can get a flat buffer, then use it, otherwise do block by block
1759
+ // uncompression
1760
+ if (allocated_size >= uncompressed_len) {
1761
+ SnappyArrayWriter writer(buf);
1762
+ bool result = InternalUncompressAllTags(&decompressor, &writer,
1763
+ compressed_len, uncompressed_len);
1764
+ uncompressed->Append(buf, writer.Produced());
1765
+ return result;
1766
+ } else {
1767
+ SnappySinkAllocator allocator(uncompressed);
1768
+ SnappyScatteredWriter<SnappySinkAllocator> writer(allocator);
1769
+ return InternalUncompressAllTags(&decompressor, &writer, compressed_len,
1770
+ uncompressed_len);
1771
+ }
1772
+ }
1773
+
1774
+ } // namespace snappy