grpc 0.11.0 → 0.12.0

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of grpc might be problematic. Click here for more details.

Files changed (459) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +29456 -0
  3. data/Rakefile +13 -8
  4. data/etc/roots.pem +5114 -0
  5. data/include/grpc/byte_buffer.h +120 -0
  6. data/include/grpc/byte_buffer_reader.h +58 -0
  7. data/include/grpc/census.h +488 -0
  8. data/include/grpc/compression.h +106 -0
  9. data/include/grpc/grpc.h +732 -0
  10. data/include/grpc/grpc_security.h +374 -0
  11. data/include/grpc/grpc_zookeeper.h +59 -0
  12. data/include/grpc/status.h +163 -0
  13. data/include/grpc/support/alloc.h +72 -0
  14. data/include/grpc/support/atm.h +92 -0
  15. data/include/grpc/support/atm_gcc_atomic.h +72 -0
  16. data/include/grpc/support/atm_gcc_sync.h +87 -0
  17. data/include/grpc/support/atm_win32.h +125 -0
  18. data/include/grpc/support/avl.h +91 -0
  19. data/include/grpc/support/cmdline.h +101 -0
  20. data/include/grpc/support/cpu.h +57 -0
  21. data/include/grpc/support/histogram.h +76 -0
  22. data/include/grpc/support/host_port.h +64 -0
  23. data/include/grpc/support/log.h +108 -0
  24. data/include/grpc/support/log_win32.h +51 -0
  25. data/include/grpc/support/port_platform.h +356 -0
  26. data/include/grpc/support/slice.h +182 -0
  27. data/include/grpc/support/slice_buffer.h +102 -0
  28. data/include/grpc/support/string_util.h +61 -0
  29. data/include/grpc/support/subprocess.h +57 -0
  30. data/include/grpc/support/sync.h +315 -0
  31. data/include/grpc/support/sync_generic.h +55 -0
  32. data/include/grpc/support/sync_posix.h +47 -0
  33. data/include/grpc/support/sync_win32.h +49 -0
  34. data/include/grpc/support/thd.h +91 -0
  35. data/include/grpc/support/time.h +128 -0
  36. data/include/grpc/support/tls.h +77 -0
  37. data/include/grpc/support/tls_gcc.h +56 -0
  38. data/include/grpc/support/tls_msvc.h +56 -0
  39. data/include/grpc/support/tls_pthread.h +60 -0
  40. data/include/grpc/support/useful.h +75 -0
  41. data/src/core/census/aggregation.h +66 -0
  42. data/src/core/census/context.c +46 -0
  43. data/src/core/census/context.h +47 -0
  44. data/src/core/census/grpc_context.c +53 -0
  45. data/src/core/census/grpc_filter.c +184 -0
  46. data/src/core/census/grpc_filter.h +44 -0
  47. data/src/core/census/initialize.c +57 -0
  48. data/src/core/census/operation.c +63 -0
  49. data/src/core/census/rpc_metric_id.h +51 -0
  50. data/src/core/census/tracing.c +45 -0
  51. data/src/core/channel/channel_args.c +209 -0
  52. data/src/core/channel/channel_args.h +88 -0
  53. data/src/core/channel/channel_stack.c +262 -0
  54. data/src/core/channel/channel_stack.h +260 -0
  55. data/src/core/channel/client_channel.c +524 -0
  56. data/src/core/channel/client_channel.h +63 -0
  57. data/src/core/channel/client_uchannel.c +243 -0
  58. data/src/core/channel/client_uchannel.h +60 -0
  59. data/src/core/channel/compress_filter.c +297 -0
  60. data/src/core/channel/compress_filter.h +65 -0
  61. data/src/core/channel/connected_channel.c +167 -0
  62. data/src/core/channel/connected_channel.h +51 -0
  63. data/src/core/channel/context.h +49 -0
  64. data/src/core/channel/http_client_filter.c +248 -0
  65. data/src/core/channel/http_client_filter.h +44 -0
  66. data/src/core/channel/http_server_filter.c +233 -0
  67. data/src/core/channel/http_server_filter.h +42 -0
  68. data/src/core/channel/subchannel_call_holder.c +259 -0
  69. data/src/core/channel/subchannel_call_holder.h +98 -0
  70. data/src/core/client_config/client_config.c +72 -0
  71. data/src/core/client_config/client_config.h +53 -0
  72. data/src/core/client_config/connector.c +54 -0
  73. data/src/core/client_config/connector.h +95 -0
  74. data/src/core/client_config/default_initial_connect_string.c +39 -0
  75. data/src/core/client_config/initial_connect_string.c +53 -0
  76. data/src/core/client_config/initial_connect_string.h +50 -0
  77. data/src/core/client_config/lb_policies/pick_first.c +398 -0
  78. data/src/core/client_config/lb_policies/pick_first.h +43 -0
  79. data/src/core/client_config/lb_policies/round_robin.c +537 -0
  80. data/src/core/client_config/lb_policies/round_robin.h +46 -0
  81. data/src/core/client_config/lb_policy.c +134 -0
  82. data/src/core/client_config/lb_policy.h +143 -0
  83. data/src/core/client_config/lb_policy_factory.c +48 -0
  84. data/src/core/client_config/lb_policy_factory.h +73 -0
  85. data/src/core/client_config/lb_policy_registry.c +88 -0
  86. data/src/core/client_config/lb_policy_registry.h +54 -0
  87. data/src/core/client_config/resolver.c +82 -0
  88. data/src/core/client_config/resolver.h +94 -0
  89. data/src/core/client_config/resolver_factory.c +55 -0
  90. data/src/core/client_config/resolver_factory.h +82 -0
  91. data/src/core/client_config/resolver_registry.c +137 -0
  92. data/src/core/client_config/resolver_registry.h +65 -0
  93. data/src/core/client_config/resolvers/dns_resolver.c +257 -0
  94. data/src/core/client_config/resolvers/dns_resolver.h +42 -0
  95. data/src/core/client_config/resolvers/sockaddr_resolver.c +391 -0
  96. data/src/core/client_config/resolvers/sockaddr_resolver.h +50 -0
  97. data/src/core/client_config/subchannel.c +697 -0
  98. data/src/core/client_config/subchannel.h +165 -0
  99. data/src/core/client_config/subchannel_factory.c +49 -0
  100. data/src/core/client_config/subchannel_factory.h +66 -0
  101. data/src/core/client_config/uri_parser.c +242 -0
  102. data/src/core/client_config/uri_parser.h +51 -0
  103. data/src/core/compression/algorithm.c +166 -0
  104. data/src/core/compression/algorithm_metadata.h +53 -0
  105. data/src/core/compression/message_compress.c +198 -0
  106. data/src/core/compression/message_compress.h +52 -0
  107. data/src/core/debug/trace.c +136 -0
  108. data/src/core/debug/trace.h +43 -0
  109. data/src/core/httpcli/format_request.c +120 -0
  110. data/src/core/httpcli/format_request.h +45 -0
  111. data/src/core/httpcli/httpcli.c +286 -0
  112. data/src/core/httpcli/httpcli.h +162 -0
  113. data/src/core/httpcli/httpcli_security_connector.c +189 -0
  114. data/src/core/httpcli/parser.c +211 -0
  115. data/src/core/httpcli/parser.h +64 -0
  116. data/src/core/iomgr/closure.c +98 -0
  117. data/src/core/iomgr/closure.h +97 -0
  118. data/src/core/iomgr/endpoint.c +67 -0
  119. data/src/core/iomgr/endpoint.h +102 -0
  120. data/src/core/iomgr/endpoint_pair.h +47 -0
  121. data/src/core/iomgr/endpoint_pair_posix.c +82 -0
  122. data/src/core/iomgr/endpoint_pair_windows.c +97 -0
  123. data/src/core/iomgr/exec_ctx.c +72 -0
  124. data/src/core/iomgr/exec_ctx.h +78 -0
  125. data/src/core/iomgr/executor.c +143 -0
  126. data/src/core/iomgr/executor.h +53 -0
  127. data/src/core/iomgr/fd_posix.c +438 -0
  128. data/src/core/iomgr/fd_posix.h +189 -0
  129. data/src/core/iomgr/iocp_windows.c +206 -0
  130. data/src/core/iomgr/iocp_windows.h +56 -0
  131. data/src/core/iomgr/iomgr.c +156 -0
  132. data/src/core/iomgr/iomgr.h +43 -0
  133. data/src/core/iomgr/iomgr_internal.h +58 -0
  134. data/src/core/iomgr/iomgr_posix.c +52 -0
  135. data/src/core/iomgr/iomgr_posix.h +39 -0
  136. data/src/core/iomgr/iomgr_windows.c +73 -0
  137. data/src/core/iomgr/pollset.h +95 -0
  138. data/src/core/iomgr/pollset_multipoller_with_epoll.c +258 -0
  139. data/src/core/iomgr/pollset_multipoller_with_poll_posix.c +227 -0
  140. data/src/core/iomgr/pollset_posix.c +638 -0
  141. data/src/core/iomgr/pollset_posix.h +147 -0
  142. data/src/core/iomgr/pollset_set.h +67 -0
  143. data/src/core/iomgr/pollset_set_posix.c +182 -0
  144. data/src/core/iomgr/pollset_set_posix.h +61 -0
  145. data/src/core/iomgr/pollset_set_windows.c +60 -0
  146. data/src/core/iomgr/pollset_set_windows.h +39 -0
  147. data/src/core/iomgr/pollset_windows.c +248 -0
  148. data/src/core/iomgr/pollset_windows.h +79 -0
  149. data/src/core/iomgr/resolve_address.h +72 -0
  150. data/src/core/iomgr/resolve_address_posix.c +183 -0
  151. data/src/core/iomgr/resolve_address_windows.c +166 -0
  152. data/src/core/iomgr/sockaddr.h +47 -0
  153. data/src/core/iomgr/sockaddr_posix.h +44 -0
  154. data/src/core/iomgr/sockaddr_utils.c +234 -0
  155. data/src/core/iomgr/sockaddr_utils.h +89 -0
  156. data/src/core/iomgr/sockaddr_win32.h +46 -0
  157. data/src/core/iomgr/socket_utils_common_posix.c +208 -0
  158. data/src/core/iomgr/socket_utils_linux.c +51 -0
  159. data/src/core/iomgr/socket_utils_posix.c +70 -0
  160. data/src/core/iomgr/socket_utils_posix.h +113 -0
  161. data/src/core/iomgr/socket_windows.c +98 -0
  162. data/src/core/iomgr/socket_windows.h +111 -0
  163. data/src/core/iomgr/tcp_client.h +53 -0
  164. data/src/core/iomgr/tcp_client_posix.c +304 -0
  165. data/src/core/iomgr/tcp_client_windows.c +221 -0
  166. data/src/core/iomgr/tcp_posix.c +485 -0
  167. data/src/core/iomgr/tcp_posix.h +65 -0
  168. data/src/core/iomgr/tcp_server.h +83 -0
  169. data/src/core/iomgr/tcp_server_posix.c +562 -0
  170. data/src/core/iomgr/tcp_server_windows.c +509 -0
  171. data/src/core/iomgr/tcp_windows.c +406 -0
  172. data/src/core/iomgr/tcp_windows.h +57 -0
  173. data/src/core/iomgr/time_averaged_stats.c +77 -0
  174. data/src/core/iomgr/time_averaged_stats.h +88 -0
  175. data/src/core/iomgr/timer.c +345 -0
  176. data/src/core/iomgr/timer.h +89 -0
  177. data/src/core/iomgr/timer_heap.c +148 -0
  178. data/src/core/iomgr/timer_heap.h +57 -0
  179. data/src/core/iomgr/timer_internal.h +61 -0
  180. data/src/core/iomgr/udp_server.c +439 -0
  181. data/src/core/iomgr/udp_server.h +83 -0
  182. data/src/core/iomgr/wakeup_fd_eventfd.c +85 -0
  183. data/src/core/iomgr/wakeup_fd_nospecial.c +51 -0
  184. data/src/core/iomgr/wakeup_fd_pipe.c +97 -0
  185. data/src/core/iomgr/wakeup_fd_pipe.h +41 -0
  186. data/src/core/iomgr/wakeup_fd_posix.c +72 -0
  187. data/src/core/iomgr/wakeup_fd_posix.h +101 -0
  188. data/src/core/iomgr/workqueue.h +85 -0
  189. data/src/core/iomgr/workqueue_posix.c +143 -0
  190. data/src/core/iomgr/workqueue_posix.h +51 -0
  191. data/src/core/iomgr/workqueue_windows.c +40 -0
  192. data/src/core/iomgr/workqueue_windows.h +37 -0
  193. data/src/core/json/json.c +64 -0
  194. data/src/core/json/json.h +88 -0
  195. data/src/core/json/json_common.h +49 -0
  196. data/src/core/json/json_reader.c +660 -0
  197. data/src/core/json/json_reader.h +160 -0
  198. data/src/core/json/json_string.c +379 -0
  199. data/src/core/json/json_writer.c +260 -0
  200. data/src/core/json/json_writer.h +97 -0
  201. data/src/core/profiling/basic_timers.c +274 -0
  202. data/src/core/profiling/stap_timers.c +65 -0
  203. data/src/core/profiling/timers.h +119 -0
  204. data/src/core/security/auth_filters.h +42 -0
  205. data/src/core/security/base64.c +233 -0
  206. data/src/core/security/base64.h +52 -0
  207. data/src/core/security/client_auth_filter.c +337 -0
  208. data/src/core/security/credentials.c +1273 -0
  209. data/src/core/security/credentials.h +376 -0
  210. data/src/core/security/credentials_metadata.c +101 -0
  211. data/src/core/security/credentials_posix.c +61 -0
  212. data/src/core/security/credentials_win32.c +61 -0
  213. data/src/core/security/google_default_credentials.c +260 -0
  214. data/src/core/security/handshake.c +327 -0
  215. data/src/core/security/handshake.h +50 -0
  216. data/src/core/security/json_token.c +405 -0
  217. data/src/core/security/json_token.h +118 -0
  218. data/src/core/security/jwt_verifier.c +842 -0
  219. data/src/core/security/jwt_verifier.h +136 -0
  220. data/src/core/security/secure_endpoint.c +383 -0
  221. data/src/core/security/secure_endpoint.h +49 -0
  222. data/src/core/security/security_connector.c +756 -0
  223. data/src/core/security/security_connector.h +246 -0
  224. data/src/core/security/security_context.c +342 -0
  225. data/src/core/security/security_context.h +114 -0
  226. data/src/core/security/server_auth_filter.c +264 -0
  227. data/src/core/security/server_secure_chttp2.c +268 -0
  228. data/src/core/statistics/census_interface.h +76 -0
  229. data/src/core/statistics/census_rpc_stats.h +101 -0
  230. data/src/core/support/alloc.c +90 -0
  231. data/src/core/support/avl.c +288 -0
  232. data/src/core/support/block_annotate.h +48 -0
  233. data/src/core/support/cmdline.c +347 -0
  234. data/src/core/support/cpu_iphone.c +49 -0
  235. data/src/core/support/cpu_linux.c +78 -0
  236. data/src/core/support/cpu_posix.c +77 -0
  237. data/src/core/support/cpu_windows.c +47 -0
  238. data/src/core/support/env.h +60 -0
  239. data/src/core/support/env_linux.c +62 -0
  240. data/src/core/support/env_posix.c +57 -0
  241. data/src/core/support/env_win32.c +65 -0
  242. data/src/core/support/file.c +91 -0
  243. data/src/core/support/file.h +63 -0
  244. data/src/core/support/file_posix.c +85 -0
  245. data/src/core/support/file_win32.c +84 -0
  246. data/src/core/support/histogram.c +244 -0
  247. data/src/core/support/host_port.c +110 -0
  248. data/src/core/support/log.c +66 -0
  249. data/src/core/support/log_android.c +87 -0
  250. data/src/core/support/log_linux.c +105 -0
  251. data/src/core/support/log_posix.c +102 -0
  252. data/src/core/support/log_win32.c +125 -0
  253. data/src/core/support/murmur_hash.c +96 -0
  254. data/src/core/support/murmur_hash.h +44 -0
  255. data/src/core/support/slice.c +343 -0
  256. data/src/core/support/slice_buffer.c +282 -0
  257. data/src/core/support/stack_lockfree.c +175 -0
  258. data/src/core/support/stack_lockfree.h +53 -0
  259. data/src/core/support/string.c +296 -0
  260. data/src/core/support/string.h +121 -0
  261. data/src/core/support/string_posix.c +86 -0
  262. data/src/core/support/string_win32.c +109 -0
  263. data/src/core/support/string_win32.h +47 -0
  264. data/src/core/support/subprocess_posix.c +112 -0
  265. data/src/core/support/sync.c +122 -0
  266. data/src/core/support/sync_posix.c +104 -0
  267. data/src/core/support/sync_win32.c +128 -0
  268. data/src/core/support/thd.c +64 -0
  269. data/src/core/support/thd_internal.h +39 -0
  270. data/src/core/support/thd_posix.c +94 -0
  271. data/src/core/support/thd_win32.c +117 -0
  272. data/src/core/support/time.c +304 -0
  273. data/src/core/support/time_posix.c +161 -0
  274. data/src/core/support/time_precise.c +89 -0
  275. data/src/core/support/time_precise.h +42 -0
  276. data/src/core/support/time_win32.c +101 -0
  277. data/src/core/support/tls_pthread.c +45 -0
  278. data/src/core/surface/api_trace.c +36 -0
  279. data/src/core/surface/api_trace.h +65 -0
  280. data/src/core/surface/byte_buffer.c +97 -0
  281. data/src/core/surface/byte_buffer_reader.c +123 -0
  282. data/src/core/surface/call.c +1424 -0
  283. data/src/core/surface/call.h +109 -0
  284. data/src/core/surface/call_details.c +50 -0
  285. data/src/core/surface/call_log_batch.c +118 -0
  286. data/src/core/surface/call_test_only.h +64 -0
  287. data/src/core/surface/channel.c +327 -0
  288. data/src/core/surface/channel.h +74 -0
  289. data/src/core/surface/channel_connectivity.c +220 -0
  290. data/src/core/surface/channel_create.c +235 -0
  291. data/src/core/surface/channel_ping.c +79 -0
  292. data/src/core/surface/completion_queue.c +481 -0
  293. data/src/core/surface/completion_queue.h +91 -0
  294. data/src/core/surface/event_string.c +81 -0
  295. data/src/core/surface/event_string.h +42 -0
  296. data/src/core/surface/init.c +168 -0
  297. data/src/core/surface/init.h +40 -0
  298. data/src/core/surface/init_secure.c +42 -0
  299. data/src/core/surface/lame_client.c +149 -0
  300. data/src/core/surface/metadata_array.c +49 -0
  301. data/src/core/surface/secure_channel_create.c +336 -0
  302. data/src/core/surface/server.c +1343 -0
  303. data/src/core/surface/server.h +67 -0
  304. data/src/core/surface/server_chttp2.c +149 -0
  305. data/src/core/surface/server_create.c +51 -0
  306. data/src/core/surface/surface_trace.h +48 -0
  307. data/src/core/surface/validate_metadata.c +73 -0
  308. data/src/core/surface/version.c +39 -0
  309. data/src/core/transport/byte_stream.c +76 -0
  310. data/src/core/transport/byte_stream.h +88 -0
  311. data/src/core/transport/chttp2/alpn.c +56 -0
  312. data/src/core/transport/chttp2/alpn.h +49 -0
  313. data/src/core/transport/chttp2/bin_encoder.c +285 -0
  314. data/src/core/transport/chttp2/bin_encoder.h +54 -0
  315. data/src/core/transport/chttp2/frame.h +69 -0
  316. data/src/core/transport/chttp2/frame_data.c +245 -0
  317. data/src/core/transport/chttp2/frame_data.h +101 -0
  318. data/src/core/transport/chttp2/frame_goaway.c +193 -0
  319. data/src/core/transport/chttp2/frame_goaway.h +77 -0
  320. data/src/core/transport/chttp2/frame_ping.c +97 -0
  321. data/src/core/transport/chttp2/frame_ping.h +56 -0
  322. data/src/core/transport/chttp2/frame_rst_stream.c +100 -0
  323. data/src/core/transport/chttp2/frame_rst_stream.h +55 -0
  324. data/src/core/transport/chttp2/frame_settings.c +259 -0
  325. data/src/core/transport/chttp2/frame_settings.h +103 -0
  326. data/src/core/transport/chttp2/frame_window_update.c +114 -0
  327. data/src/core/transport/chttp2/frame_window_update.h +58 -0
  328. data/src/core/transport/chttp2/hpack_encoder.c +572 -0
  329. data/src/core/transport/chttp2/hpack_encoder.h +95 -0
  330. data/src/core/transport/chttp2/hpack_parser.c +1449 -0
  331. data/src/core/transport/chttp2/hpack_parser.h +116 -0
  332. data/src/core/transport/chttp2/hpack_table.c +361 -0
  333. data/src/core/transport/chttp2/hpack_table.h +108 -0
  334. data/src/core/transport/chttp2/http2_errors.h +56 -0
  335. data/src/core/transport/chttp2/huffsyms.c +297 -0
  336. data/src/core/transport/chttp2/huffsyms.h +48 -0
  337. data/src/core/transport/chttp2/incoming_metadata.c +96 -0
  338. data/src/core/transport/chttp2/incoming_metadata.h +60 -0
  339. data/src/core/transport/chttp2/internal.h +757 -0
  340. data/src/core/transport/chttp2/parsing.c +866 -0
  341. data/src/core/transport/chttp2/status_conversion.c +109 -0
  342. data/src/core/transport/chttp2/status_conversion.h +50 -0
  343. data/src/core/transport/chttp2/stream_lists.c +401 -0
  344. data/src/core/transport/chttp2/stream_map.c +198 -0
  345. data/src/core/transport/chttp2/stream_map.h +85 -0
  346. data/src/core/transport/chttp2/timeout_encoding.c +185 -0
  347. data/src/core/transport/chttp2/timeout_encoding.h +47 -0
  348. data/src/core/transport/chttp2/varint.c +66 -0
  349. data/src/core/transport/chttp2/varint.h +76 -0
  350. data/src/core/transport/chttp2/writing.c +356 -0
  351. data/src/core/transport/chttp2_transport.c +1692 -0
  352. data/src/core/transport/chttp2_transport.h +51 -0
  353. data/src/core/transport/connectivity_state.c +164 -0
  354. data/src/core/transport/connectivity_state.h +85 -0
  355. data/src/core/transport/metadata.c +690 -0
  356. data/src/core/transport/metadata.h +156 -0
  357. data/src/core/transport/metadata_batch.c +194 -0
  358. data/src/core/transport/metadata_batch.h +125 -0
  359. data/src/core/transport/static_metadata.c +90 -0
  360. data/src/core/transport/static_metadata.h +408 -0
  361. data/src/core/transport/transport.c +183 -0
  362. data/src/core/transport/transport.h +222 -0
  363. data/src/core/transport/transport_impl.h +78 -0
  364. data/src/core/transport/transport_op_string.c +140 -0
  365. data/src/core/tsi/fake_transport_security.c +525 -0
  366. data/src/core/tsi/fake_transport_security.h +61 -0
  367. data/src/core/tsi/ssl_transport_security.c +1467 -0
  368. data/src/core/tsi/ssl_transport_security.h +173 -0
  369. data/src/core/tsi/transport_security.c +284 -0
  370. data/src/core/tsi/transport_security.h +111 -0
  371. data/src/core/tsi/transport_security_interface.h +344 -0
  372. data/{bin → src/ruby/bin}/apis/google/protobuf/empty.rb +0 -0
  373. data/{bin → src/ruby/bin}/apis/pubsub_demo.rb +7 -15
  374. data/{bin → src/ruby/bin}/apis/tech/pubsub/proto/pubsub.rb +0 -0
  375. data/{bin → src/ruby/bin}/apis/tech/pubsub/proto/pubsub_services.rb +0 -0
  376. data/{bin → src/ruby/bin}/grpc_ruby_interop_client +0 -0
  377. data/{bin → src/ruby/bin}/grpc_ruby_interop_server +0 -0
  378. data/{bin → src/ruby/bin}/interop/interop_client.rb +0 -0
  379. data/{bin → src/ruby/bin}/interop/interop_server.rb +0 -0
  380. data/src/ruby/bin/math.rb +32 -0
  381. data/{bin → src/ruby/bin}/math_client.rb +1 -1
  382. data/{bin → src/ruby/bin}/math_server.rb +1 -1
  383. data/src/ruby/bin/math_services.rb +27 -0
  384. data/{bin → src/ruby/bin}/noproto_client.rb +1 -1
  385. data/{bin → src/ruby/bin}/noproto_server.rb +1 -1
  386. data/{ext → src/ruby/ext}/grpc/extconf.rb +24 -40
  387. data/{ext → src/ruby/ext}/grpc/rb_byte_buffer.c +0 -0
  388. data/{ext → src/ruby/ext}/grpc/rb_byte_buffer.h +0 -0
  389. data/{ext → src/ruby/ext}/grpc/rb_call.c +80 -18
  390. data/{ext → src/ruby/ext}/grpc/rb_call.h +6 -0
  391. data/src/ruby/ext/grpc/rb_call_credentials.c +315 -0
  392. data/src/ruby/ext/grpc/rb_call_credentials.h +46 -0
  393. data/{ext → src/ruby/ext}/grpc/rb_channel.c +19 -7
  394. data/{ext → src/ruby/ext}/grpc/rb_channel.h +0 -0
  395. data/{ext → src/ruby/ext}/grpc/rb_channel_args.c +2 -0
  396. data/{ext → src/ruby/ext}/grpc/rb_channel_args.h +0 -0
  397. data/src/ruby/ext/grpc/rb_channel_credentials.c +266 -0
  398. data/{ext/grpc/rb_credentials.h → src/ruby/ext/grpc/rb_channel_credentials.h} +3 -3
  399. data/{ext → src/ruby/ext}/grpc/rb_completion_queue.c +3 -1
  400. data/{ext → src/ruby/ext}/grpc/rb_completion_queue.h +0 -0
  401. data/src/ruby/ext/grpc/rb_event_thread.c +153 -0
  402. data/src/ruby/ext/grpc/rb_event_thread.h +37 -0
  403. data/{ext → src/ruby/ext}/grpc/rb_grpc.c +25 -5
  404. data/{ext → src/ruby/ext}/grpc/rb_grpc.h +0 -0
  405. data/{ext → src/ruby/ext}/grpc/rb_server.c +4 -1
  406. data/{ext → src/ruby/ext}/grpc/rb_server.h +0 -0
  407. data/{ext → src/ruby/ext}/grpc/rb_server_credentials.c +2 -0
  408. data/{ext → src/ruby/ext}/grpc/rb_server_credentials.h +0 -0
  409. data/{lib → src/ruby/lib}/grpc.rb +6 -1
  410. data/{lib → src/ruby/lib}/grpc/core/time_consts.rb +0 -0
  411. data/{lib → src/ruby/lib}/grpc/errors.rb +0 -0
  412. data/{lib → src/ruby/lib}/grpc/generic/active_call.rb +4 -6
  413. data/{lib → src/ruby/lib}/grpc/generic/bidi_call.rb +16 -4
  414. data/{lib → src/ruby/lib}/grpc/generic/client_stub.rb +42 -52
  415. data/{lib → src/ruby/lib}/grpc/generic/rpc_desc.rb +0 -0
  416. data/{lib → src/ruby/lib}/grpc/generic/rpc_server.rb +15 -8
  417. data/{lib → src/ruby/lib}/grpc/generic/service.rb +4 -2
  418. data/src/ruby/lib/grpc/grpc.so +0 -0
  419. data/{lib → src/ruby/lib}/grpc/logconfig.rb +0 -0
  420. data/{lib → src/ruby/lib}/grpc/notifier.rb +0 -0
  421. data/{lib → src/ruby/lib}/grpc/version.rb +2 -2
  422. data/src/ruby/pb/README.md +42 -0
  423. data/src/ruby/pb/generate_proto_ruby.sh +51 -0
  424. data/src/ruby/pb/grpc/health/checker.rb +75 -0
  425. data/src/ruby/pb/grpc/health/v1alpha/health.rb +29 -0
  426. data/src/ruby/pb/grpc/health/v1alpha/health_services.rb +28 -0
  427. data/src/ruby/pb/test/client.rb +469 -0
  428. data/src/ruby/pb/test/proto/empty.rb +15 -0
  429. data/src/ruby/pb/test/proto/messages.rb +80 -0
  430. data/src/ruby/pb/test/proto/test.rb +14 -0
  431. data/src/ruby/pb/test/proto/test_services.rb +64 -0
  432. data/src/ruby/pb/test/server.rb +253 -0
  433. data/{bin/math_services.rb → src/ruby/spec/call_credentials_spec.rb} +19 -18
  434. data/{spec → src/ruby/spec}/call_spec.rb +10 -1
  435. data/{spec/credentials_spec.rb → src/ruby/spec/channel_credentials_spec.rb} +38 -12
  436. data/{spec → src/ruby/spec}/channel_spec.rb +14 -9
  437. data/{spec → src/ruby/spec}/client_server_spec.rb +31 -2
  438. data/{spec → src/ruby/spec}/completion_queue_spec.rb +0 -0
  439. data/{spec → src/ruby/spec}/generic/active_call_spec.rb +2 -1
  440. data/{spec → src/ruby/spec}/generic/client_stub_spec.rb +27 -67
  441. data/{spec → src/ruby/spec}/generic/rpc_desc_spec.rb +0 -0
  442. data/{spec → src/ruby/spec}/generic/rpc_server_pool_spec.rb +0 -0
  443. data/{spec → src/ruby/spec}/generic/rpc_server_spec.rb +12 -46
  444. data/{spec → src/ruby/spec}/generic/service_spec.rb +6 -3
  445. data/{spec → src/ruby/spec}/pb/health/checker_spec.rb +8 -8
  446. data/{spec → src/ruby/spec}/server_credentials_spec.rb +0 -0
  447. data/{spec → src/ruby/spec}/server_spec.rb +0 -0
  448. data/{spec → src/ruby/spec}/spec_helper.rb +0 -0
  449. data/{spec → src/ruby/spec}/testdata/README +0 -0
  450. data/{spec → src/ruby/spec}/testdata/ca.pem +0 -0
  451. data/{spec → src/ruby/spec}/testdata/server1.key +0 -0
  452. data/src/ruby/spec/testdata/server1.pem +16 -0
  453. data/{spec → src/ruby/spec}/time_consts_spec.rb +0 -0
  454. metadata +496 -97
  455. data/bin/math.proto +0 -80
  456. data/bin/math.rb +0 -61
  457. data/ext/grpc/rb_credentials.c +0 -294
  458. data/lib/grpc/grpc.so +0 -0
  459. data/spec/testdata/server1.pem +0 -16
@@ -0,0 +1,260 @@
1
+ /*
2
+ *
3
+ * Copyright 2015, Google Inc.
4
+ * All rights reserved.
5
+ *
6
+ * Redistribution and use in source and binary forms, with or without
7
+ * modification, are permitted provided that the following conditions are
8
+ * met:
9
+ *
10
+ * * Redistributions of source code must retain the above copyright
11
+ * notice, this list of conditions and the following disclaimer.
12
+ * * Redistributions in binary form must reproduce the above
13
+ * copyright notice, this list of conditions and the following disclaimer
14
+ * in the documentation and/or other materials provided with the
15
+ * distribution.
16
+ * * Neither the name of Google Inc. nor the names of its
17
+ * contributors may be used to endorse or promote products derived from
18
+ * this software without specific prior written permission.
19
+ *
20
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31
+ *
32
+ */
33
+
34
+ #include <string.h>
35
+
36
+ #include <grpc/support/port_platform.h>
37
+
38
+ #include "src/core/json/json_writer.h"
39
+
40
+ static void json_writer_output_char(grpc_json_writer *writer, char c) {
41
+ writer->vtable->output_char(writer->userdata, c);
42
+ }
43
+
44
+ static void json_writer_output_string(grpc_json_writer *writer,
45
+ const char *str) {
46
+ writer->vtable->output_string(writer->userdata, str);
47
+ }
48
+
49
+ static void json_writer_output_string_with_len(grpc_json_writer *writer,
50
+ const char *str, size_t len) {
51
+ writer->vtable->output_string_with_len(writer->userdata, str, len);
52
+ }
53
+
54
+ void grpc_json_writer_init(grpc_json_writer *writer, int indent,
55
+ grpc_json_writer_vtable *vtable, void *userdata) {
56
+ memset(writer, 0, sizeof(*writer));
57
+ writer->container_empty = 1;
58
+ writer->indent = indent;
59
+ writer->vtable = vtable;
60
+ writer->userdata = userdata;
61
+ }
62
+
63
+ static void json_writer_output_indent(grpc_json_writer *writer) {
64
+ static const char spacesstr[] =
65
+ " "
66
+ " "
67
+ " "
68
+ " ";
69
+
70
+ unsigned spaces = (unsigned)(writer->depth * writer->indent);
71
+
72
+ if (writer->indent == 0) return;
73
+
74
+ if (writer->got_key) {
75
+ json_writer_output_char(writer, ' ');
76
+ return;
77
+ }
78
+
79
+ while (spaces >= (sizeof(spacesstr) - 1)) {
80
+ json_writer_output_string_with_len(writer, spacesstr,
81
+ sizeof(spacesstr) - 1);
82
+ spaces -= (unsigned)(sizeof(spacesstr) - 1);
83
+ }
84
+
85
+ if (spaces == 0) return;
86
+
87
+ json_writer_output_string_with_len(
88
+ writer, spacesstr + sizeof(spacesstr) - 1 - spaces, spaces);
89
+ }
90
+
91
+ static void json_writer_value_end(grpc_json_writer *writer) {
92
+ if (writer->container_empty) {
93
+ writer->container_empty = 0;
94
+ if ((writer->indent == 0) || (writer->depth == 0)) return;
95
+ json_writer_output_char(writer, '\n');
96
+ } else {
97
+ json_writer_output_char(writer, ',');
98
+ if (writer->indent == 0) return;
99
+ json_writer_output_char(writer, '\n');
100
+ }
101
+ }
102
+
103
+ static void json_writer_escape_utf16(grpc_json_writer *writer,
104
+ gpr_uint16 utf16) {
105
+ static const char hex[] = "0123456789abcdef";
106
+
107
+ json_writer_output_string_with_len(writer, "\\u", 2);
108
+ json_writer_output_char(writer, hex[(utf16 >> 12) & 0x0f]);
109
+ json_writer_output_char(writer, hex[(utf16 >> 8) & 0x0f]);
110
+ json_writer_output_char(writer, hex[(utf16 >> 4) & 0x0f]);
111
+ json_writer_output_char(writer, hex[(utf16)&0x0f]);
112
+ }
113
+
114
+ static void json_writer_escape_string(grpc_json_writer *writer,
115
+ const char *string) {
116
+ json_writer_output_char(writer, '"');
117
+
118
+ for (;;) {
119
+ gpr_uint8 c = (gpr_uint8)*string++;
120
+ if (c == 0) {
121
+ break;
122
+ } else if ((c >= 32) && (c <= 126)) {
123
+ if ((c == '\\') || (c == '"')) json_writer_output_char(writer, '\\');
124
+ json_writer_output_char(writer, (char)c);
125
+ } else if ((c < 32) || (c == 127)) {
126
+ switch (c) {
127
+ case '\b':
128
+ json_writer_output_string_with_len(writer, "\\b", 2);
129
+ break;
130
+ case '\f':
131
+ json_writer_output_string_with_len(writer, "\\f", 2);
132
+ break;
133
+ case '\n':
134
+ json_writer_output_string_with_len(writer, "\\n", 2);
135
+ break;
136
+ case '\r':
137
+ json_writer_output_string_with_len(writer, "\\r", 2);
138
+ break;
139
+ case '\t':
140
+ json_writer_output_string_with_len(writer, "\\t", 2);
141
+ break;
142
+ default:
143
+ json_writer_escape_utf16(writer, c);
144
+ break;
145
+ }
146
+ } else {
147
+ gpr_uint32 utf32 = 0;
148
+ int extra = 0;
149
+ int i;
150
+ int valid = 1;
151
+ if ((c & 0xe0) == 0xc0) {
152
+ utf32 = c & 0x1f;
153
+ extra = 1;
154
+ } else if ((c & 0xf0) == 0xe0) {
155
+ utf32 = c & 0x0f;
156
+ extra = 2;
157
+ } else if ((c & 0xf8) == 0xf0) {
158
+ utf32 = c & 0x07;
159
+ extra = 3;
160
+ } else {
161
+ break;
162
+ }
163
+ for (i = 0; i < extra; i++) {
164
+ utf32 <<= 6;
165
+ c = (gpr_uint8)(*string++);
166
+ /* Breaks out and bail on any invalid UTF-8 sequence, including \0. */
167
+ if ((c & 0xc0) != 0x80) {
168
+ valid = 0;
169
+ break;
170
+ }
171
+ utf32 |= c & 0x3f;
172
+ }
173
+ if (!valid) break;
174
+ /* The range 0xd800 - 0xdfff is reserved by the surrogates ad vitam.
175
+ * Any other range is technically reserved for future usage, so if we
176
+ * don't want the software to break in the future, we have to allow
177
+ * anything else. The first non-unicode character is 0x110000. */
178
+ if (((utf32 >= 0xd800) && (utf32 <= 0xdfff)) || (utf32 >= 0x110000))
179
+ break;
180
+ if (utf32 >= 0x10000) {
181
+ /* If utf32 contains a character that is above 0xffff, it needs to be
182
+ * broken down into a utf-16 surrogate pair. A surrogate pair is first
183
+ * a high surrogate, followed by a low surrogate. Each surrogate holds
184
+ * 10 bits of usable data, thus allowing a total of 20 bits of data.
185
+ * The high surrogate marker is 0xd800, while the low surrogate marker
186
+ * is 0xdc00. The low 10 bits of each will be the usable data.
187
+ *
188
+ * After re-combining the 20 bits of data, one has to add 0x10000 to
189
+ * the resulting value, in order to obtain the original character.
190
+ * This is obviously because the range 0x0000 - 0xffff can be written
191
+ * without any special trick.
192
+ *
193
+ * Since 0x10ffff is the highest allowed character, we're working in
194
+ * the range 0x00000 - 0xfffff after we decrement it by 0x10000.
195
+ * That range is exactly 20 bits.
196
+ */
197
+ utf32 -= 0x10000;
198
+ json_writer_escape_utf16(writer, (gpr_uint16)(0xd800 | (utf32 >> 10)));
199
+ json_writer_escape_utf16(writer,
200
+ (gpr_uint16)(0xdc00 | (utf32 & 0x3ff)));
201
+ } else {
202
+ json_writer_escape_utf16(writer, (gpr_uint16)utf32);
203
+ }
204
+ }
205
+ }
206
+
207
+ json_writer_output_char(writer, '"');
208
+ }
209
+
210
+ void grpc_json_writer_container_begins(grpc_json_writer *writer,
211
+ grpc_json_type type) {
212
+ if (!writer->got_key) json_writer_value_end(writer);
213
+ json_writer_output_indent(writer);
214
+ json_writer_output_char(writer, type == GRPC_JSON_OBJECT ? '{' : '[');
215
+ writer->container_empty = 1;
216
+ writer->got_key = 0;
217
+ writer->depth++;
218
+ }
219
+
220
+ void grpc_json_writer_container_ends(grpc_json_writer *writer,
221
+ grpc_json_type type) {
222
+ if (writer->indent && !writer->container_empty)
223
+ json_writer_output_char(writer, '\n');
224
+ writer->depth--;
225
+ if (!writer->container_empty) json_writer_output_indent(writer);
226
+ json_writer_output_char(writer, type == GRPC_JSON_OBJECT ? '}' : ']');
227
+ writer->container_empty = 0;
228
+ writer->got_key = 0;
229
+ }
230
+
231
+ void grpc_json_writer_object_key(grpc_json_writer *writer, const char *string) {
232
+ json_writer_value_end(writer);
233
+ json_writer_output_indent(writer);
234
+ json_writer_escape_string(writer, string);
235
+ json_writer_output_char(writer, ':');
236
+ writer->got_key = 1;
237
+ }
238
+
239
+ void grpc_json_writer_value_raw(grpc_json_writer *writer, const char *string) {
240
+ if (!writer->got_key) json_writer_value_end(writer);
241
+ json_writer_output_indent(writer);
242
+ json_writer_output_string(writer, string);
243
+ writer->got_key = 0;
244
+ }
245
+
246
+ void grpc_json_writer_value_raw_with_len(grpc_json_writer *writer,
247
+ const char *string, size_t len) {
248
+ if (!writer->got_key) json_writer_value_end(writer);
249
+ json_writer_output_indent(writer);
250
+ json_writer_output_string_with_len(writer, string, len);
251
+ writer->got_key = 0;
252
+ }
253
+
254
+ void grpc_json_writer_value_string(grpc_json_writer *writer,
255
+ const char *string) {
256
+ if (!writer->got_key) json_writer_value_end(writer);
257
+ json_writer_output_indent(writer);
258
+ json_writer_escape_string(writer, string);
259
+ writer->got_key = 0;
260
+ }
@@ -0,0 +1,97 @@
1
+ /*
2
+ *
3
+ * Copyright 2015, Google Inc.
4
+ * All rights reserved.
5
+ *
6
+ * Redistribution and use in source and binary forms, with or without
7
+ * modification, are permitted provided that the following conditions are
8
+ * met:
9
+ *
10
+ * * Redistributions of source code must retain the above copyright
11
+ * notice, this list of conditions and the following disclaimer.
12
+ * * Redistributions in binary form must reproduce the above
13
+ * copyright notice, this list of conditions and the following disclaimer
14
+ * in the documentation and/or other materials provided with the
15
+ * distribution.
16
+ * * Neither the name of Google Inc. nor the names of its
17
+ * contributors may be used to endorse or promote products derived from
18
+ * this software without specific prior written permission.
19
+ *
20
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31
+ *
32
+ */
33
+
34
+ /* The idea of the writer is basically symmetrical of the reader. While the
35
+ * reader emits various calls to your code, the writer takes basically the
36
+ * same calls and emit json out of it. It doesn't try to make any check on
37
+ * the order of the calls you do on it. Meaning you can theorically force
38
+ * it to generate invalid json.
39
+ *
40
+ * Also, unlike the reader, the writer expects UTF-8 encoded input strings.
41
+ * These strings will be UTF-8 validated, and any invalid character will
42
+ * cut the conversion short, before any invalid UTF-8 sequence, thus forming
43
+ * a valid UTF-8 string overall.
44
+ */
45
+
46
+ #ifndef GRPC_INTERNAL_CORE_JSON_JSON_WRITER_H
47
+ #define GRPC_INTERNAL_CORE_JSON_JSON_WRITER_H
48
+
49
+ #include <stdlib.h>
50
+
51
+ #include "src/core/json/json_common.h"
52
+
53
+ typedef struct grpc_json_writer_vtable {
54
+ /* Adds a character to the output stream. */
55
+ void (*output_char)(void *userdata, char);
56
+ /* Adds a zero-terminated string to the output stream. */
57
+ void (*output_string)(void *userdata, const char *str);
58
+ /* Adds a fixed-length string to the output stream. */
59
+ void (*output_string_with_len)(void *userdata, const char *str, size_t len);
60
+
61
+ } grpc_json_writer_vtable;
62
+
63
+ typedef struct grpc_json_writer {
64
+ void *userdata;
65
+ grpc_json_writer_vtable *vtable;
66
+ int indent;
67
+ int depth;
68
+ int container_empty;
69
+ int got_key;
70
+ } grpc_json_writer;
71
+
72
+ /* Call this to initialize your writer structure. The indent parameter is
73
+ * specifying the number of spaces to use for indenting the output. If you
74
+ * use indent=0, then the output will not have any newlines either, thus
75
+ * emitting a condensed json output.
76
+ */
77
+ void grpc_json_writer_init(grpc_json_writer *writer, int indent,
78
+ grpc_json_writer_vtable *vtable, void *userdata);
79
+
80
+ /* Signals the beginning of a container. */
81
+ void grpc_json_writer_container_begins(grpc_json_writer *writer,
82
+ grpc_json_type type);
83
+ /* Signals the end of a container. */
84
+ void grpc_json_writer_container_ends(grpc_json_writer *writer,
85
+ grpc_json_type type);
86
+ /* Writes down an object key for the next value. */
87
+ void grpc_json_writer_object_key(grpc_json_writer *writer, const char *string);
88
+ /* Sets a raw value. Useful for numbers. */
89
+ void grpc_json_writer_value_raw(grpc_json_writer *writer, const char *string);
90
+ /* Sets a raw value with its length. Useful for values like true or false. */
91
+ void grpc_json_writer_value_raw_with_len(grpc_json_writer *writer,
92
+ const char *string, size_t len);
93
+ /* Sets a string value. It'll be escaped, and utf-8 validated. */
94
+ void grpc_json_writer_value_string(grpc_json_writer *writer,
95
+ const char *string);
96
+
97
+ #endif /* GRPC_INTERNAL_CORE_JSON_JSON_WRITER_H */
@@ -0,0 +1,274 @@
1
+ /*
2
+ *
3
+ * Copyright 2015, Google Inc.
4
+ * All rights reserved.
5
+ *
6
+ * Redistribution and use in source and binary forms, with or without
7
+ * modification, are permitted provided that the following conditions are
8
+ * met:
9
+ *
10
+ * * Redistributions of source code must retain the above copyright
11
+ * notice, this list of conditions and the following disclaimer.
12
+ * * Redistributions in binary form must reproduce the above
13
+ * copyright notice, this list of conditions and the following disclaimer
14
+ * in the documentation and/or other materials provided with the
15
+ * distribution.
16
+ * * Neither the name of Google Inc. nor the names of its
17
+ * contributors may be used to endorse or promote products derived from
18
+ * this software without specific prior written permission.
19
+ *
20
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31
+ *
32
+ */
33
+
34
+ #include <grpc/support/port_platform.h>
35
+
36
+ #ifdef GRPC_BASIC_PROFILER
37
+
38
+ #include "src/core/profiling/timers.h"
39
+
40
+ #include <grpc/support/alloc.h>
41
+ #include <grpc/support/log.h>
42
+ #include <grpc/support/time.h>
43
+ #include <grpc/support/sync.h>
44
+ #include <grpc/support/thd.h>
45
+ #include <stdio.h>
46
+
47
+ typedef enum { BEGIN = '{', END = '}', MARK = '.' } marker_type;
48
+
49
+ typedef struct gpr_timer_entry {
50
+ gpr_timespec tm;
51
+ const char *tagstr;
52
+ const char *file;
53
+ short line;
54
+ char type;
55
+ gpr_uint8 important;
56
+ int thd;
57
+ } gpr_timer_entry;
58
+
59
+ #define MAX_COUNT 1000000
60
+
61
+ typedef struct gpr_timer_log {
62
+ size_t num_entries;
63
+ struct gpr_timer_log *next;
64
+ struct gpr_timer_log *prev;
65
+ gpr_timer_entry log[MAX_COUNT];
66
+ } gpr_timer_log;
67
+
68
+ typedef struct gpr_timer_log_list {
69
+ gpr_timer_log *head;
70
+ /* valid iff head!=NULL */
71
+ gpr_timer_log *tail;
72
+ } gpr_timer_log_list;
73
+
74
+ static __thread gpr_timer_log *g_thread_log;
75
+ static gpr_once g_once_init = GPR_ONCE_INIT;
76
+ static FILE *output_file;
77
+ static const char *output_filename = "latency_trace.txt";
78
+ static pthread_mutex_t g_mu;
79
+ static pthread_cond_t g_cv;
80
+ static gpr_timer_log_list g_in_progress_logs;
81
+ static gpr_timer_log_list g_done_logs;
82
+ static int g_shutdown;
83
+ static gpr_thd_id g_writing_thread;
84
+ static __thread int g_thread_id;
85
+ static int g_next_thread_id;
86
+
87
+ static int timer_log_push_back(gpr_timer_log_list *list, gpr_timer_log *log) {
88
+ if (list->head == NULL) {
89
+ list->head = list->tail = log;
90
+ log->next = log->prev = NULL;
91
+ return 1;
92
+ } else {
93
+ log->prev = list->tail;
94
+ log->next = NULL;
95
+ list->tail->next = log;
96
+ list->tail = log;
97
+ return 0;
98
+ }
99
+ }
100
+
101
+ static gpr_timer_log *timer_log_pop_front(gpr_timer_log_list *list) {
102
+ gpr_timer_log *out = list->head;
103
+ if (out != NULL) {
104
+ list->head = out->next;
105
+ if (list->head != NULL) {
106
+ list->head->prev = NULL;
107
+ } else {
108
+ list->tail = NULL;
109
+ }
110
+ }
111
+ return out;
112
+ }
113
+
114
+ static void timer_log_remove(gpr_timer_log_list *list, gpr_timer_log *log) {
115
+ if (log->prev == NULL) {
116
+ list->head = log->next;
117
+ if (list->head != NULL) {
118
+ list->head->prev = NULL;
119
+ }
120
+ } else {
121
+ log->prev->next = log->next;
122
+ }
123
+ if (log->next == NULL) {
124
+ list->tail = log->prev;
125
+ if (list->tail != NULL) {
126
+ list->tail->next = NULL;
127
+ }
128
+ } else {
129
+ log->next->prev = log->prev;
130
+ }
131
+ }
132
+
133
+ static void write_log(gpr_timer_log *log) {
134
+ size_t i;
135
+ if (output_file == NULL) {
136
+ output_file = fopen(output_filename, "w");
137
+ }
138
+ for (i = 0; i < log->num_entries; i++) {
139
+ gpr_timer_entry *entry = &(log->log[i]);
140
+ if (gpr_time_cmp(entry->tm, gpr_time_0(entry->tm.clock_type)) < 0) {
141
+ entry->tm = gpr_time_0(entry->tm.clock_type);
142
+ }
143
+ fprintf(output_file,
144
+ "{\"t\": %lld.%09d, \"thd\": \"%d\", \"type\": \"%c\", \"tag\": "
145
+ "\"%s\", \"file\": \"%s\", \"line\": %d, \"imp\": %d}\n",
146
+ (long long)entry->tm.tv_sec, (int)entry->tm.tv_nsec, entry->thd,
147
+ entry->type, entry->tagstr, entry->file, entry->line,
148
+ entry->important);
149
+ }
150
+ }
151
+
152
+ static void writing_thread(void *unused) {
153
+ gpr_timer_log *log;
154
+ pthread_mutex_lock(&g_mu);
155
+ for (;;) {
156
+ while ((log = timer_log_pop_front(&g_done_logs)) == NULL && !g_shutdown) {
157
+ pthread_cond_wait(&g_cv, &g_mu);
158
+ }
159
+ if (log != NULL) {
160
+ pthread_mutex_unlock(&g_mu);
161
+ write_log(log);
162
+ free(log);
163
+ pthread_mutex_lock(&g_mu);
164
+ }
165
+ if (g_shutdown) {
166
+ pthread_mutex_unlock(&g_mu);
167
+ return;
168
+ }
169
+ }
170
+ }
171
+
172
+ static void flush_logs(gpr_timer_log_list *list) {
173
+ gpr_timer_log *log;
174
+ while ((log = timer_log_pop_front(list)) != NULL) {
175
+ write_log(log);
176
+ free(log);
177
+ }
178
+ }
179
+
180
+ static void finish_writing() {
181
+ pthread_mutex_lock(&g_mu);
182
+ g_shutdown = 1;
183
+ pthread_cond_signal(&g_cv);
184
+ pthread_mutex_unlock(&g_mu);
185
+ gpr_thd_join(g_writing_thread);
186
+
187
+ gpr_log(GPR_INFO, "flushing logs");
188
+
189
+ pthread_mutex_lock(&g_mu);
190
+ flush_logs(&g_done_logs);
191
+ flush_logs(&g_in_progress_logs);
192
+ pthread_mutex_unlock(&g_mu);
193
+
194
+ if (output_file) {
195
+ fclose(output_file);
196
+ }
197
+ }
198
+
199
+ void gpr_timers_set_log_filename(const char *filename) {
200
+ output_filename = filename;
201
+ }
202
+
203
+ static void init_output() {
204
+ gpr_thd_options options = gpr_thd_options_default();
205
+ gpr_thd_options_set_joinable(&options);
206
+ gpr_thd_new(&g_writing_thread, writing_thread, NULL, &options);
207
+ atexit(finish_writing);
208
+ }
209
+
210
+ static void rotate_log() {
211
+ gpr_timer_log *new = malloc(sizeof(*new));
212
+ gpr_once_init(&g_once_init, init_output);
213
+ new->num_entries = 0;
214
+ pthread_mutex_lock(&g_mu);
215
+ if (g_thread_log != NULL) {
216
+ timer_log_remove(&g_in_progress_logs, g_thread_log);
217
+ if (timer_log_push_back(&g_done_logs, g_thread_log)) {
218
+ pthread_cond_signal(&g_cv);
219
+ }
220
+ } else {
221
+ g_thread_id = g_next_thread_id++;
222
+ }
223
+ timer_log_push_back(&g_in_progress_logs, new);
224
+ pthread_mutex_unlock(&g_mu);
225
+ g_thread_log = new;
226
+ }
227
+
228
+ static void gpr_timers_log_add(const char *tagstr, marker_type type,
229
+ int important, const char *file, int line) {
230
+ gpr_timer_entry *entry;
231
+
232
+ if (g_thread_log == NULL || g_thread_log->num_entries == MAX_COUNT) {
233
+ rotate_log();
234
+ }
235
+
236
+ entry = &g_thread_log->log[g_thread_log->num_entries++];
237
+
238
+ entry->tm = gpr_now(GPR_CLOCK_PRECISE);
239
+ entry->tagstr = tagstr;
240
+ entry->type = type;
241
+ entry->file = file;
242
+ entry->line = (short)line;
243
+ entry->important = important != 0;
244
+ entry->thd = g_thread_id;
245
+ }
246
+
247
+ /* Latency profiler API implementation. */
248
+ void gpr_timer_add_mark(const char *tagstr, int important, const char *file,
249
+ int line) {
250
+ gpr_timers_log_add(tagstr, MARK, important, file, line);
251
+ }
252
+
253
+ void gpr_timer_begin(const char *tagstr, int important, const char *file,
254
+ int line) {
255
+ gpr_timers_log_add(tagstr, BEGIN, important, file, line);
256
+ }
257
+
258
+ void gpr_timer_end(const char *tagstr, int important, const char *file,
259
+ int line) {
260
+ gpr_timers_log_add(tagstr, END, important, file, line);
261
+ }
262
+
263
+ /* Basic profiler specific API functions. */
264
+ void gpr_timers_global_init(void) {}
265
+
266
+ void gpr_timers_global_destroy(void) {}
267
+
268
+ #else /* !GRPC_BASIC_PROFILER */
269
+ void gpr_timers_global_init(void) {}
270
+
271
+ void gpr_timers_global_destroy(void) {}
272
+
273
+ void gpr_timers_set_log_filename(const char *filename) {}
274
+ #endif /* GRPC_BASIC_PROFILER */