rbs 4.0.0.dev.4 → 4.0.0

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 (281) hide show
  1. checksums.yaml +4 -4
  2. data/.github/dependabot.yml +14 -14
  3. data/.github/workflows/bundle-update.yml +60 -0
  4. data/.github/workflows/c-check.yml +18 -11
  5. data/.github/workflows/comments.yml +5 -3
  6. data/.github/workflows/dependabot.yml +2 -2
  7. data/.github/workflows/ruby.yml +27 -34
  8. data/.github/workflows/rust.yml +95 -0
  9. data/.github/workflows/typecheck.yml +2 -2
  10. data/.github/workflows/windows.yml +2 -2
  11. data/.rubocop.yml +1 -1
  12. data/CHANGELOG.md +323 -0
  13. data/README.md +1 -1
  14. data/Rakefile +43 -33
  15. data/Steepfile +1 -0
  16. data/config.yml +426 -24
  17. data/core/array.rbs +307 -227
  18. data/core/basic_object.rbs +9 -8
  19. data/core/binding.rbs +0 -2
  20. data/core/builtin.rbs +2 -2
  21. data/core/class.rbs +6 -5
  22. data/core/comparable.rbs +55 -34
  23. data/core/complex.rbs +104 -78
  24. data/core/dir.rbs +61 -49
  25. data/core/encoding.rbs +12 -15
  26. data/core/enumerable.rbs +179 -87
  27. data/core/enumerator/arithmetic_sequence.rbs +70 -0
  28. data/core/enumerator.rbs +65 -2
  29. data/core/errno.rbs +11 -2
  30. data/core/errors.rbs +58 -29
  31. data/core/exception.rbs +13 -13
  32. data/core/fiber.rbs +74 -54
  33. data/core/file.rbs +280 -177
  34. data/core/file_test.rbs +3 -3
  35. data/core/float.rbs +257 -92
  36. data/core/gc.rbs +425 -281
  37. data/core/hash.rbs +1045 -739
  38. data/core/integer.rbs +135 -137
  39. data/core/io/buffer.rbs +53 -42
  40. data/core/io/wait.rbs +13 -35
  41. data/core/io.rbs +192 -144
  42. data/core/kernel.rbs +216 -155
  43. data/core/marshal.rbs +4 -4
  44. data/core/match_data.rbs +15 -13
  45. data/core/math.rbs +107 -66
  46. data/core/method.rbs +69 -33
  47. data/core/module.rbs +244 -106
  48. data/core/nil_class.rbs +7 -6
  49. data/core/numeric.rbs +74 -63
  50. data/core/object.rbs +9 -11
  51. data/core/object_space.rbs +30 -23
  52. data/core/pathname.rbs +1322 -0
  53. data/core/proc.rbs +95 -58
  54. data/core/process.rbs +222 -202
  55. data/core/ractor.rbs +371 -515
  56. data/core/random.rbs +21 -3
  57. data/core/range.rbs +159 -57
  58. data/core/rational.rbs +60 -89
  59. data/core/rbs/unnamed/argf.rbs +60 -53
  60. data/core/rbs/unnamed/env_class.rbs +19 -14
  61. data/core/rbs/unnamed/main_class.rbs +123 -0
  62. data/core/rbs/unnamed/random.rbs +11 -118
  63. data/core/regexp.rbs +258 -214
  64. data/core/ruby.rbs +53 -0
  65. data/core/ruby_vm.rbs +38 -34
  66. data/core/rubygems/config_file.rbs +5 -5
  67. data/core/rubygems/errors.rbs +4 -71
  68. data/core/rubygems/requirement.rbs +5 -5
  69. data/core/rubygems/rubygems.rbs +16 -82
  70. data/core/rubygems/version.rbs +2 -3
  71. data/core/set.rbs +490 -360
  72. data/core/signal.rbs +26 -16
  73. data/core/string.rbs +3234 -1285
  74. data/core/struct.rbs +27 -26
  75. data/core/symbol.rbs +41 -34
  76. data/core/thread.rbs +135 -67
  77. data/core/time.rbs +81 -50
  78. data/core/trace_point.rbs +41 -35
  79. data/core/true_class.rbs +2 -2
  80. data/core/unbound_method.rbs +24 -16
  81. data/core/warning.rbs +7 -7
  82. data/docs/aliases.md +79 -0
  83. data/docs/collection.md +3 -3
  84. data/docs/config.md +171 -0
  85. data/docs/encoding.md +56 -0
  86. data/docs/gem.md +0 -1
  87. data/docs/inline.md +576 -0
  88. data/docs/sigs.md +3 -3
  89. data/docs/syntax.md +46 -16
  90. data/docs/type_fingerprint.md +21 -0
  91. data/exe/rbs +1 -1
  92. data/ext/rbs_extension/ast_translation.c +544 -116
  93. data/ext/rbs_extension/ast_translation.h +3 -0
  94. data/ext/rbs_extension/class_constants.c +16 -2
  95. data/ext/rbs_extension/class_constants.h +8 -0
  96. data/ext/rbs_extension/extconf.rb +5 -1
  97. data/ext/rbs_extension/legacy_location.c +33 -56
  98. data/ext/rbs_extension/legacy_location.h +37 -0
  99. data/ext/rbs_extension/main.c +44 -35
  100. data/include/rbs/ast.h +448 -173
  101. data/include/rbs/defines.h +27 -0
  102. data/include/rbs/lexer.h +30 -11
  103. data/include/rbs/location.h +25 -44
  104. data/include/rbs/parser.h +6 -6
  105. data/include/rbs/string.h +0 -2
  106. data/include/rbs/util/rbs_allocator.h +34 -13
  107. data/include/rbs/util/rbs_assert.h +12 -1
  108. data/include/rbs/util/rbs_constant_pool.h +0 -3
  109. data/include/rbs/util/rbs_encoding.h +2 -0
  110. data/include/rbs/util/rbs_unescape.h +2 -1
  111. data/include/rbs.h +8 -0
  112. data/lib/rbs/ast/annotation.rb +1 -1
  113. data/lib/rbs/ast/comment.rb +1 -1
  114. data/lib/rbs/ast/declarations.rb +10 -10
  115. data/lib/rbs/ast/members.rb +14 -14
  116. data/lib/rbs/ast/ruby/annotations.rb +293 -3
  117. data/lib/rbs/ast/ruby/comment_block.rb +24 -0
  118. data/lib/rbs/ast/ruby/declarations.rb +198 -3
  119. data/lib/rbs/ast/ruby/helpers/constant_helper.rb +4 -0
  120. data/lib/rbs/ast/ruby/members.rb +532 -22
  121. data/lib/rbs/ast/type_param.rb +24 -4
  122. data/lib/rbs/buffer.rb +20 -15
  123. data/lib/rbs/cli/diff.rb +16 -15
  124. data/lib/rbs/cli/validate.rb +38 -106
  125. data/lib/rbs/cli.rb +52 -19
  126. data/lib/rbs/collection/config/lockfile_generator.rb +14 -2
  127. data/lib/rbs/collection/sources/git.rb +1 -0
  128. data/lib/rbs/definition.rb +1 -1
  129. data/lib/rbs/definition_builder/ancestor_builder.rb +62 -9
  130. data/lib/rbs/definition_builder/method_builder.rb +20 -0
  131. data/lib/rbs/definition_builder.rb +147 -25
  132. data/lib/rbs/diff.rb +7 -1
  133. data/lib/rbs/environment.rb +227 -74
  134. data/lib/rbs/environment_loader.rb +0 -6
  135. data/lib/rbs/errors.rb +27 -18
  136. data/lib/rbs/inline_parser.rb +342 -6
  137. data/lib/rbs/location_aux.rb +1 -1
  138. data/lib/rbs/locator.rb +5 -1
  139. data/lib/rbs/method_type.rb +5 -3
  140. data/lib/rbs/parser_aux.rb +20 -7
  141. data/lib/rbs/prototype/helpers.rb +57 -0
  142. data/lib/rbs/prototype/rb.rb +3 -28
  143. data/lib/rbs/prototype/rbi.rb +3 -20
  144. data/lib/rbs/prototype/runtime.rb +8 -0
  145. data/lib/rbs/resolver/constant_resolver.rb +2 -2
  146. data/lib/rbs/resolver/type_name_resolver.rb +116 -38
  147. data/lib/rbs/subtractor.rb +3 -1
  148. data/lib/rbs/test/type_check.rb +19 -2
  149. data/lib/rbs/type_name.rb +1 -1
  150. data/lib/rbs/types.rb +88 -78
  151. data/lib/rbs/unit_test/type_assertions.rb +35 -8
  152. data/lib/rbs/validator.rb +2 -2
  153. data/lib/rbs/version.rb +1 -1
  154. data/lib/rbs.rb +1 -2
  155. data/lib/rdoc/discover.rb +1 -1
  156. data/lib/rdoc_plugin/parser.rb +1 -1
  157. data/rbs.gemspec +4 -3
  158. data/rust/.gitignore +1 -0
  159. data/rust/Cargo.lock +378 -0
  160. data/rust/Cargo.toml +7 -0
  161. data/rust/ruby-rbs/Cargo.toml +22 -0
  162. data/rust/ruby-rbs/build.rs +764 -0
  163. data/rust/ruby-rbs/examples/locations.rs +60 -0
  164. data/rust/ruby-rbs/src/lib.rs +1 -0
  165. data/rust/ruby-rbs/src/node/mod.rs +742 -0
  166. data/rust/ruby-rbs/tests/sanity.rs +47 -0
  167. data/rust/ruby-rbs/vendor/rbs/config.yml +1 -0
  168. data/rust/ruby-rbs-sys/Cargo.toml +23 -0
  169. data/rust/ruby-rbs-sys/build.rs +204 -0
  170. data/rust/ruby-rbs-sys/src/lib.rs +50 -0
  171. data/rust/ruby-rbs-sys/vendor/rbs/include +1 -0
  172. data/rust/ruby-rbs-sys/vendor/rbs/src +1 -0
  173. data/rust/ruby-rbs-sys/wrapper.h +1 -0
  174. data/schema/typeParam.json +17 -1
  175. data/sig/ast/ruby/annotations.rbs +315 -4
  176. data/sig/ast/ruby/comment_block.rbs +8 -0
  177. data/sig/ast/ruby/declarations.rbs +102 -4
  178. data/sig/ast/ruby/members.rbs +108 -2
  179. data/sig/cli/diff.rbs +5 -11
  180. data/sig/cli/validate.rbs +12 -8
  181. data/sig/cli.rbs +18 -18
  182. data/sig/definition.rbs +6 -1
  183. data/sig/definition_builder.rbs +2 -0
  184. data/sig/environment.rbs +70 -12
  185. data/sig/errors.rbs +13 -14
  186. data/sig/inline_parser.rbs +39 -2
  187. data/sig/locator.rbs +0 -2
  188. data/sig/manifest.yaml +0 -1
  189. data/sig/method_builder.rbs +3 -1
  190. data/sig/parser.rbs +31 -13
  191. data/sig/prototype/helpers.rbs +2 -0
  192. data/sig/resolver/type_name_resolver.rbs +35 -7
  193. data/sig/source.rbs +3 -3
  194. data/sig/type_param.rbs +13 -8
  195. data/sig/types.rbs +6 -7
  196. data/sig/unit_test/spy.rbs +0 -8
  197. data/sig/unit_test/type_assertions.rbs +11 -0
  198. data/src/ast.c +410 -153
  199. data/src/lexer.c +1392 -1313
  200. data/src/lexer.re +3 -0
  201. data/src/lexstate.c +58 -37
  202. data/src/location.c +8 -48
  203. data/src/parser.c +977 -516
  204. data/src/string.c +0 -48
  205. data/src/util/rbs_allocator.c +89 -71
  206. data/src/util/rbs_assert.c +1 -1
  207. data/src/util/rbs_buffer.c +2 -2
  208. data/src/util/rbs_constant_pool.c +10 -14
  209. data/src/util/rbs_encoding.c +4 -8
  210. data/src/util/rbs_unescape.c +56 -20
  211. data/stdlib/bigdecimal/0/big_decimal.rbs +116 -98
  212. data/stdlib/bigdecimal-math/0/big_math.rbs +169 -8
  213. data/stdlib/cgi/0/core.rbs +9 -393
  214. data/stdlib/cgi/0/manifest.yaml +1 -0
  215. data/stdlib/cgi-escape/0/escape.rbs +171 -0
  216. data/stdlib/coverage/0/coverage.rbs +7 -4
  217. data/stdlib/date/0/date.rbs +92 -79
  218. data/stdlib/date/0/date_time.rbs +25 -24
  219. data/stdlib/delegate/0/delegator.rbs +10 -7
  220. data/stdlib/did_you_mean/0/did_you_mean.rbs +17 -16
  221. data/stdlib/digest/0/digest.rbs +110 -0
  222. data/stdlib/erb/0/erb.rbs +748 -347
  223. data/stdlib/etc/0/etc.rbs +55 -50
  224. data/stdlib/fileutils/0/fileutils.rbs +158 -139
  225. data/stdlib/forwardable/0/forwardable.rbs +13 -10
  226. data/stdlib/io-console/0/io-console.rbs +2 -2
  227. data/stdlib/json/0/json.rbs +217 -136
  228. data/stdlib/monitor/0/monitor.rbs +3 -3
  229. data/stdlib/net-http/0/net-http.rbs +162 -134
  230. data/stdlib/objspace/0/objspace.rbs +17 -34
  231. data/stdlib/open-uri/0/open-uri.rbs +48 -8
  232. data/stdlib/open3/0/open3.rbs +469 -10
  233. data/stdlib/openssl/0/openssl.rbs +475 -357
  234. data/stdlib/optparse/0/optparse.rbs +26 -17
  235. data/stdlib/pathname/0/pathname.rbs +11 -1381
  236. data/stdlib/pp/0/pp.rbs +9 -8
  237. data/stdlib/prettyprint/0/prettyprint.rbs +7 -7
  238. data/stdlib/pstore/0/pstore.rbs +35 -30
  239. data/stdlib/psych/0/psych.rbs +65 -12
  240. data/stdlib/psych/0/store.rbs +2 -4
  241. data/stdlib/pty/0/pty.rbs +9 -6
  242. data/stdlib/random-formatter/0/random-formatter.rbs +277 -0
  243. data/stdlib/rdoc/0/code_object.rbs +2 -1
  244. data/stdlib/rdoc/0/parser.rbs +1 -1
  245. data/stdlib/rdoc/0/rdoc.rbs +1 -1
  246. data/stdlib/rdoc/0/store.rbs +1 -1
  247. data/stdlib/resolv/0/resolv.rbs +25 -68
  248. data/stdlib/ripper/0/ripper.rbs +22 -19
  249. data/stdlib/securerandom/0/manifest.yaml +2 -0
  250. data/stdlib/securerandom/0/securerandom.rbs +7 -20
  251. data/stdlib/shellwords/0/shellwords.rbs +2 -2
  252. data/stdlib/singleton/0/singleton.rbs +3 -0
  253. data/stdlib/socket/0/addrinfo.rbs +7 -7
  254. data/stdlib/socket/0/basic_socket.rbs +3 -3
  255. data/stdlib/socket/0/ip_socket.rbs +10 -8
  256. data/stdlib/socket/0/socket.rbs +23 -10
  257. data/stdlib/socket/0/tcp_server.rbs +1 -1
  258. data/stdlib/socket/0/tcp_socket.rbs +11 -3
  259. data/stdlib/socket/0/udp_socket.rbs +1 -1
  260. data/stdlib/socket/0/unix_server.rbs +1 -1
  261. data/stdlib/stringio/0/stringio.rbs +1177 -85
  262. data/stdlib/strscan/0/string_scanner.rbs +27 -25
  263. data/stdlib/tempfile/0/tempfile.rbs +25 -21
  264. data/stdlib/time/0/time.rbs +8 -6
  265. data/stdlib/timeout/0/timeout.rbs +63 -7
  266. data/stdlib/tsort/0/cyclic.rbs +3 -0
  267. data/stdlib/tsort/0/tsort.rbs +7 -6
  268. data/stdlib/uri/0/common.rbs +42 -20
  269. data/stdlib/uri/0/file.rbs +3 -3
  270. data/stdlib/uri/0/generic.rbs +26 -18
  271. data/stdlib/uri/0/http.rbs +2 -2
  272. data/stdlib/uri/0/ldap.rbs +2 -2
  273. data/stdlib/uri/0/mailto.rbs +3 -3
  274. data/stdlib/uri/0/rfc2396_parser.rbs +12 -12
  275. data/stdlib/zlib/0/deflate.rbs +4 -3
  276. data/stdlib/zlib/0/gzip_reader.rbs +6 -6
  277. data/stdlib/zlib/0/gzip_writer.rbs +14 -12
  278. data/stdlib/zlib/0/inflate.rbs +1 -1
  279. data/stdlib/zlib/0/need_dict.rbs +1 -1
  280. data/stdlib/zlib/0/zstream.rbs +1 -0
  281. metadata +50 -6
@@ -1,6 +1,7 @@
1
1
  # <!-- rdoc-file=ext/strscan/strscan.c -->
2
2
  # Class `StringScanner` supports processing a stored string as a stream;
3
- # this code creates a new `StringScanner` object with string `'foobarbaz'`:
3
+ # this code creates a new `StringScanner` object with string
4
+ # <code>'foobarbaz'</code>:
4
5
  # require 'strscan'
5
6
  # scanner = StringScanner.new('foobarbaz')
6
7
  #
@@ -19,16 +20,16 @@
19
20
  # ENGLISH_TEXT = 'Hello'
20
21
  #
21
22
  # Some examples here assume that certain helper methods are defined:
22
- # * `put_situation(scanner)`:
23
+ # * <code>put_situation(scanner)</code>:
23
24
  # Displays the values of the scanner's
24
25
  # methods #pos, #charpos, #rest, and #rest_size.
25
- # * `put_match_values(scanner)`:
26
+ # * <code>put_match_values(scanner)</code>:
26
27
  # Displays the scanner's [match
27
28
  # values](rdoc-ref:StringScanner@Match+Values).
28
- # * `match_values_cleared?(scanner)`:
29
+ # * <code>match_values_cleared?(scanner)</code>:
29
30
  # Returns whether the scanner's [match
30
31
  # values](rdoc-ref:StringScanner@Match+Values) are cleared.
31
- # See examples [[here]](ext/strscan/helper_methods_md.html).
32
+ # See examples at [helper methods](helper_methods.md).
32
33
  # ## The `StringScanner` Object
33
34
  # This code creates a `StringScanner` object
34
35
  # (we'll call it simply a *scanner*),
@@ -45,7 +46,7 @@
45
46
  # The scanner has:
46
47
  # * A *stored string*, which is:
47
48
  # * Initially set by StringScanner.new(string) to the given `string`
48
- # (`'foobarbaz'` in the example above).
49
+ # (<code>'foobarbaz'</code> in the example above).
49
50
  # * Modifiable by methods #string=(new_string) and #concat(more_string).
50
51
  # * Returned by method #string.
51
52
  # More at [Stored String](rdoc-ref:StringScanner@Stored+String) below.
@@ -63,7 +64,7 @@
63
64
  # which is a trailing substring of the stored string;
64
65
  # it extends from the current position to the end of the stored string:
65
66
  # * Initially set by StringScanner.new(string) to the given `string`
66
- # (`'foobarbaz'` in the example above).
67
+ # (<code>'foobarbaz'</code> in the example above).
67
68
  # * Returned by method #rest.
68
69
  # * Modified by any modification to either the stored string or the
69
70
  # position.
@@ -85,10 +86,10 @@
85
86
  # and a zero-based *character position*.
86
87
  # Each of these methods explicitly sets positions:
87
88
  # Method | Effect
88
- # ------------------------|--------------------------------------------------------
89
- # #reset |Sets both positions to zero (begining of stored string).
89
+ # ------------------------|---------------------------------------------------------
90
+ # #reset |Sets both positions to zero (beginning of stored string).
90
91
  # #terminate | Sets both positions to the end of the stored string.
91
- # #pos=(new_byte_position)| Sets byte position; adjusts character position.
92
+ # #pos=(new_byte_position)| Sets byte position; adjusts character position.
92
93
  # ### Byte Position (Position)
93
94
  # The byte position (or simply *position*)
94
95
  # is a zero-based index into the bytes in the scanner's stored string;
@@ -96,7 +97,7 @@
96
97
  # When the byte position is:
97
98
  # * Zero (at the beginning), the target substring is the entire stored string.
98
99
  # * Equal to the size of the stored string (at the end),
99
- # the target substring is the empty string `''`.
100
+ # the target substring is the empty string <code>''</code>.
100
101
  # To get or set the byte position:
101
102
  # * #pos: returns the byte position.
102
103
  # * #pos=(new_pos): sets the byte position.
@@ -120,7 +121,7 @@
120
121
  # * #charpos: the [character
121
122
  # position](rdoc-ref:StringScanner@Character+Position).
122
123
  # * #rest: the [target substring](rdoc-ref:StringScanner@Target+Substring).
123
- # * #rest_size: `rest.size`.
124
+ # * #rest_size: <code>rest.size</code>.
124
125
  # ### Character Position
125
126
  # The character position is a zero-based index into the *characters*
126
127
  # in the stored string;
@@ -159,7 +160,7 @@
159
160
  # # rest_size: 12
160
161
  #
161
162
  # ## Target Substring
162
- # The target substring is the the part of the [stored
163
+ # The target substring is the part of the [stored
163
164
  # string](rdoc-ref:StringScanner@Stored+String)
164
165
  # that extends from the current [byte
165
166
  # position](rdoc-ref:StringScanner@Byte+Position+-28Position-29) to the end of
@@ -290,7 +291,7 @@
290
291
  # generally contain the results of the most recent attempted match.
291
292
  # Each match value may be thought of as:
292
293
  # * *Clear*: Initially, or after an unsuccessful match attempt:
293
- # usually, `false`, `nil`, or `{}`.
294
+ # usually, `false`, `nil`, or <code>{}</code>.
294
295
  # * *Set*: After a successful match attempt:
295
296
  # `true`, string, array, or hash.
296
297
  # Each of these methods clears match values:
@@ -327,10 +328,10 @@
327
328
  # Method | Return After Match |Return After No Match
328
329
  # ---------------|---------------------------------------|---------------------
329
330
  # #size | Count of captured substrings. | +nil+.
330
- # #[](n) | <tt>n</tt>th captured substring. | +nil+.
331
+ # #[](n) | `n`th captured substring. | +nil+.
331
332
  # #captures | Array of all captured substrings. | +nil+.
332
333
  # #values_at(*n) |Array of specified captured substrings.| +nil+.
333
- # #named_captures| Hash of named captures. | <tt>{}</tt>.
334
+ # #named_captures| Hash of named captures. | <code>{}</code>.
334
335
  #
335
336
  # See examples below.
336
337
  # #### Match Values Examples
@@ -401,7 +402,7 @@
401
402
  # ## Fixed-Anchor Property
402
403
  # Pattern matching in `StringScanner` is the same as in Ruby's,
403
404
  # except for its fixed-anchor property,
404
- # which determines the meaning of `'\A'`:
405
+ # which determines the meaning of <code>'\A'</code>:
405
406
  # * `false` (the default): matches the current byte position.
406
407
  # scanner = StringScanner.new('foobar')
407
408
  # scanner.scan(/\A./) # => "f"
@@ -486,13 +487,13 @@ class StringScanner
486
487
  # scanner[:day] # => "12"
487
488
  # scanner[:nope] # => nil
488
489
  #
489
- # When there are no captures, only `[0]` returns non-`nil`:
490
+ # When there are no captures, only <code>[0]</code> returns non-`nil`:
490
491
  # scanner = StringScanner.new('foobarbaz')
491
492
  # scanner.exist?(/bar/)
492
493
  # scanner[0] # => "bar"
493
494
  # scanner[1] # => nil
494
495
  #
495
- # For a failed match, even `[0]` returns `nil`:
496
+ # For a failed match, even <code>[0]</code> returns `nil`:
496
497
  # scanner.scan(/nope/) # => nil
497
498
  # scanner[0] # => nil
498
499
  # scanner[1] # => nil
@@ -539,7 +540,8 @@ class StringScanner
539
540
  # - captures -> substring_array or nil
540
541
  # -->
541
542
  # Returns the array of [captured match
542
- # values](rdoc-ref:StringScanner@Captured+Match+Values) at indexes `(1..)`
543
+ # values](rdoc-ref:StringScanner@Captured+Match+Values) at indexes
544
+ # <code>(1..)</code>
543
545
  # if the most recent match attempt succeeded, or `nil` otherwise:
544
546
  # scanner = StringScanner.new('Fri Dec 12 1975 14:39')
545
547
  # scanner.captures # => nil
@@ -999,7 +1001,7 @@ class StringScanner
999
1001
  # rdoc-file=ext/strscan/strscan.c
1000
1002
  # - peek(length) -> substring
1001
1003
  # -->
1002
- # Returns the substring `string[pos, length]`;
1004
+ # Returns the substring <code>string[pos, length]</code>;
1003
1005
  # does not update [match values](rdoc-ref:StringScanner@Match+Values) or
1004
1006
  # [positions](rdoc-ref:StringScanner@Positions):
1005
1007
  # scanner = StringScanner.new('foobarbaz')
@@ -1151,7 +1153,7 @@ class StringScanner
1151
1153
  # Sets both [byte position](rdoc-ref:StringScanner@Byte+Position+-28Position-29)
1152
1154
  # and [character position](rdoc-ref:StringScanner@Character+Position) to zero,
1153
1155
  # and clears [match values](rdoc-ref:StringScanner@Match+Values);
1154
- # returns `self`:
1156
+ # returns +self+:
1155
1157
  # scanner = StringScanner.new('foobarbaz')
1156
1158
  # scanner.exist?(/bar/) # => 6
1157
1159
  # scanner.reset # => #<StringScanner 0/9 @ "fooba...">
@@ -1237,7 +1239,7 @@ class StringScanner
1237
1239
  # * Returns the matched substring.
1238
1240
  # * Increments the [byte
1239
1241
  # position](rdoc-ref:StringScanner@Byte+Position+-28Position-29) by
1240
- # `substring.bytesize`,
1242
+ # <code>substring.bytesize</code>,
1241
1243
  # and may increment the [character
1242
1244
  # position](rdoc-ref:StringScanner@Character+Position).
1243
1245
  # * Sets [match values](rdoc-ref:StringScanner@Match+Values).
@@ -1517,7 +1519,7 @@ class StringScanner
1517
1519
  # call-seq:
1518
1520
  # terminate -> self
1519
1521
  # Sets the scanner to end-of-string;
1520
- # returns `self`:
1522
+ # returns +self+:
1521
1523
  # * Sets both [positions](rdoc-ref:StringScanner@Positions) to end-of-stream.
1522
1524
  # * Clears [match values](rdoc-ref:StringScanner@Match+Values).
1523
1525
  # scanner = StringScanner.new(HIRAGANA_TEXT)
@@ -1578,7 +1580,7 @@ class StringScanner
1578
1580
  # - values_at(*specifiers) -> array_of_captures or nil
1579
1581
  # -->
1580
1582
  # Returns an array of captured substrings, or `nil` of none.
1581
- # For each `specifier`, the returned substring is `[specifier]`;
1583
+ # For each `specifier`, the returned substring is <code>[specifier]</code>;
1582
1584
  # see #[].
1583
1585
  # scanner = StringScanner.new('Fri Dec 12 1975 14:39')
1584
1586
  # pattern = /(?<wday>\w+) (?<month>\w+) (?<day>\d+) /
@@ -19,7 +19,7 @@
19
19
  # require 'tempfile'
20
20
  #
21
21
  # # Tempfile.create with a block
22
- # # The filename are choosen automatically.
22
+ # # The filename are chosen automatically.
23
23
  # # (You can specify the prefix and suffix of the filename by an optional argument.)
24
24
  # Tempfile.create {|f|
25
25
  # f.puts "foo"
@@ -159,7 +159,7 @@ class Tempfile < File
159
159
  # * Generated filename is unique in that directory.
160
160
  # * Permissions are `0600`; see [File
161
161
  # Permissions](rdoc-ref:File@File+Permissions).
162
- # * Mode is `'w+'` (read/write mode, positioned at the end).
162
+ # * Mode is <code>'w+'</code> (read/write mode, positioned at the end).
163
163
  #
164
164
  # The temporary file removal depends on the keyword argument `anonymous` and
165
165
  # whether a block is given or not. See the description about the `anonymous`
@@ -206,8 +206,8 @@ class Tempfile < File
206
206
  #
207
207
  # Tempfile.create('foo') # => #<File:/tmp/foo20220505-9795-1gok8l9>
208
208
  #
209
- # * An array of two strings `[prefix, suffix]`: the generated filename begins
210
- # with `prefix` and ends with `suffix`:
209
+ # * An array of two strings <code>[prefix, suffix]</code>: the generated
210
+ # filename begins with `prefix` and ends with `suffix`:
211
211
  #
212
212
  # Tempfile.create(%w/foo .jpg/) # => #<File:/tmp/foo20220505-17839-tnjchh.jpg>
213
213
  #
@@ -226,16 +226,19 @@ class Tempfile < File
226
226
  #
227
227
  # The keyword argument `anonymous` specifies when the file is removed.
228
228
  #
229
- # * `anonymous=false` (default) without a block: the file is not removed.
230
- # * `anonymous=false` (default) with a block: the file is removed after the
231
- # block exits.
232
- # * `anonymous=true` without a block: the file is removed before returning.
233
- # * `anonymous=true` with a block: the file is removed before the block is
234
- # called.
229
+ # * <code>anonymous=false</code> (default) without a block: the file is not
230
+ # removed.
231
+ # * <code>anonymous=false</code> (default) with a block: the file is removed
232
+ # after the block exits.
233
+ # * <code>anonymous=true</code> without a block: the file is removed before
234
+ # returning.
235
+ # * <code>anonymous=true</code> with a block: the file is removed before the
236
+ # block is called.
235
237
  #
236
- # In the first case (`anonymous=false` without a block), the file is not removed
237
- # automatically. It should be explicitly closed. It can be used to rename to the
238
- # desired filename. If the file is not needed, it should be explicitly removed.
238
+ # In the first case (<code>anonymous=false</code> without a block), the file is
239
+ # not removed automatically. It should be explicitly closed. It can be used to
240
+ # rename to the desired filename. If the file is not needed, it should be
241
+ # explicitly removed.
239
242
  #
240
243
  # The File#path method of the created file object returns the temporary
241
244
  # directory with a trailing slash when `anonymous` is true.
@@ -248,8 +251,8 @@ class Tempfile < File
248
251
  #
249
252
  # Implementation note:
250
253
  #
251
- # The keyword argument +anonymous=true+ is implemented using FILE_SHARE_DELETE
252
- # on Windows. O_TMPFILE is used on Linux.
254
+ # The keyword argument <code>anonymous=true</code> is implemented using
255
+ # `FILE_SHARE_DELETE` on Windows. `O_TMPFILE` is used on Linux.
253
256
  #
254
257
  # Related: Tempfile.new.
255
258
  #
@@ -283,7 +286,8 @@ class Tempfile < File
283
286
  #
284
287
  # The call returns the value of the block.
285
288
  #
286
- # In any case, all arguments (`*args`) will be passed to Tempfile.new.
289
+ # In any case, all arguments (<code>*args</code>) will be passed to
290
+ # Tempfile.new.
287
291
  #
288
292
  # Tempfile.open('foo', '/home/temp') do |f|
289
293
  # # ... do something with f ...
@@ -318,7 +322,7 @@ class Tempfile < File
318
322
  # - close!()
319
323
  # -->
320
324
  # Closes and unlinks (deletes) the file. Has the same effect as called
321
- # `close(true)`.
325
+ # <code>close(true)</code>.
322
326
  #
323
327
  def close!: () -> void
324
328
 
@@ -422,7 +426,7 @@ class Tempfile < File
422
426
  # If possible, consider instead using Tempfile.create, which:
423
427
  #
424
428
  # * Avoids the performance cost of delegation, incurred when Tempfile.new
425
- # calls its superclass `DelegateClass(File)`.
429
+ # calls its superclass <code>DelegateClass(File)</code>.
426
430
  # * Does not rely on a finalizer to close and unlink the file, which can be
427
431
  # unreliable.
428
432
  #
@@ -433,7 +437,7 @@ class Tempfile < File
433
437
  # * Generated filename is unique in that directory.
434
438
  # * Permissions are `0600`; see [File
435
439
  # Permissions](rdoc-ref:File@File+Permissions).
436
- # * Mode is `'w+'` (read/write mode, positioned at the end).
440
+ # * Mode is <code>'w+'</code> (read/write mode, positioned at the end).
437
441
  #
438
442
  # The underlying file is removed when the Tempfile object dies and is reclaimed
439
443
  # by the garbage collector.
@@ -454,8 +458,8 @@ class Tempfile < File
454
458
  #
455
459
  # Tempfile.new('foo') # => #<Tempfile:/tmp/foo20220505-17839-1whk2f>
456
460
  #
457
- # * An array of two strings `[prefix, suffix]`: the generated filename begins
458
- # with `prefix` and ends with `suffix`:
461
+ # * An array of two strings <code>[prefix, suffix]</code>: the generated
462
+ # filename begins with `prefix` and ends with `suffix`:
459
463
  #
460
464
  # Tempfile.new(%w/foo .jpg/) # => #<Tempfile:/tmp/foo20220505-17839-58xtfi.jpg>
461
465
  #
@@ -10,12 +10,13 @@ class Time
10
10
 
11
11
  # <!--
12
12
  # rdoc-file=lib/time.rb
13
- # - zone_offset(zone, year=self.now.year)
13
+ # - zone_offset(zone, year=nil)
14
14
  # -->
15
15
  # Return the number of seconds the specified time zone differs from UTC.
16
16
  #
17
- # Numeric time zones that include minutes, such as `-10:00` or `+1330` will
18
- # work, as will simpler hour-only time zones like `-10` or `+13`.
17
+ # Numeric time zones that include minutes, such as <code>-10:00</code> or
18
+ # <code>+1330</code> will work, as will simpler hour-only time zones like
19
+ # <code>-10</code> or <code>+13</code>.
19
20
  #
20
21
  # Textual time zones listed in ZoneOffset are also supported.
21
22
  #
@@ -120,9 +121,10 @@ class Time
120
121
  # Based on this fact, this method only understands the time zone abbreviations
121
122
  # described in RFC 822 and the system time zone, in the order named. (i.e. a
122
123
  # definition in RFC 822 overrides the system time zone definition.) The system
123
- # time zone is taken from `Time.local(year, 1, 1).zone` and `Time.local(year, 7,
124
- # 1).zone`. If the extracted time zone abbreviation does not match any of them,
125
- # it is ignored and the given time is regarded as a local time.
124
+ # time zone is taken from <code>Time.local(year, 1, 1).zone</code> and
125
+ # <code>Time.local(year, 7, 1).zone</code>. If the extracted time zone
126
+ # abbreviation does not match any of them, it is ignored and the given time is
127
+ # regarded as a local time.
126
128
  #
127
129
  # ArgumentError is raised if Date._parse cannot extract information from `date`
128
130
  # or if the Time class cannot represent specified date.
@@ -26,7 +26,7 @@ module Timeout
26
26
  # rdoc-file=lib/timeout.rb
27
27
  # - timeout(sec, klass = nil, message = nil) { |sec| ... }
28
28
  # -->
29
- # Perform an operation in a block, raising an error if it takes longer than
29
+ # Perform an operation in a block, raising an exception if it takes longer than
30
30
  # `sec` seconds to complete.
31
31
  #
32
32
  # `sec`
@@ -45,12 +45,20 @@ module Timeout
45
45
  #
46
46
  #
47
47
  # Returns the result of the block **if** the block completed before `sec`
48
- # seconds, otherwise throws an exception, based on the value of `klass`.
48
+ # seconds, otherwise raises an exception, based on the value of `klass`.
49
49
  #
50
- # The exception thrown to terminate the given block cannot be rescued inside the
51
- # block unless `klass` is given explicitly. However, the block can use ensure to
52
- # prevent the handling of the exception. For that reason, this method cannot be
53
- # relied on to enforce timeouts for untrusted blocks.
50
+ # The exception raised to terminate the given block is the given `klass`, or
51
+ # Timeout::ExitException if `klass` is not given. The reason for that behavior
52
+ # is that Timeout::Error inherits from RuntimeError and might be caught
53
+ # unexpectedly by `rescue`. Timeout::ExitException inherits from Exception so it
54
+ # will only be rescued by `rescue Exception`. Note that the
55
+ # Timeout::ExitException is translated to a Timeout::Error once it reaches the
56
+ # Timeout.timeout call, so outside that call it will be a Timeout::Error.
57
+ #
58
+ # In general, be aware that the code block may rescue the exception, and in such
59
+ # a case not respect the timeout. Also, the block can use `ensure` to prevent
60
+ # the handling of the exception. For those reasons, this method cannot be relied
61
+ # on to enforce timeouts for untrusted blocks.
54
62
  #
55
63
  # If a scheduler is defined, it will be used to handle the timeout by invoking
56
64
  # Scheduler#timeout_after.
@@ -59,11 +67,59 @@ module Timeout
59
67
  # Timeout` into your classes so they have a #timeout method, as well as a module
60
68
  # method, so you can call it directly as Timeout.timeout().
61
69
  #
70
+ # #### Ensuring the exception does not fire inside ensure blocks
71
+ #
72
+ # When using Timeout.timeout it can be desirable to ensure the timeout exception
73
+ # does not fire inside an `ensure` block. The simplest and best way to do so it
74
+ # to put the Timeout.timeout call inside the body of the begin/ensure/end:
75
+ #
76
+ # begin
77
+ # Timeout.timeout(sec) { some_long_operation }
78
+ # ensure
79
+ # cleanup # safe, cannot be interrupt by timeout
80
+ # end
81
+ #
82
+ # If that is not feasible, e.g. if there are `ensure` blocks inside
83
+ # `some_long_operation`, they need to not be interrupted by timeout, and it's
84
+ # not possible to move these ensure blocks outside, one can use
85
+ # Thread.handle_interrupt to delay the timeout exception like so:
86
+ #
87
+ # Thread.handle_interrupt(Timeout::Error => :never) {
88
+ # Timeout.timeout(sec, Timeout::Error) do
89
+ # setup # timeout cannot happen here, no matter how long it takes
90
+ # Thread.handle_interrupt(Timeout::Error => :immediate) {
91
+ # some_long_operation # timeout can happen here
92
+ # }
93
+ # ensure
94
+ # cleanup # timeout cannot happen here, no matter how long it takes
95
+ # end
96
+ # }
97
+ #
98
+ # An important thing to note is the need to pass an exception klass to
99
+ # Timeout.timeout, otherwise it does not work. Specifically, using
100
+ # +Thread.handle_interrupt(Timeout::ExitException => ...)+ is unsupported and
101
+ # causes subtle errors like raising the wrong exception outside the block, do
102
+ # not use that.
103
+ #
104
+ # Note that Thread.handle_interrupt is somewhat dangerous because if setup or
105
+ # cleanup hangs then the current thread will hang too and the timeout will never
106
+ # fire. Also note the block might run for longer than `sec` seconds: e.g.
107
+ # some_long_operation executes for `sec` seconds + whatever time cleanup takes.
108
+ #
109
+ # If you want the timeout to only happen on blocking operations one can use
110
+ # :on_blocking instead of :immediate. However, that means if the block uses no
111
+ # blocking operations after `sec` seconds, the block will not be interrupted.
112
+ # ----
113
+ # <!--
114
+ # rdoc-file=lib/timeout.rb
115
+ # - timeout(*args, &block)
116
+ # -->
117
+ #
62
118
  def self?.timeout: [T] (Numeric? sec, ?singleton(Exception) klass, ?String message) { (Numeric sec) -> T } -> T
63
119
  end
64
120
 
65
121
  # <!-- rdoc-file=lib/timeout.rb -->
66
- # Internal error raised to when a timeout is triggered.
122
+ # Internal exception raised to when a timeout is triggered.
67
123
  #
68
124
  class Timeout::ExitException < Exception
69
125
  end
@@ -1,5 +1,8 @@
1
1
  %a{annotate:rdoc:skip}
2
2
  module TSort[Node]
3
+ # <!-- rdoc-file=lib/tsort.rb -->
4
+ # Exception class to be raised when a cycle is found.
5
+ #
3
6
  class Cyclic < StandardError
4
7
  end
5
8
  end
@@ -262,9 +262,9 @@ module TSort[Node] : TSort::_Sortable[Node]
262
262
  # - each_strongly_connected_component() { |nodes| ... }
263
263
  # -->
264
264
  # The iterator version of the #strongly_connected_components method.
265
- # *`obj*.each_strongly_connected_component` is similar to
266
- # *`obj*.strongly_connected_components.each`, but modification of *obj* during
267
- # the iteration may lead to unexpected results.
265
+ # <code><em>obj</em>.each_strongly_connected_component</code> is similar to
266
+ # <code><em>obj</em>.strongly_connected_components.each</code>, but modification
267
+ # of *obj* during the iteration may lead to unexpected results.
268
268
  #
269
269
  # #each_strongly_connected_component returns `nil`.
270
270
  #
@@ -382,9 +382,10 @@ module TSort[Node] : TSort::_Sortable[Node]
382
382
  # rdoc-file=lib/tsort.rb
383
383
  # - tsort_each() { |node| ... }
384
384
  # -->
385
- # The iterator version of the #tsort method. *`obj*.tsort_each` is similar to
386
- # *`obj*.tsort.each`, but modification of *obj* during the iteration may lead to
387
- # unexpected results.
385
+ # The iterator version of the #tsort method.
386
+ # <code><em>obj</em>.tsort_each</code> is similar to
387
+ # <code><em>obj</em>.tsort.each</code>, but modification of *obj* during the
388
+ # iteration may lead to unexpected results.
388
389
  #
389
390
  # #tsort_each returns `nil`. If there is a cycle, TSort::Cyclic is raised.
390
391
  #
@@ -119,7 +119,7 @@ module URI
119
119
  # rdoc-file=lib/uri/common.rb
120
120
  # - decode_uri_component(str, enc=Encoding::UTF_8)
121
121
  # -->
122
- # Like URI.decode_www_form_component, except that `'+'` is preserved.
122
+ # Like URI.decode_www_form_component, except that <code>'+'</code> is preserved.
123
123
  #
124
124
  def self.decode_uri_component: (String str, ?encoding enc) -> String
125
125
 
@@ -131,7 +131,8 @@ module URI
131
131
  # ASCII string.
132
132
  #
133
133
  # The method may be used to decode the body of Net::HTTPResponse object `res`
134
- # for which `res['Content-Type']` is `'application/x-www-form-urlencoded'`.
134
+ # for which <code>res['Content-Type']</code> is
135
+ # <code>'application/x-www-form-urlencoded'</code>.
135
136
  #
136
137
  # The returned data is an array of 2-element subarrays; each subarray is a
137
138
  # name/value pair (both are strings). Each returned string has encoding `enc`,
@@ -175,8 +176,10 @@ module URI
175
176
  #
176
177
  # * Preserves:
177
178
  #
178
- # * Characters `'*'`, `'.'`, `'-'`, and `'_'`.
179
- # * Character in ranges `'a'..'z'`, `'A'..'Z'`, and `'0'..'9'`.
179
+ # * Characters <code>'*'</code>, <code>'.'</code>, <code>'-'</code>, and
180
+ # <code>'_'</code>.
181
+ # * Character in ranges <code>'a'..'z'</code>, <code>'A'..'Z'</code>, and
182
+ # <code>'0'..'9'</code>.
180
183
  #
181
184
  # Example:
182
185
  #
@@ -185,7 +188,7 @@ module URI
185
188
  #
186
189
  # * Converts:
187
190
  #
188
- # * Character `'+'` to character `' '`.
191
+ # * Character <code>'+'</code> to character <code>' '</code>.
189
192
  # * Each "percent notation" to an ASCII character.
190
193
  #
191
194
  # Example:
@@ -193,7 +196,7 @@ module URI
193
196
  # URI.decode_www_form_component('Here+are+some+punctuation+characters%3A+%2C%3B%3F%3A')
194
197
  # # => "Here are some punctuation characters: ,;?:"
195
198
  #
196
- # Related: URI.decode_uri_component (preserves `'+'`).
199
+ # Related: URI.decode_uri_component (preserves <code>'+'</code>).
197
200
  #
198
201
  def self.decode_www_form_component: (String str, ?encoding enc) -> String
199
202
 
@@ -201,8 +204,8 @@ module URI
201
204
  # rdoc-file=lib/uri/common.rb
202
205
  # - encode_uri_component(str, enc=nil)
203
206
  # -->
204
- # Like URI.encode_www_form_component, except that `' '` (space) is encoded as
205
- # `'%20'` (instead of `'+'`).
207
+ # Like URI.encode_www_form_component, except that <code>' '</code> (space) is
208
+ # encoded as <code>'%20'</code> (instead of <code>'+'</code>).
206
209
  #
207
210
  def self.encode_uri_component: (String str, ?encoding enc) -> String
208
211
 
@@ -214,10 +217,10 @@ module URI
214
217
  # [Enumerable](rdoc-ref:Enumerable@Enumerable+in+Ruby+Classes) `enum`.
215
218
  #
216
219
  # The result is suitable for use as form data for an HTTP request whose
217
- # `Content-Type` is `'application/x-www-form-urlencoded'`.
220
+ # <code>Content-Type</code> is <code>'application/x-www-form-urlencoded'</code>.
218
221
  #
219
222
  # The returned string consists of the elements of `enum`, each converted to one
220
- # or more URL-encoded strings, and all joined with character `'&'`.
223
+ # or more URL-encoded strings, and all joined with character <code>'&'</code>.
221
224
  #
222
225
  # Simple examples:
223
226
  #
@@ -248,7 +251,8 @@ module URI
248
251
  # URI.encode_www_form([['foo', 0], ['bar', :baz, 'bat']])
249
252
  # # => "foo=0&bar=baz"
250
253
  #
251
- # * If `ele` is an array of one element, the field is formed from `ele[0]`:
254
+ # * If `ele` is an array of one element, the field is formed from
255
+ # <code>ele[0]</code>:
252
256
  #
253
257
  # URI.encode_www_form_component(ele[0])
254
258
  #
@@ -316,8 +320,10 @@ module URI
316
320
  #
317
321
  # * Preserves:
318
322
  #
319
- # * Characters `'*'`, `'.'`, `'-'`, and `'_'`.
320
- # * Character in ranges `'a'..'z'`, `'A'..'Z'`, and `'0'..'9'`.
323
+ # * Characters <code>'*'</code>, <code>'.'</code>, <code>'-'</code>, and
324
+ # <code>'_'</code>.
325
+ # * Character in ranges <code>'a'..'z'</code>, <code>'A'..'Z'</code>, and
326
+ # <code>'0'..'9'</code>.
321
327
  #
322
328
  # Example:
323
329
  #
@@ -326,9 +332,9 @@ module URI
326
332
  #
327
333
  # * Converts:
328
334
  #
329
- # * Character `' '` to character `'+'`.
335
+ # * Character <code>' '</code> to character <code>'+'</code>.
330
336
  # * Any other character to "percent notation"; the percent notation for
331
- # character *c* is `'%%%X' % c.ord`.
337
+ # character *c* is <code>'%%%X' % c.ord</code>.
332
338
  #
333
339
  # Example:
334
340
  #
@@ -343,7 +349,8 @@ module URI
343
349
  #
344
350
  # In either case, the returned string has forced encoding Encoding::US_ASCII.
345
351
  #
346
- # Related: URI.encode_uri_component (encodes `' '` as `'%20'`).
352
+ # Related: URI.encode_uri_component (encodes <code>' '</code> as
353
+ # <code>'%20'</code>).
347
354
  #
348
355
  def self.encode_www_form_component: (_ToS str, ?encoding? enc) -> String
349
356
 
@@ -420,8 +427,8 @@ module URI
420
427
  # URI.parse('http://john.doe@www.example.com:123/forum/questions/?tag=networking&order=newest#top')
421
428
  # # => #<URI::HTTP http://john.doe@www.example.com:123/forum/questions/?tag=networking&order=newest#top>
422
429
  #
423
- # It's recommended to first ::escape string `uri` if it may contain invalid URI
424
- # characters.
430
+ # It's recommended to first URI::RFC2396_PARSER.escape string `uri` if it may
431
+ # contain invalid URI characters.
425
432
  #
426
433
  def self.parse: (_ToStr uri) -> (File | FTP | HTTP | HTTPS | LDAP | LDAPS | MailTo | WS | WSS | Generic)
427
434
 
@@ -491,7 +498,8 @@ module URI
491
498
  # Returns a new object constructed from the given `scheme`, `arguments`, and
492
499
  # `default`:
493
500
  #
494
- # * The new object is an instance of `URI.scheme_list[scheme.upcase]`.
501
+ # * The new object is an instance of
502
+ # <code>URI.scheme_list[scheme.upcase]</code>.
495
503
  # * The object is initialized by calling the class initializer using `scheme`
496
504
  # and `arguments`. See URI::Generic.new.
497
505
  #
@@ -535,6 +543,9 @@ URI::ABS_URI: Regexp
535
543
 
536
544
  URI::ABS_URI_REF: Regexp
537
545
 
546
+ # <!-- rdoc-file=lib/uri/common.rb -->
547
+ # The default parser instance.
548
+ #
538
549
  URI::DEFAULT_PARSER: URI::RFC2396_Parser
539
550
 
540
551
  URI::ESCAPED: Regexp
@@ -557,6 +568,14 @@ URI::REL_URI: Regexp
557
568
 
558
569
  URI::REL_URI_REF: Regexp
559
570
 
571
+ # <!-- rdoc-file=lib/uri/common.rb -->
572
+ # The default parser instance for RFC 2396.
573
+ #
574
+ URI::RFC2396_PARSER: URI::RFC2396_Parser
575
+
576
+ # <!-- rdoc-file=lib/uri/common.rb -->
577
+ # The default parser instance for RFC 3986.
578
+ #
560
579
  URI::RFC3986_PARSER: URI::RFC3986_Parser
561
580
 
562
581
  URI::SCHEME: Regexp
@@ -588,6 +607,7 @@ module Kernel
588
607
  # Returns a URI object derived from the given `uri`, which may be a URI string
589
608
  # or an existing URI object:
590
609
  #
610
+ # require 'uri'
591
611
  # # Returns a new URI.
592
612
  # uri = URI('http://github.com/ruby/ruby')
593
613
  # # => #<URI::HTTP http://github.com/ruby/ruby>
@@ -595,5 +615,7 @@ module Kernel
595
615
  # URI(uri)
596
616
  # # => #<URI::HTTP http://github.com/ruby/ruby>
597
617
  #
598
- def self?.URI: (URI::Generic | String uri) -> URI::Generic
618
+ # You must require 'uri' to use this method.
619
+ #
620
+ def self?.URI: (URI::Generic | string uri) -> URI::Generic
599
621
  end