rbs 2.8.4 → 3.8.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (434) hide show
  1. checksums.yaml +4 -4
  2. data/.github/dependabot.yml +12 -4
  3. data/.github/workflows/comments.yml +11 -11
  4. data/.github/workflows/dependabot.yml +30 -0
  5. data/.github/workflows/ruby.yml +40 -49
  6. data/.github/workflows/typecheck.yml +36 -0
  7. data/.github/workflows/windows.yml +28 -0
  8. data/.gitignore +1 -0
  9. data/.rubocop.yml +42 -2
  10. data/CHANGELOG.md +845 -1
  11. data/README.md +64 -4
  12. data/Rakefile +198 -18
  13. data/Steepfile +11 -11
  14. data/config.yml +311 -0
  15. data/core/array.rbs +2189 -1914
  16. data/core/basic_object.rbs +59 -84
  17. data/core/binding.rbs +7 -69
  18. data/core/builtin.rbs +210 -11
  19. data/core/class.rbs +37 -0
  20. data/core/comparable.rbs +23 -25
  21. data/core/complex.rbs +449 -227
  22. data/core/constants.rbs +29 -21
  23. data/core/data.rbs +415 -0
  24. data/core/dir.rbs +698 -415
  25. data/core/encoding.rbs +468 -843
  26. data/core/enumerable.rbs +495 -455
  27. data/core/enumerator/product.rbs +92 -0
  28. data/core/enumerator.rbs +106 -9
  29. data/core/env.rbs +1 -1
  30. data/core/errno.rbs +506 -605
  31. data/core/errors.rbs +15 -17
  32. data/core/exception.rbs +361 -145
  33. data/core/false_class.rbs +39 -26
  34. data/core/fiber.rbs +121 -14
  35. data/core/file.rbs +1262 -320
  36. data/core/file_test.rbs +62 -45
  37. data/core/float.rbs +187 -208
  38. data/core/gc.rbs +446 -196
  39. data/core/global_variables.rbs +29 -29
  40. data/core/hash.rbs +242 -349
  41. data/core/integer.rbs +246 -308
  42. data/core/io/buffer.rbs +373 -122
  43. data/core/io/wait.rbs +29 -17
  44. data/core/io.rbs +1881 -1518
  45. data/core/kernel.rbs +2116 -1538
  46. data/core/marshal.rbs +24 -14
  47. data/core/match_data.rbs +413 -166
  48. data/core/math.rbs +531 -291
  49. data/core/method.rbs +101 -32
  50. data/core/module.rbs +228 -64
  51. data/core/nil_class.rbs +106 -47
  52. data/core/numeric.rbs +206 -292
  53. data/core/object.rbs +73 -1168
  54. data/core/object_space/weak_key_map.rbs +166 -0
  55. data/core/object_space.rbs +5 -3
  56. data/core/proc.rbs +280 -39
  57. data/core/process.rbs +1318 -658
  58. data/core/ractor.rbs +200 -134
  59. data/core/random.rbs +21 -4
  60. data/core/range.rbs +309 -153
  61. data/core/rational.rbs +4 -12
  62. data/core/rb_config.rbs +64 -43
  63. data/core/rbs/unnamed/argf.rbs +411 -147
  64. data/core/rbs/unnamed/env_class.rbs +137 -253
  65. data/core/rbs/unnamed/random.rbs +49 -26
  66. data/core/refinement.rbs +16 -1
  67. data/core/regexp.rbs +1568 -862
  68. data/core/ruby_vm.rbs +719 -7
  69. data/core/rubygems/config_file.rbs +3 -0
  70. data/core/rubygems/errors.rbs +69 -6
  71. data/core/rubygems/rubygems.rbs +71 -17
  72. data/core/rubygems/version.rbs +11 -7
  73. data/{stdlib/set/0 → core}/set.rbs +80 -91
  74. data/core/signal.rbs +14 -8
  75. data/core/string.rbs +1732 -1607
  76. data/core/struct.rbs +467 -95
  77. data/core/symbol.rbs +215 -245
  78. data/core/thread.rbs +133 -89
  79. data/core/thread_group.rbs +9 -9
  80. data/core/time.rbs +1141 -841
  81. data/core/trace_point.rbs +181 -121
  82. data/core/true_class.rbs +58 -32
  83. data/core/unbound_method.rbs +103 -30
  84. data/core/warning.rbs +50 -5
  85. data/docs/CONTRIBUTING.md +1 -1
  86. data/docs/architecture.md +110 -0
  87. data/docs/collection.md +59 -5
  88. data/docs/data_and_struct.md +86 -0
  89. data/docs/gem.md +57 -0
  90. data/docs/rbs_by_example.md +16 -35
  91. data/docs/repo.md +1 -1
  92. data/docs/sigs.md +7 -7
  93. data/docs/stdlib.md +63 -5
  94. data/docs/syntax.md +255 -61
  95. data/docs/tools.md +1 -0
  96. data/ext/rbs_extension/extconf.rb +10 -0
  97. data/ext/rbs_extension/lexer.c +1741 -1548
  98. data/ext/rbs_extension/lexer.h +11 -1
  99. data/ext/rbs_extension/lexer.re +12 -6
  100. data/ext/rbs_extension/lexstate.c +26 -3
  101. data/ext/rbs_extension/location.c +119 -111
  102. data/ext/rbs_extension/location.h +32 -7
  103. data/ext/rbs_extension/main.c +3 -0
  104. data/ext/rbs_extension/parser.c +883 -481
  105. data/ext/rbs_extension/parserstate.c +65 -25
  106. data/ext/rbs_extension/parserstate.h +13 -3
  107. data/ext/rbs_extension/rbs_extension.h +1 -10
  108. data/ext/rbs_extension/unescape.c +7 -47
  109. data/goodcheck.yml +2 -2
  110. data/{ext/rbs_extension → include/rbs}/constants.h +26 -15
  111. data/include/rbs/ruby_objs.h +72 -0
  112. data/include/rbs.h +7 -0
  113. data/lib/rbs/annotate/annotations.rb +3 -3
  114. data/lib/rbs/annotate/formatter.rb +13 -3
  115. data/lib/rbs/annotate/rdoc_annotator.rb +1 -1
  116. data/lib/rbs/annotate/rdoc_source.rb +12 -3
  117. data/lib/rbs/ast/declarations.rb +85 -2
  118. data/lib/rbs/ast/directives.rb +39 -0
  119. data/lib/rbs/ast/members.rb +49 -15
  120. data/lib/rbs/ast/type_param.rb +104 -15
  121. data/lib/rbs/ast/visitor.rb +137 -0
  122. data/lib/rbs/buffer.rb +5 -0
  123. data/lib/rbs/cli/colored_io.rb +48 -0
  124. data/lib/rbs/cli/diff.rb +83 -0
  125. data/lib/rbs/cli/validate.rb +356 -0
  126. data/lib/rbs/cli.rb +253 -143
  127. data/lib/rbs/collection/cleaner.rb +8 -1
  128. data/lib/rbs/collection/config/lockfile.rb +92 -0
  129. data/lib/rbs/collection/config/lockfile_generator.rb +154 -65
  130. data/lib/rbs/collection/config.rb +19 -46
  131. data/lib/rbs/collection/installer.rb +12 -13
  132. data/lib/rbs/collection/sources/base.rb +2 -2
  133. data/lib/rbs/collection/sources/git.rb +146 -69
  134. data/lib/rbs/collection/sources/local.rb +81 -0
  135. data/lib/rbs/collection/sources/rubygems.rb +10 -12
  136. data/lib/rbs/collection/sources/stdlib.rb +14 -13
  137. data/lib/rbs/collection/sources.rb +15 -2
  138. data/lib/rbs/collection.rb +2 -1
  139. data/lib/rbs/definition.rb +13 -16
  140. data/lib/rbs/definition_builder/ancestor_builder.rb +100 -24
  141. data/lib/rbs/definition_builder/method_builder.rb +4 -4
  142. data/lib/rbs/definition_builder.rb +489 -584
  143. data/lib/rbs/diff.rb +125 -0
  144. data/lib/rbs/environment/use_map.rb +77 -0
  145. data/lib/rbs/environment.rb +406 -105
  146. data/lib/rbs/environment_loader.rb +48 -44
  147. data/lib/rbs/environment_walker.rb +1 -1
  148. data/lib/rbs/errors.rb +175 -56
  149. data/lib/rbs/file_finder.rb +28 -0
  150. data/lib/rbs/location_aux.rb +8 -7
  151. data/lib/rbs/locator.rb +37 -15
  152. data/lib/rbs/method_type.rb +23 -0
  153. data/lib/rbs/namespace.rb +1 -0
  154. data/lib/rbs/parser/lex_result.rb +15 -0
  155. data/lib/rbs/parser/token.rb +23 -0
  156. data/lib/rbs/parser_aux.rb +22 -13
  157. data/lib/rbs/prototype/helpers.rb +48 -22
  158. data/lib/rbs/prototype/node_usage.rb +99 -0
  159. data/lib/rbs/prototype/rb.rb +125 -31
  160. data/lib/rbs/prototype/rbi.rb +49 -36
  161. data/lib/rbs/prototype/runtime/helpers.rb +59 -0
  162. data/lib/rbs/prototype/runtime/reflection.rb +19 -0
  163. data/lib/rbs/prototype/runtime/value_object_generator.rb +279 -0
  164. data/lib/rbs/prototype/runtime.rb +273 -159
  165. data/lib/rbs/resolver/constant_resolver.rb +24 -8
  166. data/lib/rbs/resolver/type_name_resolver.rb +41 -7
  167. data/lib/rbs/sorter.rb +153 -123
  168. data/lib/rbs/substitution.rb +19 -0
  169. data/lib/rbs/subtractor.rb +201 -0
  170. data/lib/rbs/test/errors.rb +24 -11
  171. data/lib/rbs/test/guaranteed.rb +30 -0
  172. data/lib/rbs/test/hook.rb +45 -40
  173. data/lib/rbs/test/setup.rb +1 -1
  174. data/lib/rbs/test/tester.rb +1 -1
  175. data/lib/rbs/test/type_check.rb +120 -23
  176. data/lib/rbs/test.rb +6 -3
  177. data/lib/rbs/type_alias_dependency.rb +13 -3
  178. data/lib/rbs/type_alias_regularity.rb +21 -14
  179. data/lib/rbs/type_name.rb +18 -13
  180. data/lib/rbs/types.rb +352 -18
  181. data/lib/rbs/unit_test/convertibles.rb +176 -0
  182. data/lib/rbs/unit_test/spy.rb +136 -0
  183. data/lib/rbs/unit_test/type_assertions.rb +341 -0
  184. data/lib/rbs/unit_test/with_aliases.rb +143 -0
  185. data/lib/rbs/unit_test.rb +6 -0
  186. data/lib/rbs/validator.rb +55 -30
  187. data/lib/rbs/variance_calculator.rb +26 -23
  188. data/lib/rbs/vendorer.rb +3 -3
  189. data/lib/rbs/version.rb +1 -1
  190. data/lib/rbs/writer.rb +69 -22
  191. data/lib/rbs.rb +7 -2
  192. data/lib/rdoc/discover.rb +1 -1
  193. data/lib/rdoc_plugin/parser.rb +5 -5
  194. data/rbs.gemspec +12 -2
  195. data/schema/decls.json +1 -1
  196. data/schema/members.json +15 -10
  197. data/sig/ancestor_builder.rbs +4 -0
  198. data/sig/ancestor_graph.rbs +22 -2
  199. data/sig/annotate/formatter.rbs +2 -2
  200. data/sig/annotate/rdoc_annotater.rbs +1 -1
  201. data/sig/cli/colored_io.rbs +15 -0
  202. data/sig/cli/diff.rbs +21 -0
  203. data/sig/cli/validate.rbs +43 -0
  204. data/sig/cli.rbs +4 -0
  205. data/sig/collection/config/lockfile.rbs +74 -0
  206. data/sig/collection/config/lockfile_generator.rbs +66 -0
  207. data/sig/collection/config.rbs +5 -48
  208. data/sig/collection/installer.rbs +1 -1
  209. data/sig/collection/sources.rbs +105 -33
  210. data/sig/constant.rbs +1 -1
  211. data/sig/declarations.rbs +42 -3
  212. data/sig/definition.rbs +26 -10
  213. data/sig/definition_builder.rbs +103 -81
  214. data/sig/diff.rbs +28 -0
  215. data/sig/directives.rbs +61 -0
  216. data/sig/environment.rbs +175 -29
  217. data/sig/environment_loader.rbs +20 -18
  218. data/sig/errors.rbs +123 -2
  219. data/sig/file_finder.rbs +28 -0
  220. data/sig/location.rbs +0 -3
  221. data/sig/locator.rbs +14 -2
  222. data/sig/manifest.yaml +0 -1
  223. data/sig/members.rbs +32 -9
  224. data/sig/method_types.rbs +10 -4
  225. data/sig/namespace.rbs +2 -3
  226. data/sig/parser.rbs +55 -16
  227. data/sig/prototype/helpers.rbs +4 -0
  228. data/sig/prototype/node_usage.rbs +20 -0
  229. data/sig/prototype/rb.rbs +10 -2
  230. data/sig/prototype/rbi.rbs +2 -0
  231. data/sig/prototype/runtime.rbs +182 -0
  232. data/sig/rbs.rbs +1 -1
  233. data/sig/rdoc/rbs.rbs +4 -0
  234. data/sig/repository.rbs +7 -5
  235. data/sig/resolver/constant_resolver.rbs +3 -4
  236. data/sig/resolver/context.rbs +1 -1
  237. data/sig/resolver/type_name_resolver.rbs +5 -1
  238. data/sig/shims/bundler.rbs +38 -0
  239. data/sig/shims/rubygems.rbs +19 -0
  240. data/sig/sorter.rbs +23 -5
  241. data/sig/substitution.rbs +6 -0
  242. data/sig/subtractor.rbs +37 -0
  243. data/sig/test/errors.rbs +52 -0
  244. data/sig/test/guranteed.rbs +9 -0
  245. data/sig/test/type_check.rbs +19 -0
  246. data/sig/test.rbs +82 -0
  247. data/sig/type_alias_dependency.rbs +31 -0
  248. data/sig/type_alias_regularity.rbs +12 -6
  249. data/sig/type_param.rbs +45 -9
  250. data/sig/typename.rbs +8 -5
  251. data/sig/types.rbs +119 -12
  252. data/sig/unit_test/convertibles.rbs +154 -0
  253. data/sig/unit_test/spy.rbs +28 -0
  254. data/sig/unit_test/type_assertions.rbs +194 -0
  255. data/sig/unit_test/with_aliases.rbs +136 -0
  256. data/sig/use_map.rbs +35 -0
  257. data/sig/validator.rbs +12 -5
  258. data/sig/variance_calculator.rbs +3 -1
  259. data/sig/vendorer.rbs +1 -1
  260. data/sig/visitor.rbs +47 -0
  261. data/sig/writer.rbs +6 -2
  262. data/src/constants.c +153 -0
  263. data/src/ruby_objs.c +793 -0
  264. data/stdlib/base64/0/base64.rbs +298 -45
  265. data/stdlib/benchmark/0/benchmark.rbs +12 -3
  266. data/stdlib/bigdecimal/0/big_decimal.rbs +62 -198
  267. data/stdlib/cgi/0/core.rbs +68 -15
  268. data/stdlib/cgi/0/manifest.yaml +1 -0
  269. data/stdlib/coverage/0/coverage.rbs +50 -11
  270. data/stdlib/csv/0/csv.rbs +90 -119
  271. data/stdlib/csv/0/manifest.yaml +1 -0
  272. data/stdlib/date/0/date.rbs +806 -735
  273. data/stdlib/date/0/date_time.rbs +70 -211
  274. data/stdlib/dbm/0/dbm.rbs +0 -2
  275. data/stdlib/delegate/0/delegator.rbs +184 -0
  276. data/stdlib/delegate/0/kernel.rbs +47 -0
  277. data/stdlib/delegate/0/simple_delegator.rbs +96 -0
  278. data/stdlib/did_you_mean/0/did_you_mean.rbs +3 -8
  279. data/stdlib/digest/0/digest.rbs +48 -35
  280. data/stdlib/erb/0/erb.rbs +15 -39
  281. data/stdlib/etc/0/etc.rbs +174 -54
  282. data/stdlib/fileutils/0/fileutils.rbs +1234 -385
  283. data/stdlib/forwardable/0/forwardable.rbs +4 -4
  284. data/stdlib/io-console/0/io-console.rbs +82 -17
  285. data/stdlib/ipaddr/0/ipaddr.rbs +11 -6
  286. data/stdlib/json/0/json.rbs +434 -151
  287. data/stdlib/kconv/0/kconv.rbs +166 -0
  288. data/stdlib/logger/0/formatter.rbs +0 -2
  289. data/stdlib/logger/0/log_device.rbs +1 -3
  290. data/stdlib/logger/0/logger.rbs +465 -328
  291. data/stdlib/minitest/0/kernel.rbs +2 -2
  292. data/stdlib/minitest/0/minitest/abstract_reporter.rbs +4 -1
  293. data/stdlib/minitest/0/minitest/assertion.rbs +1 -0
  294. data/stdlib/minitest/0/minitest/assertions.rbs +58 -13
  295. data/stdlib/minitest/0/minitest/backtrace_filter.rbs +7 -0
  296. data/stdlib/minitest/0/minitest/bench_spec.rbs +8 -8
  297. data/stdlib/minitest/0/minitest/benchmark.rbs +17 -16
  298. data/stdlib/minitest/0/minitest/compress.rbs +13 -0
  299. data/stdlib/minitest/0/minitest/error_on_warning.rbs +3 -0
  300. data/stdlib/minitest/0/minitest/mock.rbs +9 -5
  301. data/stdlib/minitest/0/minitest/parallel/executor.rbs +4 -0
  302. data/stdlib/minitest/0/minitest/parallel/test/class_methods.rbs +0 -1
  303. data/stdlib/minitest/0/minitest/pride_io.rbs +8 -0
  304. data/stdlib/minitest/0/minitest/pride_lol.rbs +2 -0
  305. data/stdlib/minitest/0/minitest/progress_reporter.rbs +1 -1
  306. data/stdlib/minitest/0/minitest/reportable.rbs +2 -0
  307. data/stdlib/minitest/0/minitest/runnable.rbs +33 -1
  308. data/stdlib/minitest/0/minitest/spec/dsl/instance_methods.rbs +1 -1
  309. data/stdlib/minitest/0/minitest/spec/dsl.rbs +10 -6
  310. data/stdlib/minitest/0/minitest/spec.rbs +1 -1
  311. data/stdlib/minitest/0/minitest/statistics_reporter.rbs +5 -0
  312. data/stdlib/minitest/0/minitest/summary_reporter.rbs +0 -7
  313. data/stdlib/minitest/0/minitest/test/lifecycle_hooks.rbs +7 -7
  314. data/stdlib/minitest/0/minitest/test.rbs +7 -14
  315. data/stdlib/minitest/0/minitest/unexpected_error.rbs +2 -0
  316. data/stdlib/minitest/0/minitest/unexpected_warning.rbs +6 -0
  317. data/stdlib/minitest/0/minitest/unit.rbs +1 -2
  318. data/stdlib/minitest/0/minitest.rbs +41 -892
  319. data/stdlib/monitor/0/monitor.rbs +91 -10
  320. data/stdlib/mutex_m/0/mutex_m.rbs +0 -2
  321. data/stdlib/net-http/0/manifest.yaml +1 -1
  322. data/stdlib/net-http/0/net-http.rbs +3858 -964
  323. data/stdlib/net-protocol/0/manifest.yaml +2 -0
  324. data/stdlib/net-protocol/0/net-protocol.rbs +56 -0
  325. data/stdlib/net-smtp/0/manifest.yaml +2 -0
  326. data/stdlib/net-smtp/0/net-smtp.rbs +55 -0
  327. data/stdlib/nkf/0/nkf.rbs +35 -5
  328. data/stdlib/objspace/0/objspace.rbs +40 -18
  329. data/stdlib/observable/0/observable.rbs +217 -0
  330. data/stdlib/open-uri/0/manifest.yaml +4 -0
  331. data/stdlib/open-uri/0/open-uri.rbs +393 -0
  332. data/stdlib/open3/0/open3.rbs +147 -0
  333. data/stdlib/openssl/0/manifest.yaml +1 -0
  334. data/stdlib/openssl/0/openssl.rbs +681 -316
  335. data/stdlib/optparse/0/optparse.rbs +100 -65
  336. data/stdlib/pathname/0/pathname.rbs +24 -15
  337. data/stdlib/pp/0/manifest.yaml +2 -0
  338. data/stdlib/pp/0/pp.rbs +300 -0
  339. data/stdlib/prettyprint/0/prettyprint.rbs +2 -6
  340. data/stdlib/pstore/0/pstore.rbs +370 -156
  341. data/stdlib/psych/0/core_ext.rbs +12 -0
  342. data/stdlib/{yaml → psych}/0/dbm.rbs +3 -3
  343. data/stdlib/psych/0/manifest.yaml +3 -0
  344. data/stdlib/psych/0/psych.rbs +402 -0
  345. data/stdlib/{yaml → psych}/0/store.rbs +2 -2
  346. data/stdlib/pty/0/pty.rbs +63 -11
  347. data/stdlib/rdoc/0/code_object.rbs +51 -0
  348. data/stdlib/rdoc/0/comment.rbs +59 -0
  349. data/stdlib/rdoc/0/context.rbs +153 -0
  350. data/stdlib/rdoc/0/markup.rbs +117 -0
  351. data/stdlib/rdoc/0/parser.rbs +56 -0
  352. data/stdlib/rdoc/0/rdoc.rbs +13 -380
  353. data/stdlib/rdoc/0/ri.rbs +17 -0
  354. data/stdlib/rdoc/0/store.rbs +48 -0
  355. data/stdlib/rdoc/0/top_level.rbs +97 -0
  356. data/stdlib/resolv/0/resolv.rbs +16 -79
  357. data/stdlib/ripper/0/ripper.rbs +1648 -0
  358. data/stdlib/securerandom/0/securerandom.rbs +7 -2
  359. data/stdlib/shellwords/0/shellwords.rbs +11 -12
  360. data/stdlib/singleton/0/singleton.rbs +0 -3
  361. data/stdlib/socket/0/addrinfo.rbs +13 -18
  362. data/stdlib/socket/0/basic_socket.rbs +5 -10
  363. data/stdlib/socket/0/ip_socket.rbs +0 -2
  364. data/stdlib/socket/0/socket.rbs +77 -46
  365. data/stdlib/socket/0/tcp_server.rbs +0 -5
  366. data/stdlib/socket/0/tcp_socket.rbs +36 -3
  367. data/stdlib/socket/0/udp_socket.rbs +4 -5
  368. data/stdlib/socket/0/unix_server.rbs +0 -5
  369. data/stdlib/socket/0/unix_socket.rbs +2 -4
  370. data/{core/string_io.rbs → stdlib/stringio/0/stringio.rbs} +188 -107
  371. data/stdlib/strscan/0/string_scanner.rbs +1269 -425
  372. data/stdlib/tempfile/0/tempfile.rbs +224 -61
  373. data/stdlib/time/0/time.rbs +48 -35
  374. data/stdlib/timeout/0/timeout.rbs +17 -8
  375. data/stdlib/tmpdir/0/tmpdir.rbs +10 -3
  376. data/stdlib/tsort/0/tsort.rbs +0 -4
  377. data/stdlib/uri/0/common.rbs +271 -144
  378. data/stdlib/uri/0/file.rbs +5 -0
  379. data/stdlib/uri/0/ftp.rbs +1 -1
  380. data/stdlib/uri/0/generic.rbs +26 -22
  381. data/stdlib/uri/0/http.rbs +4 -4
  382. data/stdlib/uri/0/ldap.rbs +1 -1
  383. data/stdlib/uri/0/mailto.rbs +84 -0
  384. data/stdlib/uri/0/rfc2396_parser.rbs +3 -0
  385. data/stdlib/yaml/0/manifest.yaml +1 -2
  386. data/stdlib/yaml/0/yaml.rbs +1 -199
  387. data/stdlib/zlib/0/buf_error.rbs +10 -0
  388. data/stdlib/zlib/0/data_error.rbs +10 -0
  389. data/stdlib/zlib/0/deflate.rbs +210 -0
  390. data/stdlib/zlib/0/error.rbs +20 -0
  391. data/stdlib/zlib/0/gzip_file/crc_error.rbs +12 -0
  392. data/stdlib/zlib/0/gzip_file/error.rbs +23 -0
  393. data/stdlib/zlib/0/gzip_file/length_error.rbs +12 -0
  394. data/stdlib/zlib/0/gzip_file/no_footer.rbs +11 -0
  395. data/stdlib/zlib/0/gzip_file.rbs +156 -0
  396. data/stdlib/zlib/0/gzip_reader.rbs +293 -0
  397. data/stdlib/zlib/0/gzip_writer.rbs +166 -0
  398. data/stdlib/zlib/0/inflate.rbs +180 -0
  399. data/stdlib/zlib/0/mem_error.rbs +10 -0
  400. data/stdlib/zlib/0/need_dict.rbs +13 -0
  401. data/stdlib/zlib/0/stream_end.rbs +11 -0
  402. data/stdlib/zlib/0/stream_error.rbs +11 -0
  403. data/stdlib/zlib/0/version_error.rbs +11 -0
  404. data/stdlib/zlib/0/zlib.rbs +1 -3
  405. data/stdlib/zlib/0/zstream.rbs +200 -0
  406. data/templates/include/rbs/constants.h.erb +20 -0
  407. data/templates/include/rbs/ruby_objs.h.erb +10 -0
  408. data/templates/src/constants.c.erb +36 -0
  409. data/templates/src/ruby_objs.c.erb +27 -0
  410. data/templates/template.rb +122 -0
  411. metadata +136 -36
  412. data/Gemfile +0 -33
  413. data/Gemfile.lock +0 -118
  414. data/core/deprecated.rbs +0 -9
  415. data/ext/rbs_extension/constants.c +0 -135
  416. data/ext/rbs_extension/ruby_objs.c +0 -525
  417. data/ext/rbs_extension/ruby_objs.h +0 -43
  418. data/lib/rbs/constant_table.rb +0 -167
  419. data/lib/rbs/parser_compat/lexer_error.rb +0 -6
  420. data/lib/rbs/parser_compat/located_value.rb +0 -7
  421. data/lib/rbs/parser_compat/semantics_error.rb +0 -6
  422. data/lib/rbs/parser_compat/syntax_error.rb +0 -6
  423. data/lib/rbs/test/spy.rb +0 -6
  424. data/lib/rbs/type_name_resolver.rb +0 -67
  425. data/sig/constant_table.rbs +0 -30
  426. data/sig/shims/abstract_syntax_tree.rbs +0 -25
  427. data/sig/shims/pp.rbs +0 -3
  428. data/sig/shims/ripper.rbs +0 -8
  429. data/sig/shims.rbs +0 -69
  430. data/sig/type_name_resolver.rbs +0 -26
  431. data/stdlib/minitest/0/manifest.yaml +0 -2
  432. data/stdlib/prime/0/integer-extension.rbs +0 -41
  433. data/stdlib/prime/0/manifest.yaml +0 -2
  434. data/stdlib/prime/0/prime.rbs +0 -372
@@ -0,0 +1,393 @@
1
+ %a{annotate:rdoc:skip}
2
+ module URI
3
+ # <!--
4
+ # rdoc-file=lib/open-uri.rb
5
+ # - open(name, *rest, &block)
6
+ # -->
7
+ # Allows the opening of various resources including URIs.
8
+ #
9
+ # If the first argument responds to the 'open' method, 'open' is called on it
10
+ # with the rest of the arguments.
11
+ #
12
+ # If the first argument is a string that begins with `(protocol)://`, it is
13
+ # parsed by URI.parse. If the parsed object responds to the 'open' method,
14
+ # 'open' is called on it with the rest of the arguments.
15
+ #
16
+ # Otherwise, Kernel#open is called.
17
+ #
18
+ # OpenURI::OpenRead#open provides URI::HTTP#open, URI::HTTPS#open and
19
+ # URI::FTP#open, Kernel#open.
20
+ #
21
+ # We can accept URIs and strings that begin with http://, https:// and ftp://.
22
+ # In these cases, the opened file object is extended by OpenURI::Meta.
23
+ #
24
+ def self.open: (String name, ?String mode, ?Integer perm, ?untyped options) -> ((StringIO & OpenURI::Meta) | (Tempfile & OpenURI::Meta))
25
+ | [T] (String name, ?String mode, ?Integer perm, ?untyped options) { (StringIO | Tempfile) -> T } -> T
26
+ end
27
+
28
+ # <!-- rdoc-file=lib/open-uri.rb -->
29
+ # OpenURI is an easy-to-use wrapper for Net::HTTP, Net::HTTPS and Net::FTP.
30
+ #
31
+ # ## Example
32
+ #
33
+ # It is possible to open an http, https or ftp URL as though it were a file:
34
+ #
35
+ # URI.open("http://www.ruby-lang.org/") {|f|
36
+ # f.each_line {|line| p line}
37
+ # }
38
+ #
39
+ # The opened file has several getter methods for its meta-information, as
40
+ # follows, since it is extended by OpenURI::Meta.
41
+ #
42
+ # URI.open("http://www.ruby-lang.org/en") {|f|
43
+ # f.each_line {|line| p line}
44
+ # p f.base_uri # <URI::HTTP:0x40e6ef2 URL:http://www.ruby-lang.org/en/>
45
+ # p f.content_type # "text/html"
46
+ # p f.charset # "iso-8859-1"
47
+ # p f.content_encoding # []
48
+ # p f.last_modified # Thu Dec 05 02:45:02 UTC 2002
49
+ # }
50
+ #
51
+ # Additional header fields can be specified by an optional hash argument.
52
+ #
53
+ # URI.open("http://www.ruby-lang.org/en/",
54
+ # "User-Agent" => "Ruby/#{RUBY_VERSION}",
55
+ # "From" => "foo@bar.invalid",
56
+ # "Referer" => "http://www.ruby-lang.org/") {|f|
57
+ # # ...
58
+ # }
59
+ #
60
+ # The environment variables such as http_proxy, https_proxy and ftp_proxy are in
61
+ # effect by default. Here we disable proxy:
62
+ #
63
+ # URI.open("http://www.ruby-lang.org/en/", :proxy => nil) {|f|
64
+ # # ...
65
+ # }
66
+ #
67
+ # See OpenURI::OpenRead.open and URI.open for more on available options.
68
+ #
69
+ # URI objects can be opened in a similar way.
70
+ #
71
+ # uri = URI.parse("http://www.ruby-lang.org/en/")
72
+ # uri.open {|f|
73
+ # # ...
74
+ # }
75
+ #
76
+ # URI objects can be read directly. The returned string is also extended by
77
+ # OpenURI::Meta.
78
+ #
79
+ # str = uri.read
80
+ # p str.base_uri
81
+ #
82
+ # Author
83
+ # : Tanaka Akira <akr@m17n.org>
84
+ #
85
+ module OpenURI
86
+ # <!-- rdoc-file=lib/open-uri.rb -->
87
+ # Mixin for holding meta-information.
88
+ #
89
+ module Meta
90
+ # <!-- rdoc-file=lib/open-uri.rb -->
91
+ # returns an Array that consists of status code and message.
92
+ #
93
+ attr_accessor status: [ String, String ]
94
+
95
+ # <!-- rdoc-file=lib/open-uri.rb -->
96
+ # returns a URI that is the base of relative URIs in the data. It may differ
97
+ # from the URI supplied by a user due to redirection.
98
+ #
99
+ attr_accessor base_uri: URI::Generic
100
+
101
+ # <!-- rdoc-file=lib/open-uri.rb -->
102
+ # returns a Hash that represents header fields. The Hash keys are downcased for
103
+ # canonicalization. The Hash values are a field body. If there are multiple
104
+ # field with same field name, the field values are concatenated with a comma.
105
+ #
106
+ attr_reader meta: Hash[String, String]
107
+
108
+ # <!--
109
+ # rdoc-file=lib/open-uri.rb
110
+ # - last_modified()
111
+ # -->
112
+ # returns a Time that represents the Last-Modified field.
113
+ #
114
+ def last_modified: () -> Time?
115
+
116
+ # <!--
117
+ # rdoc-file=lib/open-uri.rb
118
+ # - content_type()
119
+ # -->
120
+ # returns "type/subtype" which is MIME Content-Type. It is downcased for
121
+ # canonicalization. Content-Type parameters are stripped.
122
+ #
123
+ def content_type: () -> String
124
+
125
+ def charet: () -> String?
126
+
127
+ # <!--
128
+ # rdoc-file=lib/open-uri.rb
129
+ # - content_encoding()
130
+ # -->
131
+ # Returns a list of encodings in Content-Encoding field as an array of strings.
132
+ #
133
+ # The encodings are downcased for canonicalization.
134
+ #
135
+ def content_encoding: () -> Array[String]
136
+ end
137
+
138
+ # <!-- rdoc-file=lib/open-uri.rb -->
139
+ # Mixin for HTTP and FTP URIs.
140
+ #
141
+ module OpenRead
142
+ # <!--
143
+ # rdoc-file=lib/open-uri.rb
144
+ # - open(*rest, &block)
145
+ # -->
146
+ # OpenURI::OpenRead#open provides `open' for URI::HTTP and URI::FTP.
147
+ #
148
+ # OpenURI::OpenRead#open takes optional 3 arguments as:
149
+ #
150
+ # OpenURI::OpenRead#open([mode [, perm]] [, options]) [{|io| ... }]
151
+ #
152
+ # OpenURI::OpenRead#open returns an IO-like object if block is not given.
153
+ # Otherwise it yields the IO object and return the value of the block. The IO
154
+ # object is extended with OpenURI::Meta.
155
+ #
156
+ # `mode` and `perm` are the same as Kernel#open.
157
+ #
158
+ # However, `mode` must be read mode because OpenURI::OpenRead#open doesn't
159
+ # support write mode (yet). Also `perm` is ignored because it is meaningful only
160
+ # for file creation.
161
+ #
162
+ # `options` must be a hash.
163
+ #
164
+ # Each option with a string key specifies an extra header field for HTTP. I.e.,
165
+ # it is ignored for FTP without HTTP proxy.
166
+ #
167
+ # The hash may include other options, where keys are symbols:
168
+ #
169
+ # :proxy
170
+ # : Synopsis:
171
+ # :proxy => "http://proxy.foo.com:8000/"
172
+ # :proxy => URI.parse("http://proxy.foo.com:8000/")
173
+ # :proxy => true
174
+ # :proxy => false
175
+ # :proxy => nil
176
+ #
177
+ # If :proxy option is specified, the value should be String, URI, boolean or
178
+ # nil.
179
+ #
180
+ # When String or URI is given, it is treated as proxy URI.
181
+ #
182
+ # When true is given or the option itself is not specified, environment
183
+ # variable `scheme_proxy' is examined. `scheme' is replaced by `http',
184
+ # `https' or `ftp'.
185
+ #
186
+ # When false or nil is given, the environment variables are ignored and
187
+ # connection will be made to a server directly.
188
+ #
189
+ #
190
+ # :proxy_http_basic_authentication
191
+ # : Synopsis:
192
+ # :proxy_http_basic_authentication =>
193
+ # ["http://proxy.foo.com:8000/", "proxy-user", "proxy-password"]
194
+ # :proxy_http_basic_authentication =>
195
+ # [URI.parse("http://proxy.foo.com:8000/"),
196
+ # "proxy-user", "proxy-password"]
197
+ #
198
+ # If :proxy option is specified, the value should be an Array with 3
199
+ # elements. It should contain a proxy URI, a proxy user name and a proxy
200
+ # password. The proxy URI should be a String, an URI or nil. The proxy
201
+ # user name and password should be a String.
202
+ #
203
+ # If nil is given for the proxy URI, this option is just ignored.
204
+ #
205
+ # If :proxy and :proxy_http_basic_authentication is specified, ArgumentError
206
+ # is raised.
207
+ #
208
+ #
209
+ # :http_basic_authentication
210
+ # : Synopsis:
211
+ # :http_basic_authentication=>[user, password]
212
+ #
213
+ # If :http_basic_authentication is specified, the value should be an array
214
+ # which contains 2 strings: username and password. It is used for HTTP Basic
215
+ # authentication defined by RFC 2617.
216
+ #
217
+ #
218
+ # :content_length_proc
219
+ # : Synopsis:
220
+ # :content_length_proc => lambda {|content_length| ... }
221
+ #
222
+ # If :content_length_proc option is specified, the option value procedure is
223
+ # called before actual transfer is started. It takes one argument, which is
224
+ # expected content length in bytes.
225
+ #
226
+ # If two or more transfers are performed by HTTP redirection, the procedure
227
+ # is called only once for the last transfer.
228
+ #
229
+ # When expected content length is unknown, the procedure is called with nil.
230
+ # This happens when the HTTP response has no Content-Length header.
231
+ #
232
+ #
233
+ # :progress_proc
234
+ # : Synopsis:
235
+ # :progress_proc => lambda {|size| ...}
236
+ #
237
+ # If :progress_proc option is specified, the proc is called with one
238
+ # argument each time when `open' gets content fragment from network. The
239
+ # argument `size` is the accumulated transferred size in bytes.
240
+ #
241
+ # If two or more transfer is done by HTTP redirection, the procedure is
242
+ # called only one for a last transfer.
243
+ #
244
+ # :progress_proc and :content_length_proc are intended to be used for
245
+ # progress bar. For example, it can be implemented as follows using
246
+ # Ruby/ProgressBar.
247
+ #
248
+ # pbar = nil
249
+ # open("http://...",
250
+ # :content_length_proc => lambda {|t|
251
+ # if t && 0 < t
252
+ # pbar = ProgressBar.new("...", t)
253
+ # pbar.file_transfer_mode
254
+ # end
255
+ # },
256
+ # :progress_proc => lambda {|s|
257
+ # pbar.set s if pbar
258
+ # }) {|f| ... }
259
+ #
260
+ #
261
+ # :read_timeout
262
+ # : Synopsis:
263
+ # :read_timeout=>nil (no timeout)
264
+ # :read_timeout=>10 (10 second)
265
+ #
266
+ # :read_timeout option specifies a timeout of read for http connections.
267
+ #
268
+ #
269
+ # :open_timeout
270
+ # : Synopsis:
271
+ # :open_timeout=>nil (no timeout)
272
+ # :open_timeout=>10 (10 second)
273
+ #
274
+ # :open_timeout option specifies a timeout of open for http connections.
275
+ #
276
+ #
277
+ # :ssl_ca_cert
278
+ # : Synopsis:
279
+ # :ssl_ca_cert=>filename or an Array of filenames
280
+ #
281
+ # :ssl_ca_cert is used to specify CA certificate for SSL. If it is given,
282
+ # default certificates are not used.
283
+ #
284
+ #
285
+ # :ssl_verify_mode
286
+ # : Synopsis:
287
+ # :ssl_verify_mode=>mode
288
+ #
289
+ # :ssl_verify_mode is used to specify openssl verify mode.
290
+ #
291
+ #
292
+ # :ssl_min_version
293
+ # : Synopsis:
294
+ # :ssl_min_version=>:TLS1_2
295
+ #
296
+ # :ssl_min_version option specifies the minimum allowed SSL/TLS protocol
297
+ # version. See also OpenSSL::SSL::SSLContext#min_version=.
298
+ #
299
+ #
300
+ # :ssl_max_version
301
+ # : Synopsis:
302
+ # :ssl_max_version=>:TLS1_2
303
+ #
304
+ # :ssl_max_version option specifies the maximum allowed SSL/TLS protocol
305
+ # version. See also OpenSSL::SSL::SSLContext#max_version=.
306
+ #
307
+ #
308
+ # :ftp_active_mode
309
+ # : Synopsis:
310
+ # :ftp_active_mode=>bool
311
+ #
312
+ # `:ftp_active_mode => true` is used to make ftp active mode. Ruby 1.9 uses
313
+ # passive mode by default. Note that the active mode is default in Ruby 1.8
314
+ # or prior.
315
+ #
316
+ #
317
+ # :redirect
318
+ # : Synopsis:
319
+ # :redirect=>bool
320
+ #
321
+ # `:redirect` is true by default. `:redirect => false` is used to disable
322
+ # all HTTP redirects.
323
+ #
324
+ # OpenURI::HTTPRedirect exception raised on redirection. Using `true` also
325
+ # means that redirections between http and ftp are permitted.
326
+ #
327
+ #
328
+ # :max_redirects
329
+ # : Synopsis:
330
+ # :max_redirects=>int
331
+ #
332
+ # Number of HTTP redirects allowed before OpenURI::TooManyRedirects is
333
+ # raised. The default is 64.
334
+ #
335
+ #
336
+ # :request_specific_fields
337
+ # : Synopsis:
338
+ # :request_specific_fields => {}
339
+ # :request_specific_fields => lambda {|url| ...}
340
+ #
341
+ # :request_specific_fields option allows specifying custom header fields
342
+ # that are sent with the HTTP request. It can be passed as a Hash or a Proc
343
+ # that gets evaluated on each request and returns a Hash of header fields.
344
+ #
345
+ # If a Hash is provided, it specifies the headers only for the initial
346
+ # request and these headers will not be sent on redirects.
347
+ #
348
+ # If a Proc is provided, it will be executed for each request including
349
+ # redirects, allowing dynamic header customization based on the request URL.
350
+ # It is important that the Proc returns a Hash. And this Hash specifies the
351
+ # headers to be sent with the request.
352
+ #
353
+ # For Example with Hash
354
+ # URI.open("http://...",
355
+ # request_specific_fields: {"Authorization" => "token dummy"}) {|f| ... }
356
+ #
357
+ # For Example with Proc:
358
+ # URI.open("http://...",
359
+ # request_specific_fields: lambda { |uri|
360
+ # if uri.host == "example.com"
361
+ # {"Authorization" => "token dummy"}
362
+ # else
363
+ # {}
364
+ # end
365
+ # }) {|f| ... }
366
+ #
367
+ def open: (*untyped) -> IO
368
+ | [T] (*untyped) { (IO) -> T } -> T
369
+
370
+ # <!--
371
+ # rdoc-file=lib/open-uri.rb
372
+ # - read(options={})
373
+ # -->
374
+ # OpenURI::OpenRead#read([ options ]) reads a content referenced by self and
375
+ # returns the content as string. The string is extended with OpenURI::Meta. The
376
+ # argument `options` is same as OpenURI::OpenRead#open.
377
+ #
378
+ def read: (untyped options) -> String
379
+ end
380
+ end
381
+
382
+ %a{annotate:rdoc:skip}
383
+ module URI
384
+ %a{annotate:rdoc:skip}
385
+ class HTTP
386
+ include OpenURI::OpenRead
387
+ end
388
+
389
+ %a{annotate:rdoc:skip}
390
+ class FTP
391
+ include OpenURI::OpenRead
392
+ end
393
+ end
@@ -0,0 +1,147 @@
1
+ # <!-- rdoc-file=lib/open3.rb -->
2
+ # Module Open3 supports creating child processes with access to their $stdin,
3
+ # $stdout, and $stderr streams.
4
+ #
5
+ # ## What's Here
6
+ #
7
+ # Each of these methods executes a given command in a new process or subshell,
8
+ # or multiple commands in new processes and/or subshells:
9
+ #
10
+ # * Each of these methods executes a single command in a process or subshell,
11
+ # accepts a string for input to $stdin, and returns string output from
12
+ # $stdout, $stderr, or both:
13
+ #
14
+ # * Open3.capture2: Executes the command; returns the string from $stdout.
15
+ # * Open3.capture2e: Executes the command; returns the string from merged
16
+ # $stdout and $stderr.
17
+ # * Open3.capture3: Executes the command; returns strings from $stdout and
18
+ # $stderr.
19
+ #
20
+ # * Each of these methods executes a single command in a process or subshell,
21
+ # and returns pipes for $stdin, $stdout, and/or $stderr:
22
+ #
23
+ # * Open3.popen2: Executes the command; returns pipes for $stdin and
24
+ # $stdout.
25
+ # * Open3.popen2e: Executes the command; returns pipes for $stdin and
26
+ # merged $stdout and $stderr.
27
+ # * Open3.popen3: Executes the command; returns pipes for $stdin, $stdout,
28
+ # and $stderr.
29
+ #
30
+ # * Each of these methods executes one or more commands in processes and/or
31
+ # subshells, returns pipes for the first $stdin, the last $stdout, or both:
32
+ #
33
+ # * Open3.pipeline_r: Returns a pipe for the last $stdout.
34
+ # * Open3.pipeline_rw: Returns pipes for the first $stdin and the last
35
+ # $stdout.
36
+ # * Open3.pipeline_w: Returns a pipe for the first $stdin.
37
+ # * Open3.pipeline_start: Does not wait for processes to complete.
38
+ # * Open3.pipeline: Waits for processes to complete.
39
+ #
40
+ # Each of the methods above accepts:
41
+ #
42
+ # * An optional hash of environment variable names and values; see [Execution
43
+ # Environment](rdoc-ref:Process@Execution+Environment).
44
+ # * A required string argument that is a `command_line` or `exe_path`; see
45
+ # [Argument command_line or
46
+ # exe_path](rdoc-ref:Process@Argument+command_line+or+exe_path).
47
+ # * An optional hash of execution options; see [Execution
48
+ # Options](rdoc-ref:Process@Execution+Options).
49
+ #
50
+ module Open3
51
+ # <!--
52
+ # rdoc-file=lib/open3.rb
53
+ # - Open3.capture2e([env, ] command_line, options = {}) -> [stdout_and_stderr_s, status]
54
+ # - Open3.capture2e([env, ] exe_path, *args, options = {}) -> [stdout_and_stderr_s, status]
55
+ # -->
56
+ # Basically a wrapper for Open3.popen3 that:
57
+ #
58
+ # * Creates a child process, by calling Open3.popen3 with the given arguments
59
+ # (except for certain entries in hash `options`; see below).
60
+ # * Returns as string `stdout_and_stderr_s` the merged standard output and
61
+ # standard error of the child process.
62
+ # * Returns as `status` a `Process::Status` object that represents the exit
63
+ # status of the child process.
64
+ #
65
+ # Returns the array `[stdout_and_stderr_s, status]`:
66
+ #
67
+ # stdout_and_stderr_s, status = Open3.capture2e('echo "Foo"')
68
+ # # => ["Foo\n", #<Process::Status: pid 2371692 exit 0>]
69
+ #
70
+ # Like Process.spawn, this method has potential security vulnerabilities if
71
+ # called with untrusted input; see [Command
72
+ # Injection](rdoc-ref:command_injection.rdoc@Command+Injection).
73
+ #
74
+ # Unlike Process.spawn, this method waits for the child process to exit before
75
+ # returning, so the caller need not do so.
76
+ #
77
+ # If the first argument is a hash, it becomes leading argument `env` in the call
78
+ # to Open3.popen3; see [Execution
79
+ # Environment](rdoc-ref:Process@Execution+Environment).
80
+ #
81
+ # If the last argument is a hash, it becomes trailing argument `options` in the
82
+ # call to Open3.popen3; see [Execution
83
+ # Options](rdoc-ref:Process@Execution+Options).
84
+ #
85
+ # The hash `options` is given; two options have local effect in method
86
+ # Open3.capture2e:
87
+ #
88
+ # * If entry `options[:stdin_data]` exists, the entry is removed and its
89
+ # string value is sent to the command's standard input:
90
+ #
91
+ # Open3.capture2e('tee', stdin_data: 'Foo')
92
+ # # => ["Foo", #<Process::Status: pid 2371732 exit 0>]
93
+ #
94
+ # * If entry `options[:binmode]` exists, the entry is removed and the internal
95
+ # streams are set to binary mode.
96
+ #
97
+ # The single required argument is one of the following:
98
+ #
99
+ # * `command_line` if it is a string, and if it begins with a shell reserved
100
+ # word or special built-in, or if it contains one or more metacharacters.
101
+ # * `exe_path` otherwise.
102
+ #
103
+ # **Argument `command_line`**
104
+ #
105
+ # String argument `command_line` is a command line to be passed to a shell; it
106
+ # must begin with a shell reserved word, begin with a special built-in, or
107
+ # contain meta characters:
108
+ #
109
+ # Open3.capture2e('if true; then echo "Foo"; fi') # Shell reserved word.
110
+ # # => ["Foo\n", #<Process::Status: pid 2371740 exit 0>]
111
+ # Open3.capture2e('echo') # Built-in.
112
+ # # => ["\n", #<Process::Status: pid 2371774 exit 0>]
113
+ # Open3.capture2e('date > date.tmp') # Contains meta character.
114
+ # # => ["", #<Process::Status: pid 2371812 exit 0>]
115
+ #
116
+ # The command line may also contain arguments and options for the command:
117
+ #
118
+ # Open3.capture2e('echo "Foo"')
119
+ # # => ["Foo\n", #<Process::Status: pid 2326183 exit 0>]
120
+ #
121
+ # **Argument `exe_path`**
122
+ #
123
+ # Argument `exe_path` is one of the following:
124
+ #
125
+ # * The string path to an executable to be called.
126
+ # * A 2-element array containing the path to an executable and the string to
127
+ # be used as the name of the executing process.
128
+ #
129
+ # Example:
130
+ #
131
+ # Open3.capture2e('/usr/bin/date')
132
+ # # => ["Sat Sep 30 09:01:46 AM CDT 2023\n", #<Process::Status: pid 2371820 exit 0>]
133
+ #
134
+ # Ruby invokes the executable directly, with no shell and no shell expansion:
135
+ #
136
+ # Open3.capture2e('doesnt_exist') # Raises Errno::ENOENT
137
+ #
138
+ # If one or more `args` is given, each is an argument or option to be passed to
139
+ # the executable:
140
+ #
141
+ # Open3.capture2e('echo', 'C #')
142
+ # # => ["C #\n", #<Process::Status: pid 2371856 exit 0>]
143
+ # Open3.capture2e('echo', 'hello', 'world')
144
+ # # => ["hello world\n", #<Process::Status: pid 2371894 exit 0>]
145
+ #
146
+ def self.capture2e: (*String, ?stdin_data: String, ?binmode: boolish) -> [String, Process::Status]
147
+ end
@@ -1,2 +1,3 @@
1
1
  dependencies:
2
2
  - name: socket
3
+ - name: digest