rbs-relaxed 3.9.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (484) hide show
  1. checksums.yaml +7 -0
  2. data/.github/dependabot.yml +22 -0
  3. data/.github/workflows/comments.yml +35 -0
  4. data/.github/workflows/dependabot.yml +30 -0
  5. data/.github/workflows/ruby.yml +82 -0
  6. data/.github/workflows/typecheck.yml +38 -0
  7. data/.github/workflows/windows.yml +43 -0
  8. data/.gitignore +23 -0
  9. data/.rubocop.yml +68 -0
  10. data/BSDL +22 -0
  11. data/CHANGELOG.md +1868 -0
  12. data/COPYING +56 -0
  13. data/README.md +203 -0
  14. data/Rakefile +417 -0
  15. data/Steepfile +44 -0
  16. data/config.yml +313 -0
  17. data/core/array.rbs +4062 -0
  18. data/core/basic_object.rbs +375 -0
  19. data/core/binding.rbs +150 -0
  20. data/core/builtin.rbs +277 -0
  21. data/core/class.rbs +220 -0
  22. data/core/comparable.rbs +171 -0
  23. data/core/complex.rbs +786 -0
  24. data/core/constants.rbs +96 -0
  25. data/core/data.rbs +415 -0
  26. data/core/dir.rbs +981 -0
  27. data/core/encoding.rbs +1371 -0
  28. data/core/enumerable.rbs +2405 -0
  29. data/core/enumerator/product.rbs +92 -0
  30. data/core/enumerator.rbs +630 -0
  31. data/core/env.rbs +6 -0
  32. data/core/errno.rbs +673 -0
  33. data/core/errors.rbs +760 -0
  34. data/core/exception.rbs +485 -0
  35. data/core/false_class.rbs +82 -0
  36. data/core/fiber.rbs +550 -0
  37. data/core/fiber_error.rbs +11 -0
  38. data/core/file.rbs +2936 -0
  39. data/core/file_test.rbs +331 -0
  40. data/core/float.rbs +1151 -0
  41. data/core/gc.rbs +644 -0
  42. data/core/global_variables.rbs +184 -0
  43. data/core/hash.rbs +1861 -0
  44. data/core/integer.rbs +1413 -0
  45. data/core/io/buffer.rbs +984 -0
  46. data/core/io/wait.rbs +70 -0
  47. data/core/io.rbs +3406 -0
  48. data/core/kernel.rbs +3096 -0
  49. data/core/marshal.rbs +207 -0
  50. data/core/match_data.rbs +635 -0
  51. data/core/math.rbs +729 -0
  52. data/core/method.rbs +386 -0
  53. data/core/module.rbs +1704 -0
  54. data/core/nil_class.rbs +209 -0
  55. data/core/numeric.rbs +818 -0
  56. data/core/object.rbs +110 -0
  57. data/core/object_space/weak_key_map.rbs +166 -0
  58. data/core/object_space.rbs +190 -0
  59. data/core/proc.rbs +868 -0
  60. data/core/process.rbs +2296 -0
  61. data/core/ractor.rbs +1068 -0
  62. data/core/random.rbs +237 -0
  63. data/core/range.rbs +1107 -0
  64. data/core/rational.rbs +531 -0
  65. data/core/rb_config.rbs +88 -0
  66. data/core/rbs/unnamed/argf.rbs +1229 -0
  67. data/core/rbs/unnamed/env_class.rbs +1209 -0
  68. data/core/rbs/unnamed/random.rbs +293 -0
  69. data/core/refinement.rbs +59 -0
  70. data/core/regexp.rbs +1930 -0
  71. data/core/ruby_vm.rbs +765 -0
  72. data/core/rubygems/basic_specification.rbs +6 -0
  73. data/core/rubygems/config_file.rbs +38 -0
  74. data/core/rubygems/dependency_installer.rbs +6 -0
  75. data/core/rubygems/errors.rbs +176 -0
  76. data/core/rubygems/installer.rbs +15 -0
  77. data/core/rubygems/path_support.rbs +6 -0
  78. data/core/rubygems/platform.rbs +7 -0
  79. data/core/rubygems/request_set.rbs +49 -0
  80. data/core/rubygems/requirement.rbs +148 -0
  81. data/core/rubygems/rubygems.rbs +1171 -0
  82. data/core/rubygems/source_list.rbs +15 -0
  83. data/core/rubygems/specification.rbs +23 -0
  84. data/core/rubygems/stream_ui.rbs +5 -0
  85. data/core/rubygems/uninstaller.rbs +10 -0
  86. data/core/rubygems/version.rbs +294 -0
  87. data/core/set.rbs +621 -0
  88. data/core/signal.rbs +100 -0
  89. data/core/string.rbs +3583 -0
  90. data/core/struct.rbs +667 -0
  91. data/core/symbol.rbs +475 -0
  92. data/core/thread.rbs +1765 -0
  93. data/core/thread_group.rbs +79 -0
  94. data/core/time.rbs +1762 -0
  95. data/core/trace_point.rbs +477 -0
  96. data/core/true_class.rbs +98 -0
  97. data/core/unbound_method.rbs +329 -0
  98. data/core/warning.rbs +87 -0
  99. data/docs/CONTRIBUTING.md +106 -0
  100. data/docs/architecture.md +110 -0
  101. data/docs/collection.md +192 -0
  102. data/docs/data_and_struct.md +86 -0
  103. data/docs/gem.md +57 -0
  104. data/docs/rbs_by_example.md +309 -0
  105. data/docs/repo.md +125 -0
  106. data/docs/sigs.md +167 -0
  107. data/docs/stdlib.md +147 -0
  108. data/docs/syntax.md +910 -0
  109. data/docs/tools.md +17 -0
  110. data/exe/rbs +7 -0
  111. data/ext/rbs_extension/extconf.rb +15 -0
  112. data/ext/rbs_extension/lexer.c +2728 -0
  113. data/ext/rbs_extension/lexer.h +179 -0
  114. data/ext/rbs_extension/lexer.re +147 -0
  115. data/ext/rbs_extension/lexstate.c +175 -0
  116. data/ext/rbs_extension/location.c +325 -0
  117. data/ext/rbs_extension/location.h +85 -0
  118. data/ext/rbs_extension/main.c +33 -0
  119. data/ext/rbs_extension/parser.c +2973 -0
  120. data/ext/rbs_extension/parser.h +18 -0
  121. data/ext/rbs_extension/parserstate.c +397 -0
  122. data/ext/rbs_extension/parserstate.h +163 -0
  123. data/ext/rbs_extension/rbs_extension.h +31 -0
  124. data/ext/rbs_extension/unescape.c +32 -0
  125. data/goodcheck.yml +91 -0
  126. data/include/rbs/constants.h +82 -0
  127. data/include/rbs/ruby_objs.h +72 -0
  128. data/include/rbs/util/rbs_constant_pool.h +219 -0
  129. data/include/rbs.h +7 -0
  130. data/lib/rbs/ancestor_graph.rb +92 -0
  131. data/lib/rbs/annotate/annotations.rb +199 -0
  132. data/lib/rbs/annotate/formatter.rb +92 -0
  133. data/lib/rbs/annotate/rdoc_annotator.rb +400 -0
  134. data/lib/rbs/annotate/rdoc_source.rb +131 -0
  135. data/lib/rbs/annotate.rb +8 -0
  136. data/lib/rbs/ast/annotation.rb +29 -0
  137. data/lib/rbs/ast/comment.rb +29 -0
  138. data/lib/rbs/ast/declarations.rb +467 -0
  139. data/lib/rbs/ast/directives.rb +49 -0
  140. data/lib/rbs/ast/members.rb +451 -0
  141. data/lib/rbs/ast/type_param.rb +225 -0
  142. data/lib/rbs/ast/visitor.rb +137 -0
  143. data/lib/rbs/buffer.rb +67 -0
  144. data/lib/rbs/builtin_names.rb +58 -0
  145. data/lib/rbs/cli/colored_io.rb +48 -0
  146. data/lib/rbs/cli/diff.rb +83 -0
  147. data/lib/rbs/cli/validate.rb +357 -0
  148. data/lib/rbs/cli.rb +1223 -0
  149. data/lib/rbs/collection/cleaner.rb +38 -0
  150. data/lib/rbs/collection/config/lockfile.rb +92 -0
  151. data/lib/rbs/collection/config/lockfile_generator.rb +218 -0
  152. data/lib/rbs/collection/config.rb +81 -0
  153. data/lib/rbs/collection/installer.rb +32 -0
  154. data/lib/rbs/collection/sources/base.rb +14 -0
  155. data/lib/rbs/collection/sources/git.rb +258 -0
  156. data/lib/rbs/collection/sources/local.rb +81 -0
  157. data/lib/rbs/collection/sources/rubygems.rb +48 -0
  158. data/lib/rbs/collection/sources/stdlib.rb +50 -0
  159. data/lib/rbs/collection/sources.rb +38 -0
  160. data/lib/rbs/collection.rb +16 -0
  161. data/lib/rbs/constant.rb +28 -0
  162. data/lib/rbs/definition.rb +401 -0
  163. data/lib/rbs/definition_builder/ancestor_builder.rb +620 -0
  164. data/lib/rbs/definition_builder/method_builder.rb +254 -0
  165. data/lib/rbs/definition_builder.rb +845 -0
  166. data/lib/rbs/diff.rb +125 -0
  167. data/lib/rbs/environment/use_map.rb +77 -0
  168. data/lib/rbs/environment.rb +829 -0
  169. data/lib/rbs/environment_loader.rb +173 -0
  170. data/lib/rbs/environment_walker.rb +155 -0
  171. data/lib/rbs/errors.rb +645 -0
  172. data/lib/rbs/factory.rb +18 -0
  173. data/lib/rbs/file_finder.rb +28 -0
  174. data/lib/rbs/location_aux.rb +138 -0
  175. data/lib/rbs/locator.rb +243 -0
  176. data/lib/rbs/method_type.rb +143 -0
  177. data/lib/rbs/namespace.rb +125 -0
  178. data/lib/rbs/parser/lex_result.rb +15 -0
  179. data/lib/rbs/parser/token.rb +23 -0
  180. data/lib/rbs/parser_aux.rb +114 -0
  181. data/lib/rbs/prototype/helpers.rb +140 -0
  182. data/lib/rbs/prototype/node_usage.rb +99 -0
  183. data/lib/rbs/prototype/rb.rb +840 -0
  184. data/lib/rbs/prototype/rbi.rb +641 -0
  185. data/lib/rbs/prototype/runtime/helpers.rb +59 -0
  186. data/lib/rbs/prototype/runtime/reflection.rb +19 -0
  187. data/lib/rbs/prototype/runtime/value_object_generator.rb +279 -0
  188. data/lib/rbs/prototype/runtime.rb +667 -0
  189. data/lib/rbs/repository.rb +127 -0
  190. data/lib/rbs/resolver/constant_resolver.rb +219 -0
  191. data/lib/rbs/resolver/type_name_resolver.rb +91 -0
  192. data/lib/rbs/sorter.rb +198 -0
  193. data/lib/rbs/substitution.rb +83 -0
  194. data/lib/rbs/subtractor.rb +201 -0
  195. data/lib/rbs/test/errors.rb +80 -0
  196. data/lib/rbs/test/guaranteed.rb +30 -0
  197. data/lib/rbs/test/hook.rb +212 -0
  198. data/lib/rbs/test/observer.rb +19 -0
  199. data/lib/rbs/test/setup.rb +84 -0
  200. data/lib/rbs/test/setup_helper.rb +50 -0
  201. data/lib/rbs/test/tester.rb +167 -0
  202. data/lib/rbs/test/type_check.rb +435 -0
  203. data/lib/rbs/test.rb +112 -0
  204. data/lib/rbs/type_alias_dependency.rb +100 -0
  205. data/lib/rbs/type_alias_regularity.rb +126 -0
  206. data/lib/rbs/type_name.rb +109 -0
  207. data/lib/rbs/types.rb +1596 -0
  208. data/lib/rbs/unit_test/convertibles.rb +176 -0
  209. data/lib/rbs/unit_test/spy.rb +138 -0
  210. data/lib/rbs/unit_test/type_assertions.rb +347 -0
  211. data/lib/rbs/unit_test/with_aliases.rb +143 -0
  212. data/lib/rbs/unit_test.rb +6 -0
  213. data/lib/rbs/validator.rb +186 -0
  214. data/lib/rbs/variance_calculator.rb +189 -0
  215. data/lib/rbs/vendorer.rb +71 -0
  216. data/lib/rbs/version.rb +5 -0
  217. data/lib/rbs/writer.rb +424 -0
  218. data/lib/rbs.rb +94 -0
  219. data/lib/rdoc/discover.rb +20 -0
  220. data/lib/rdoc_plugin/parser.rb +163 -0
  221. data/rbs-relaxed.gemspec +48 -0
  222. data/schema/annotation.json +14 -0
  223. data/schema/comment.json +26 -0
  224. data/schema/decls.json +326 -0
  225. data/schema/function.json +87 -0
  226. data/schema/location.json +56 -0
  227. data/schema/members.json +266 -0
  228. data/schema/methodType.json +50 -0
  229. data/schema/typeParam.json +36 -0
  230. data/schema/types.json +317 -0
  231. data/sig/ancestor_builder.rbs +163 -0
  232. data/sig/ancestor_graph.rbs +60 -0
  233. data/sig/annotate/annotations.rbs +102 -0
  234. data/sig/annotate/formatter.rbs +24 -0
  235. data/sig/annotate/rdoc_annotater.rbs +82 -0
  236. data/sig/annotate/rdoc_source.rbs +30 -0
  237. data/sig/annotation.rbs +27 -0
  238. data/sig/buffer.rbs +32 -0
  239. data/sig/builtin_names.rbs +44 -0
  240. data/sig/cli/colored_io.rbs +15 -0
  241. data/sig/cli/diff.rbs +21 -0
  242. data/sig/cli/validate.rbs +43 -0
  243. data/sig/cli.rbs +87 -0
  244. data/sig/collection/cleaner.rbs +13 -0
  245. data/sig/collection/config/lockfile.rbs +74 -0
  246. data/sig/collection/config/lockfile_generator.rbs +66 -0
  247. data/sig/collection/config.rbs +46 -0
  248. data/sig/collection/installer.rbs +17 -0
  249. data/sig/collection/sources.rbs +214 -0
  250. data/sig/collection.rbs +4 -0
  251. data/sig/comment.rbs +26 -0
  252. data/sig/constant.rbs +21 -0
  253. data/sig/declarations.rbs +267 -0
  254. data/sig/definition.rbs +173 -0
  255. data/sig/definition_builder.rbs +165 -0
  256. data/sig/diff.rbs +28 -0
  257. data/sig/directives.rbs +77 -0
  258. data/sig/environment.rbs +279 -0
  259. data/sig/environment_loader.rbs +111 -0
  260. data/sig/environment_walker.rbs +65 -0
  261. data/sig/errors.rbs +405 -0
  262. data/sig/factory.rbs +5 -0
  263. data/sig/file_finder.rbs +28 -0
  264. data/sig/location.rbs +110 -0
  265. data/sig/locator.rbs +58 -0
  266. data/sig/manifest.yaml +7 -0
  267. data/sig/members.rbs +258 -0
  268. data/sig/method_builder.rbs +84 -0
  269. data/sig/method_types.rbs +58 -0
  270. data/sig/namespace.rbs +146 -0
  271. data/sig/parser.rbs +100 -0
  272. data/sig/prototype/helpers.rbs +27 -0
  273. data/sig/prototype/node_usage.rbs +20 -0
  274. data/sig/prototype/rb.rbs +96 -0
  275. data/sig/prototype/rbi.rbs +75 -0
  276. data/sig/prototype/runtime.rbs +182 -0
  277. data/sig/rbs.rbs +21 -0
  278. data/sig/rdoc/rbs.rbs +67 -0
  279. data/sig/repository.rbs +85 -0
  280. data/sig/resolver/constant_resolver.rbs +92 -0
  281. data/sig/resolver/context.rbs +34 -0
  282. data/sig/resolver/type_name_resolver.rbs +35 -0
  283. data/sig/shims/bundler.rbs +38 -0
  284. data/sig/shims/enumerable.rbs +5 -0
  285. data/sig/shims/rubygems.rbs +19 -0
  286. data/sig/sorter.rbs +41 -0
  287. data/sig/substitution.rbs +48 -0
  288. data/sig/subtractor.rbs +37 -0
  289. data/sig/test/errors.rbs +52 -0
  290. data/sig/test/guranteed.rbs +9 -0
  291. data/sig/test/type_check.rbs +19 -0
  292. data/sig/test.rbs +82 -0
  293. data/sig/type_alias_dependency.rbs +53 -0
  294. data/sig/type_alias_regularity.rbs +98 -0
  295. data/sig/type_param.rbs +110 -0
  296. data/sig/typename.rbs +79 -0
  297. data/sig/types.rbs +579 -0
  298. data/sig/unit_test/convertibles.rbs +154 -0
  299. data/sig/unit_test/spy.rbs +30 -0
  300. data/sig/unit_test/type_assertions.rbs +196 -0
  301. data/sig/unit_test/with_aliases.rbs +136 -0
  302. data/sig/use_map.rbs +35 -0
  303. data/sig/util.rbs +9 -0
  304. data/sig/validator.rbs +63 -0
  305. data/sig/variance_calculator.rbs +87 -0
  306. data/sig/vendorer.rbs +51 -0
  307. data/sig/version.rbs +3 -0
  308. data/sig/visitor.rbs +47 -0
  309. data/sig/writer.rbs +127 -0
  310. data/src/constants.c +153 -0
  311. data/src/ruby_objs.c +795 -0
  312. data/src/util/rbs_constant_pool.c +342 -0
  313. data/stdlib/abbrev/0/abbrev.rbs +66 -0
  314. data/stdlib/abbrev/0/array.rbs +26 -0
  315. data/stdlib/base64/0/base64.rbs +355 -0
  316. data/stdlib/benchmark/0/benchmark.rbs +452 -0
  317. data/stdlib/bigdecimal/0/big_decimal.rbs +1629 -0
  318. data/stdlib/bigdecimal-math/0/big_math.rbs +119 -0
  319. data/stdlib/bigdecimal-math/0/manifest.yaml +2 -0
  320. data/stdlib/cgi/0/core.rbs +1285 -0
  321. data/stdlib/cgi/0/manifest.yaml +3 -0
  322. data/stdlib/coverage/0/coverage.rbs +263 -0
  323. data/stdlib/csv/0/csv.rbs +3776 -0
  324. data/stdlib/csv/0/manifest.yaml +3 -0
  325. data/stdlib/date/0/date.rbs +1585 -0
  326. data/stdlib/date/0/date_time.rbs +616 -0
  327. data/stdlib/date/0/time.rbs +26 -0
  328. data/stdlib/dbm/0/dbm.rbs +421 -0
  329. data/stdlib/delegate/0/delegator.rbs +184 -0
  330. data/stdlib/delegate/0/kernel.rbs +47 -0
  331. data/stdlib/delegate/0/simple_delegator.rbs +96 -0
  332. data/stdlib/did_you_mean/0/did_you_mean.rbs +343 -0
  333. data/stdlib/digest/0/digest.rbs +577 -0
  334. data/stdlib/erb/0/erb.rbs +532 -0
  335. data/stdlib/etc/0/etc.rbs +865 -0
  336. data/stdlib/fileutils/0/fileutils.rbs +1734 -0
  337. data/stdlib/find/0/find.rbs +49 -0
  338. data/stdlib/forwardable/0/forwardable.rbs +268 -0
  339. data/stdlib/io-console/0/io-console.rbs +414 -0
  340. data/stdlib/ipaddr/0/ipaddr.rbs +428 -0
  341. data/stdlib/json/0/json.rbs +1916 -0
  342. data/stdlib/kconv/0/kconv.rbs +166 -0
  343. data/stdlib/logger/0/formatter.rbs +45 -0
  344. data/stdlib/logger/0/log_device.rbs +100 -0
  345. data/stdlib/logger/0/logger.rbs +796 -0
  346. data/stdlib/logger/0/manifest.yaml +2 -0
  347. data/stdlib/logger/0/period.rbs +17 -0
  348. data/stdlib/logger/0/severity.rbs +34 -0
  349. data/stdlib/minitest/0/kernel.rbs +42 -0
  350. data/stdlib/minitest/0/minitest/abstract_reporter.rbs +52 -0
  351. data/stdlib/minitest/0/minitest/assertion.rbs +17 -0
  352. data/stdlib/minitest/0/minitest/assertions.rbs +590 -0
  353. data/stdlib/minitest/0/minitest/backtrace_filter.rbs +23 -0
  354. data/stdlib/minitest/0/minitest/bench_spec.rbs +102 -0
  355. data/stdlib/minitest/0/minitest/benchmark.rbs +259 -0
  356. data/stdlib/minitest/0/minitest/composite_reporter.rbs +25 -0
  357. data/stdlib/minitest/0/minitest/compress.rbs +13 -0
  358. data/stdlib/minitest/0/minitest/error_on_warning.rbs +3 -0
  359. data/stdlib/minitest/0/minitest/expectation.rbs +2 -0
  360. data/stdlib/minitest/0/minitest/expectations.rbs +21 -0
  361. data/stdlib/minitest/0/minitest/guard.rbs +64 -0
  362. data/stdlib/minitest/0/minitest/mock.rbs +64 -0
  363. data/stdlib/minitest/0/minitest/parallel/executor.rbs +46 -0
  364. data/stdlib/minitest/0/minitest/parallel/test/class_methods.rbs +5 -0
  365. data/stdlib/minitest/0/minitest/parallel/test.rbs +3 -0
  366. data/stdlib/minitest/0/minitest/parallel.rbs +2 -0
  367. data/stdlib/minitest/0/minitest/pride_io.rbs +62 -0
  368. data/stdlib/minitest/0/minitest/pride_lol.rbs +19 -0
  369. data/stdlib/minitest/0/minitest/progress_reporter.rbs +11 -0
  370. data/stdlib/minitest/0/minitest/reportable.rbs +53 -0
  371. data/stdlib/minitest/0/minitest/reporter.rbs +5 -0
  372. data/stdlib/minitest/0/minitest/result.rbs +28 -0
  373. data/stdlib/minitest/0/minitest/runnable.rbs +163 -0
  374. data/stdlib/minitest/0/minitest/skip.rbs +6 -0
  375. data/stdlib/minitest/0/minitest/spec/dsl/instance_methods.rbs +48 -0
  376. data/stdlib/minitest/0/minitest/spec/dsl.rbs +129 -0
  377. data/stdlib/minitest/0/minitest/spec.rbs +11 -0
  378. data/stdlib/minitest/0/minitest/statistics_reporter.rbs +81 -0
  379. data/stdlib/minitest/0/minitest/summary_reporter.rbs +18 -0
  380. data/stdlib/minitest/0/minitest/test/lifecycle_hooks.rbs +92 -0
  381. data/stdlib/minitest/0/minitest/test.rbs +69 -0
  382. data/stdlib/minitest/0/minitest/unexpected_error.rbs +12 -0
  383. data/stdlib/minitest/0/minitest/unexpected_warning.rbs +6 -0
  384. data/stdlib/minitest/0/minitest/unit/test_case.rbs +3 -0
  385. data/stdlib/minitest/0/minitest/unit.rbs +4 -0
  386. data/stdlib/minitest/0/minitest.rbs +115 -0
  387. data/stdlib/monitor/0/monitor.rbs +363 -0
  388. data/stdlib/mutex_m/0/mutex_m.rbs +104 -0
  389. data/stdlib/net-http/0/manifest.yaml +3 -0
  390. data/stdlib/net-http/0/net-http.rbs +5552 -0
  391. data/stdlib/net-protocol/0/manifest.yaml +2 -0
  392. data/stdlib/net-protocol/0/net-protocol.rbs +56 -0
  393. data/stdlib/net-smtp/0/manifest.yaml +2 -0
  394. data/stdlib/net-smtp/0/net-smtp.rbs +55 -0
  395. data/stdlib/nkf/0/nkf.rbs +402 -0
  396. data/stdlib/objspace/0/objspace.rbs +487 -0
  397. data/stdlib/observable/0/observable.rbs +217 -0
  398. data/stdlib/open-uri/0/manifest.yaml +4 -0
  399. data/stdlib/open-uri/0/open-uri.rbs +393 -0
  400. data/stdlib/open3/0/open3.rbs +147 -0
  401. data/stdlib/openssl/0/manifest.yaml +3 -0
  402. data/stdlib/openssl/0/openssl.rbs +12113 -0
  403. data/stdlib/optparse/0/optparse.rbs +1725 -0
  404. data/stdlib/pathname/0/pathname.rbs +1406 -0
  405. data/stdlib/pp/0/manifest.yaml +2 -0
  406. data/stdlib/pp/0/pp.rbs +300 -0
  407. data/stdlib/prettyprint/0/prettyprint.rbs +383 -0
  408. data/stdlib/pstore/0/pstore.rbs +603 -0
  409. data/stdlib/psych/0/core_ext.rbs +12 -0
  410. data/stdlib/psych/0/dbm.rbs +237 -0
  411. data/stdlib/psych/0/manifest.yaml +3 -0
  412. data/stdlib/psych/0/psych.rbs +402 -0
  413. data/stdlib/psych/0/store.rbs +59 -0
  414. data/stdlib/pty/0/pty.rbs +237 -0
  415. data/stdlib/rdoc/0/code_object.rbs +51 -0
  416. data/stdlib/rdoc/0/comment.rbs +59 -0
  417. data/stdlib/rdoc/0/context.rbs +153 -0
  418. data/stdlib/rdoc/0/markup.rbs +117 -0
  419. data/stdlib/rdoc/0/parser.rbs +56 -0
  420. data/stdlib/rdoc/0/rdoc.rbs +391 -0
  421. data/stdlib/rdoc/0/ri.rbs +17 -0
  422. data/stdlib/rdoc/0/store.rbs +48 -0
  423. data/stdlib/rdoc/0/top_level.rbs +97 -0
  424. data/stdlib/resolv/0/manifest.yaml +3 -0
  425. data/stdlib/resolv/0/resolv.rbs +1830 -0
  426. data/stdlib/ripper/0/ripper.rbs +1648 -0
  427. data/stdlib/securerandom/0/securerandom.rbs +62 -0
  428. data/stdlib/shellwords/0/shellwords.rbs +229 -0
  429. data/stdlib/singleton/0/singleton.rbs +131 -0
  430. data/stdlib/socket/0/addrinfo.rbs +666 -0
  431. data/stdlib/socket/0/basic_socket.rbs +590 -0
  432. data/stdlib/socket/0/constants.rbs +2295 -0
  433. data/stdlib/socket/0/ip_socket.rbs +92 -0
  434. data/stdlib/socket/0/socket.rbs +4157 -0
  435. data/stdlib/socket/0/socket_error.rbs +5 -0
  436. data/stdlib/socket/0/tcp_server.rbs +192 -0
  437. data/stdlib/socket/0/tcp_socket.rbs +79 -0
  438. data/stdlib/socket/0/udp_socket.rbs +133 -0
  439. data/stdlib/socket/0/unix_server.rbs +169 -0
  440. data/stdlib/socket/0/unix_socket.rbs +172 -0
  441. data/stdlib/stringio/0/stringio.rbs +567 -0
  442. data/stdlib/strscan/0/string_scanner.rbs +1627 -0
  443. data/stdlib/tempfile/0/tempfile.rbs +479 -0
  444. data/stdlib/time/0/time.rbs +432 -0
  445. data/stdlib/timeout/0/timeout.rbs +81 -0
  446. data/stdlib/tmpdir/0/tmpdir.rbs +69 -0
  447. data/stdlib/tsort/0/cyclic.rbs +5 -0
  448. data/stdlib/tsort/0/interfaces.rbs +20 -0
  449. data/stdlib/tsort/0/tsort.rbs +409 -0
  450. data/stdlib/uri/0/common.rbs +582 -0
  451. data/stdlib/uri/0/file.rbs +118 -0
  452. data/stdlib/uri/0/ftp.rbs +13 -0
  453. data/stdlib/uri/0/generic.rbs +1108 -0
  454. data/stdlib/uri/0/http.rbs +104 -0
  455. data/stdlib/uri/0/https.rbs +14 -0
  456. data/stdlib/uri/0/ldap.rbs +230 -0
  457. data/stdlib/uri/0/ldaps.rbs +14 -0
  458. data/stdlib/uri/0/mailto.rbs +92 -0
  459. data/stdlib/uri/0/rfc2396_parser.rbs +189 -0
  460. data/stdlib/uri/0/rfc3986_parser.rbs +2 -0
  461. data/stdlib/uri/0/ws.rbs +13 -0
  462. data/stdlib/uri/0/wss.rbs +9 -0
  463. data/stdlib/yaml/0/manifest.yaml +2 -0
  464. data/stdlib/yaml/0/yaml.rbs +1 -0
  465. data/stdlib/zlib/0/buf_error.rbs +10 -0
  466. data/stdlib/zlib/0/data_error.rbs +10 -0
  467. data/stdlib/zlib/0/deflate.rbs +210 -0
  468. data/stdlib/zlib/0/error.rbs +20 -0
  469. data/stdlib/zlib/0/gzip_file/crc_error.rbs +12 -0
  470. data/stdlib/zlib/0/gzip_file/error.rbs +23 -0
  471. data/stdlib/zlib/0/gzip_file/length_error.rbs +12 -0
  472. data/stdlib/zlib/0/gzip_file/no_footer.rbs +11 -0
  473. data/stdlib/zlib/0/gzip_file.rbs +156 -0
  474. data/stdlib/zlib/0/gzip_reader.rbs +293 -0
  475. data/stdlib/zlib/0/gzip_writer.rbs +166 -0
  476. data/stdlib/zlib/0/inflate.rbs +180 -0
  477. data/stdlib/zlib/0/mem_error.rbs +10 -0
  478. data/stdlib/zlib/0/need_dict.rbs +13 -0
  479. data/stdlib/zlib/0/stream_end.rbs +11 -0
  480. data/stdlib/zlib/0/stream_error.rbs +11 -0
  481. data/stdlib/zlib/0/version_error.rbs +11 -0
  482. data/stdlib/zlib/0/zlib.rbs +449 -0
  483. data/stdlib/zlib/0/zstream.rbs +200 -0
  484. metadata +532 -0
@@ -0,0 +1,342 @@
1
+ #include "rbs/util/rbs_constant_pool.h"
2
+
3
+ /**
4
+ * Initialize a list of constant ids.
5
+ */
6
+ void
7
+ rbs_constant_id_list_init(rbs_constant_id_list_t *list) {
8
+ list->ids = NULL;
9
+ list->size = 0;
10
+ list->capacity = 0;
11
+ }
12
+
13
+ /**
14
+ * Initialize a list of constant ids with a given capacity.
15
+ */
16
+ void
17
+ rbs_constant_id_list_init_capacity(rbs_constant_id_list_t *list, size_t capacity) {
18
+ list->ids = calloc(capacity, sizeof(rbs_constant_id_t));
19
+ if (list->ids == NULL) abort();
20
+
21
+ list->size = 0;
22
+ list->capacity = capacity;
23
+ }
24
+
25
+ /**
26
+ * Append a constant id to a list of constant ids. Returns false if any
27
+ * potential reallocations fail.
28
+ */
29
+ bool
30
+ rbs_constant_id_list_append(rbs_constant_id_list_t *list, rbs_constant_id_t id) {
31
+ if (list->size >= list->capacity) {
32
+ list->capacity = list->capacity == 0 ? 8 : list->capacity * 2;
33
+ list->ids = (rbs_constant_id_t *) realloc(list->ids, sizeof(rbs_constant_id_t) * list->capacity);
34
+ if (list->ids == NULL) return false;
35
+ }
36
+
37
+ list->ids[list->size++] = id;
38
+ return true;
39
+ }
40
+
41
+ /**
42
+ * Insert a constant id into a list of constant ids at the specified index.
43
+ */
44
+ void
45
+ rbs_constant_id_list_insert(rbs_constant_id_list_t *list, size_t index, rbs_constant_id_t id) {
46
+ assert(index < list->capacity);
47
+ assert(list->ids[index] == RBS_CONSTANT_ID_UNSET);
48
+
49
+ list->ids[index] = id;
50
+ list->size++;
51
+ }
52
+
53
+ /**
54
+ * Checks if the current constant id list includes the given constant id.
55
+ */
56
+ bool
57
+ rbs_constant_id_list_includes(rbs_constant_id_list_t *list, rbs_constant_id_t id) {
58
+ for (size_t index = 0; index < list->size; index++) {
59
+ if (list->ids[index] == id) return true;
60
+ }
61
+ return false;
62
+ }
63
+
64
+ /**
65
+ * Free the memory associated with a list of constant ids.
66
+ */
67
+ void
68
+ rbs_constant_id_list_free(rbs_constant_id_list_t *list) {
69
+ if (list->ids != NULL) {
70
+ free(list->ids);
71
+ }
72
+ }
73
+
74
+ /**
75
+ * A relatively simple hash function (djb2) that is used to hash strings. We are
76
+ * optimizing here for simplicity and speed.
77
+ */
78
+ static inline uint32_t
79
+ rbs_constant_pool_hash(const uint8_t *start, size_t length) {
80
+ // This is a prime number used as the initial value for the hash function.
81
+ uint32_t value = 5381;
82
+
83
+ for (size_t index = 0; index < length; index++) {
84
+ value = ((value << 5) + value) + start[index];
85
+ }
86
+
87
+ return value;
88
+ }
89
+
90
+ /**
91
+ * https://graphics.stanford.edu/~seander/bithacks.html#RoundUpPowerOf2
92
+ */
93
+ static uint32_t
94
+ next_power_of_two(uint32_t v) {
95
+ // Avoid underflow in subtraction on next line.
96
+ if (v == 0) {
97
+ // 1 is the nearest power of 2 to 0 (2^0)
98
+ return 1;
99
+ }
100
+ v--;
101
+ v |= v >> 1;
102
+ v |= v >> 2;
103
+ v |= v >> 4;
104
+ v |= v >> 8;
105
+ v |= v >> 16;
106
+ v++;
107
+ return v;
108
+ }
109
+
110
+ #ifndef NDEBUG
111
+ static bool
112
+ is_power_of_two(uint32_t size) {
113
+ return (size & (size - 1)) == 0;
114
+ }
115
+ #endif
116
+
117
+ /**
118
+ * Resize a constant pool to a given capacity.
119
+ */
120
+ static inline bool
121
+ rbs_constant_pool_resize(rbs_constant_pool_t *pool) {
122
+ assert(is_power_of_two(pool->capacity));
123
+
124
+ uint32_t next_capacity = pool->capacity * 2;
125
+ if (next_capacity < pool->capacity) return false;
126
+
127
+ const uint32_t mask = next_capacity - 1;
128
+ const size_t element_size = sizeof(rbs_constant_pool_bucket_t) + sizeof(rbs_constant_t);
129
+
130
+ void *next = calloc(next_capacity, element_size);
131
+ if (next == NULL) return false;
132
+
133
+ rbs_constant_pool_bucket_t *next_buckets = next;
134
+ rbs_constant_t *next_constants = (void *)(((char *) next) + next_capacity * sizeof(rbs_constant_pool_bucket_t));
135
+
136
+ // For each bucket in the current constant pool, find the index in the
137
+ // next constant pool, and insert it.
138
+ for (uint32_t index = 0; index < pool->capacity; index++) {
139
+ rbs_constant_pool_bucket_t *bucket = &pool->buckets[index];
140
+
141
+ // If an id is set on this constant, then we know we have content here.
142
+ // In this case we need to insert it into the next constant pool.
143
+ if (bucket->id != RBS_CONSTANT_ID_UNSET) {
144
+ uint32_t next_index = bucket->hash & mask;
145
+
146
+ // This implements linear scanning to find the next available slot
147
+ // in case this index is already taken. We don't need to bother
148
+ // comparing the values since we know that the hash is unique.
149
+ while (next_buckets[next_index].id != RBS_CONSTANT_ID_UNSET) {
150
+ next_index = (next_index + 1) & mask;
151
+ }
152
+
153
+ // Here we copy over the entire bucket, which includes the id so
154
+ // that they are consistent between resizes.
155
+ next_buckets[next_index] = *bucket;
156
+ }
157
+ }
158
+
159
+ // The constants are stable with respect to hash table resizes.
160
+ memcpy(next_constants, pool->constants, pool->size * sizeof(rbs_constant_t));
161
+
162
+ // pool->constants and pool->buckets are allocated out of the same chunk
163
+ // of memory, with the buckets coming first.
164
+ free(pool->buckets);
165
+ pool->constants = next_constants;
166
+ pool->buckets = next_buckets;
167
+ pool->capacity = next_capacity;
168
+ return true;
169
+ }
170
+
171
+ // This storage is initialized by `Init_rbs_extension()` in `main.c`.
172
+ static rbs_constant_pool_t RBS_GLOBAL_CONSTANT_POOL_STORAGE = {};
173
+ rbs_constant_pool_t *RBS_GLOBAL_CONSTANT_POOL = &RBS_GLOBAL_CONSTANT_POOL_STORAGE;
174
+
175
+ /**
176
+ * Initialize a new constant pool with a given capacity.
177
+ */
178
+ bool
179
+ rbs_constant_pool_init(rbs_constant_pool_t *pool, uint32_t capacity) {
180
+ const uint32_t maximum = (~((uint32_t) 0));
181
+ if (capacity >= ((maximum / 2) + 1)) return false;
182
+
183
+ capacity = next_power_of_two(capacity);
184
+ const size_t element_size = sizeof(rbs_constant_pool_bucket_t) + sizeof(rbs_constant_t);
185
+ void *memory = calloc(capacity, element_size);
186
+ if (memory == NULL) return false;
187
+
188
+ pool->buckets = memory;
189
+ pool->constants = (void *)(((char *)memory) + capacity * sizeof(rbs_constant_pool_bucket_t));
190
+ pool->size = 0;
191
+ pool->capacity = capacity;
192
+ return true;
193
+ }
194
+
195
+ /**
196
+ * Return a pointer to the constant indicated by the given constant id.
197
+ */
198
+ rbs_constant_t *
199
+ rbs_constant_pool_id_to_constant(const rbs_constant_pool_t *pool, rbs_constant_id_t constant_id) {
200
+ assert(constant_id != RBS_CONSTANT_ID_UNSET && constant_id <= pool->size);
201
+ return &pool->constants[constant_id - 1];
202
+ }
203
+
204
+ /**
205
+ * Find a constant in a constant pool. Returns the id of the constant, or 0 if
206
+ * the constant is not found.
207
+ */
208
+ rbs_constant_id_t
209
+ rbs_constant_pool_find(const rbs_constant_pool_t *pool, const uint8_t *start, size_t length) {
210
+ assert(is_power_of_two(pool->capacity));
211
+ const uint32_t mask = pool->capacity - 1;
212
+
213
+ uint32_t hash = rbs_constant_pool_hash(start, length);
214
+ uint32_t index = hash & mask;
215
+ rbs_constant_pool_bucket_t *bucket;
216
+
217
+ while (bucket = &pool->buckets[index], bucket->id != RBS_CONSTANT_ID_UNSET) {
218
+ rbs_constant_t *constant = &pool->constants[bucket->id - 1];
219
+ if ((constant->length == length) && memcmp(constant->start, start, length) == 0) {
220
+ return bucket->id;
221
+ }
222
+
223
+ index = (index + 1) & mask;
224
+ }
225
+
226
+ return RBS_CONSTANT_ID_UNSET;
227
+ }
228
+
229
+ /**
230
+ * Insert a constant into a constant pool and return its index in the pool.
231
+ */
232
+ static inline rbs_constant_id_t
233
+ rbs_constant_pool_insert(rbs_constant_pool_t *pool, const uint8_t *start, size_t length, rbs_constant_pool_bucket_type_t type) {
234
+ if (pool->size >= (pool->capacity / 4 * 3)) {
235
+ if (!rbs_constant_pool_resize(pool)) return RBS_CONSTANT_ID_UNSET;
236
+ }
237
+
238
+ assert(is_power_of_two(pool->capacity));
239
+ const uint32_t mask = pool->capacity - 1;
240
+
241
+ uint32_t hash = rbs_constant_pool_hash(start, length);
242
+ uint32_t index = hash & mask;
243
+ rbs_constant_pool_bucket_t *bucket;
244
+
245
+ while (bucket = &pool->buckets[index], bucket->id != RBS_CONSTANT_ID_UNSET) {
246
+ // If there is a collision, then we need to check if the content is the
247
+ // same as the content we are trying to insert. If it is, then we can
248
+ // return the id of the existing constant.
249
+ rbs_constant_t *constant = &pool->constants[bucket->id - 1];
250
+
251
+ if ((constant->length == length) && memcmp(constant->start, start, length) == 0) {
252
+ // Since we have found a match, we need to check if this is
253
+ // attempting to insert a shared or an owned constant. We want to
254
+ // prefer shared constants since they don't require allocations.
255
+ if (type == RBS_CONSTANT_POOL_BUCKET_OWNED) {
256
+ // If we're attempting to insert an owned constant and we have
257
+ // an existing constant, then either way we don't want the given
258
+ // memory. Either it's duplicated with the existing constant or
259
+ // it's not necessary because we have a shared version.
260
+ free((void *) start);
261
+ } else if (bucket->type == RBS_CONSTANT_POOL_BUCKET_OWNED) {
262
+ // If we're attempting to insert a shared constant and the
263
+ // existing constant is owned, then we can free the owned
264
+ // constant and replace it with the shared constant.
265
+ free((void *) constant->start);
266
+ constant->start = start;
267
+ bucket->type = (unsigned int) (RBS_CONSTANT_POOL_BUCKET_DEFAULT & 0x3);
268
+ }
269
+
270
+ return bucket->id;
271
+ }
272
+
273
+ index = (index + 1) & mask;
274
+ }
275
+
276
+ // IDs are allocated starting at 1, since the value 0 denotes a non-existent
277
+ // constant.
278
+ uint32_t id = ++pool->size;
279
+ assert(pool->size < ((uint32_t) (1 << 30)));
280
+
281
+ *bucket = (rbs_constant_pool_bucket_t) {
282
+ .id = (unsigned int) (id & 0x3fffffff),
283
+ .type = (unsigned int) (type & 0x3),
284
+ .hash = hash
285
+ };
286
+
287
+ pool->constants[id - 1] = (rbs_constant_t) {
288
+ .start = start,
289
+ .length = length,
290
+ };
291
+
292
+ return id;
293
+ }
294
+
295
+ /**
296
+ * Insert a constant into a constant pool. Returns the id of the constant, or
297
+ * RBS_CONSTANT_ID_UNSET if any potential calls to resize fail.
298
+ */
299
+ rbs_constant_id_t
300
+ rbs_constant_pool_insert_shared(rbs_constant_pool_t *pool, const uint8_t *start, size_t length) {
301
+ return rbs_constant_pool_insert(pool, start, length, RBS_CONSTANT_POOL_BUCKET_DEFAULT);
302
+ }
303
+
304
+ /**
305
+ * Insert a constant into a constant pool from memory that is now owned by the
306
+ * constant pool. Returns the id of the constant, or RBS_CONSTANT_ID_UNSET if any
307
+ * potential calls to resize fail.
308
+ */
309
+ rbs_constant_id_t
310
+ rbs_constant_pool_insert_owned(rbs_constant_pool_t *pool, uint8_t *start, size_t length) {
311
+ return rbs_constant_pool_insert(pool, start, length, RBS_CONSTANT_POOL_BUCKET_OWNED);
312
+ }
313
+
314
+ /**
315
+ * Insert a constant into a constant pool from memory that is constant. Returns
316
+ * the id of the constant, or RBS_CONSTANT_ID_UNSET if any potential calls to
317
+ * resize fail.
318
+ */
319
+ rbs_constant_id_t
320
+ rbs_constant_pool_insert_constant(rbs_constant_pool_t *pool, const uint8_t *start, size_t length) {
321
+ return rbs_constant_pool_insert(pool, start, length, RBS_CONSTANT_POOL_BUCKET_CONSTANT);
322
+ }
323
+
324
+ /**
325
+ * Free the memory associated with a constant pool.
326
+ */
327
+ void
328
+ rbs_constant_pool_free(rbs_constant_pool_t *pool) {
329
+ // For each constant in the current constant pool, free the contents if the
330
+ // contents are owned.
331
+ for (uint32_t index = 0; index < pool->capacity; index++) {
332
+ rbs_constant_pool_bucket_t *bucket = &pool->buckets[index];
333
+
334
+ // If an id is set on this constant, then we know we have content here.
335
+ if (bucket->id != RBS_CONSTANT_ID_UNSET && bucket->type == RBS_CONSTANT_POOL_BUCKET_OWNED) {
336
+ rbs_constant_t *constant = &pool->constants[bucket->id - 1];
337
+ free((void *) constant->start);
338
+ }
339
+ }
340
+
341
+ free(pool->buckets);
342
+ }
@@ -0,0 +1,66 @@
1
+ # <!-- rdoc-file=lib/abbrev.rb -->
2
+ # Calculates the set of unambiguous abbreviations for a given set of strings.
3
+ #
4
+ # require 'abbrev'
5
+ # require 'pp'
6
+ #
7
+ # pp Abbrev.abbrev(['ruby'])
8
+ # #=> {"ruby"=>"ruby", "rub"=>"ruby", "ru"=>"ruby", "r"=>"ruby"}
9
+ #
10
+ # pp Abbrev.abbrev(%w{ ruby rules })
11
+ #
12
+ # *Generates:*
13
+ # { "ruby" => "ruby",
14
+ # "rub" => "ruby",
15
+ # "rules" => "rules",
16
+ # "rule" => "rules",
17
+ # "rul" => "rules" }
18
+ #
19
+ # It also provides an array core extension, Array#abbrev.
20
+ #
21
+ # pp %w{ summer winter }.abbrev
22
+ #
23
+ # *Generates:*
24
+ # { "summer" => "summer",
25
+ # "summe" => "summer",
26
+ # "summ" => "summer",
27
+ # "sum" => "summer",
28
+ # "su" => "summer",
29
+ # "s" => "summer",
30
+ # "winter" => "winter",
31
+ # "winte" => "winter",
32
+ # "wint" => "winter",
33
+ # "win" => "winter",
34
+ # "wi" => "winter",
35
+ # "w" => "winter" }
36
+ #
37
+ module Abbrev
38
+ # <!--
39
+ # rdoc-file=lib/abbrev.rb
40
+ # - abbrev(words, pattern = nil)
41
+ # -->
42
+ # Given a set of strings, calculate the set of unambiguous abbreviations for
43
+ # those strings, and return a hash where the keys are all the possible
44
+ # abbreviations and the values are the full strings.
45
+ #
46
+ # Thus, given `words` is "car" and "cone", the keys pointing to "car" would be
47
+ # "ca" and "car", while those pointing to "cone" would be "co", "con", and
48
+ # "cone".
49
+ #
50
+ # require 'abbrev'
51
+ #
52
+ # Abbrev.abbrev(%w{ car cone })
53
+ # #=> {"ca"=>"car", "con"=>"cone", "co"=>"cone", "car"=>"car", "cone"=>"cone"}
54
+ #
55
+ # The optional `pattern` parameter is a pattern or a string. Only input strings
56
+ # that match the pattern or start with the string are included in the output
57
+ # hash.
58
+ #
59
+ # Abbrev.abbrev(%w{car box cone crab}, /b/)
60
+ # #=> {"box"=>"box", "bo"=>"box", "b"=>"box", "crab" => "crab"}
61
+ #
62
+ # Abbrev.abbrev(%w{car box cone}, 'ca')
63
+ # #=> {"car"=>"car", "ca"=>"car"}
64
+ #
65
+ def self?.abbrev: (Array[String], ?String | Regexp | nil) -> Hash[String, String]
66
+ end
@@ -0,0 +1,26 @@
1
+ %a{annotate:rdoc:skip}
2
+ class Array[unchecked out Elem]
3
+ # <!--
4
+ # rdoc-file=lib/abbrev.rb
5
+ # - abbrev(pattern = nil)
6
+ # -->
7
+ # Calculates the set of unambiguous abbreviations for the strings in `self`.
8
+ #
9
+ # require 'abbrev'
10
+ # %w{ car cone }.abbrev
11
+ # #=> {"car"=>"car", "ca"=>"car", "cone"=>"cone", "con"=>"cone", "co"=>"cone"}
12
+ #
13
+ # The optional `pattern` parameter is a pattern or a string. Only input strings
14
+ # that match the pattern or start with the string are included in the output
15
+ # hash.
16
+ #
17
+ # %w{ fast boat day }.abbrev(/^.a/)
18
+ # #=> {"fast"=>"fast", "fas"=>"fast", "fa"=>"fast", "day"=>"day", "da"=>"day"}
19
+ #
20
+ # Abbrev.abbrev(%w{car box cone}, "ca")
21
+ # #=> {"car"=>"car", "ca"=>"car"}
22
+ #
23
+ # See also Abbrev.abbrev
24
+ #
25
+ def abbrev: (?String | Regexp | nil) -> Hash[String, String]
26
+ end