rbs 4.0.0.dev.5 → 4.0.1.dev.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 (194) hide show
  1. checksums.yaml +4 -4
  2. data/.clang-format +1 -0
  3. data/.github/workflows/c-check.yml +8 -4
  4. data/.github/workflows/comments.yml +3 -1
  5. data/.github/workflows/dependabot.yml +1 -1
  6. data/.github/workflows/ruby.yml +10 -0
  7. data/.github/workflows/rust.yml +95 -0
  8. data/CHANGELOG.md +323 -0
  9. data/Rakefile +12 -29
  10. data/Steepfile +1 -0
  11. data/config.yml +393 -37
  12. data/core/array.rbs +218 -188
  13. data/core/basic_object.rbs +9 -8
  14. data/core/class.rbs +6 -5
  15. data/core/comparable.rbs +45 -31
  16. data/core/complex.rbs +52 -40
  17. data/core/dir.rbs +57 -45
  18. data/core/encoding.rbs +5 -5
  19. data/core/enumerable.rbs +96 -91
  20. data/core/enumerator.rbs +4 -3
  21. data/core/errno.rbs +3 -2
  22. data/core/errors.rbs +31 -29
  23. data/core/exception.rbs +12 -12
  24. data/core/fiber.rbs +36 -36
  25. data/core/file.rbs +186 -113
  26. data/core/file_test.rbs +2 -2
  27. data/core/float.rbs +41 -32
  28. data/core/gc.rbs +78 -70
  29. data/core/hash.rbs +70 -60
  30. data/core/integer.rbs +32 -28
  31. data/core/io/buffer.rbs +36 -36
  32. data/core/io/wait.rbs +7 -7
  33. data/core/io.rbs +120 -135
  34. data/core/kernel.rbs +189 -139
  35. data/core/marshal.rbs +3 -3
  36. data/core/match_data.rbs +14 -12
  37. data/core/math.rbs +69 -67
  38. data/core/method.rbs +6 -6
  39. data/core/module.rbs +146 -85
  40. data/core/nil_class.rbs +4 -3
  41. data/core/numeric.rbs +35 -32
  42. data/core/object.rbs +6 -8
  43. data/core/object_space.rbs +11 -10
  44. data/core/pathname.rbs +131 -81
  45. data/core/proc.rbs +65 -33
  46. data/core/process.rbs +219 -201
  47. data/core/ractor.rbs +15 -11
  48. data/core/random.rbs +4 -3
  49. data/core/range.rbs +52 -47
  50. data/core/rational.rbs +5 -5
  51. data/core/rbs/unnamed/argf.rbs +58 -51
  52. data/core/rbs/unnamed/env_class.rbs +18 -13
  53. data/core/rbs/unnamed/main_class.rbs +123 -0
  54. data/core/rbs/unnamed/random.rbs +7 -5
  55. data/core/regexp.rbs +236 -197
  56. data/core/ruby.rbs +1 -1
  57. data/core/ruby_vm.rbs +32 -30
  58. data/core/rubygems/config_file.rbs +5 -5
  59. data/core/rubygems/errors.rbs +1 -1
  60. data/core/rubygems/requirement.rbs +5 -5
  61. data/core/rubygems/rubygems.rbs +5 -3
  62. data/core/set.rbs +17 -16
  63. data/core/signal.rbs +2 -2
  64. data/core/string.rbs +311 -292
  65. data/core/struct.rbs +26 -25
  66. data/core/symbol.rbs +25 -24
  67. data/core/thread.rbs +40 -34
  68. data/core/time.rbs +47 -42
  69. data/core/trace_point.rbs +34 -31
  70. data/core/true_class.rbs +2 -2
  71. data/core/unbound_method.rbs +10 -10
  72. data/core/warning.rbs +7 -7
  73. data/docs/collection.md +1 -1
  74. data/docs/config.md +171 -0
  75. data/docs/inline.md +110 -4
  76. data/docs/syntax.md +13 -12
  77. data/ext/rbs_extension/ast_translation.c +489 -135
  78. data/ext/rbs_extension/class_constants.c +8 -0
  79. data/ext/rbs_extension/class_constants.h +4 -0
  80. data/ext/rbs_extension/legacy_location.c +28 -51
  81. data/ext/rbs_extension/legacy_location.h +37 -0
  82. data/ext/rbs_extension/main.c +12 -20
  83. data/include/rbs/ast.h +423 -195
  84. data/include/rbs/lexer.h +2 -2
  85. data/include/rbs/location.h +25 -44
  86. data/include/rbs/parser.h +2 -2
  87. data/include/rbs/util/rbs_constant_pool.h +0 -3
  88. data/include/rbs.h +8 -0
  89. data/lib/rbs/ast/ruby/annotations.rb +157 -4
  90. data/lib/rbs/ast/ruby/members.rb +374 -22
  91. data/lib/rbs/cli/validate.rb +5 -60
  92. data/lib/rbs/collection/config/lockfile_generator.rb +6 -2
  93. data/lib/rbs/definition_builder.rb +60 -27
  94. data/lib/rbs/errors.rb +0 -11
  95. data/lib/rbs/inline_parser.rb +1 -1
  96. data/lib/rbs/parser_aux.rb +20 -7
  97. data/lib/rbs/prototype/helpers.rb +57 -0
  98. data/lib/rbs/prototype/rb.rb +1 -26
  99. data/lib/rbs/prototype/rbi.rb +1 -20
  100. data/lib/rbs/test/type_check.rb +3 -0
  101. data/lib/rbs/types.rb +62 -52
  102. data/lib/rbs/unit_test/type_assertions.rb +35 -8
  103. data/lib/rbs/version.rb +1 -1
  104. data/lib/rbs.rb +0 -1
  105. data/rbs.gemspec +1 -1
  106. data/rust/.gitignore +1 -0
  107. data/rust/Cargo.lock +378 -0
  108. data/rust/Cargo.toml +7 -0
  109. data/rust/ruby-rbs/Cargo.toml +22 -0
  110. data/rust/ruby-rbs/build.rs +764 -0
  111. data/rust/ruby-rbs/examples/locations.rs +60 -0
  112. data/rust/ruby-rbs/src/lib.rs +1 -0
  113. data/rust/ruby-rbs/src/node/mod.rs +742 -0
  114. data/rust/ruby-rbs/tests/sanity.rs +47 -0
  115. data/rust/ruby-rbs/vendor/rbs/config.yml +1 -0
  116. data/rust/ruby-rbs-sys/Cargo.toml +23 -0
  117. data/rust/ruby-rbs-sys/build.rs +204 -0
  118. data/rust/ruby-rbs-sys/src/lib.rs +50 -0
  119. data/rust/ruby-rbs-sys/vendor/rbs/include +1 -0
  120. data/rust/ruby-rbs-sys/vendor/rbs/src +1 -0
  121. data/rust/ruby-rbs-sys/wrapper.h +1 -0
  122. data/sig/ast/ruby/annotations.rbs +191 -4
  123. data/sig/ast/ruby/members.rbs +21 -1
  124. data/sig/cli/validate.rbs +1 -6
  125. data/sig/definition_builder.rbs +2 -0
  126. data/sig/errors.rbs +0 -8
  127. data/sig/method_types.rbs +1 -1
  128. data/sig/parser.rbs +17 -13
  129. data/sig/prototype/helpers.rbs +2 -0
  130. data/sig/types.rbs +10 -11
  131. data/sig/unit_test/spy.rbs +0 -8
  132. data/sig/unit_test/type_assertions.rbs +11 -0
  133. data/src/ast.c +339 -161
  134. data/src/lexstate.c +1 -1
  135. data/src/location.c +7 -47
  136. data/src/parser.c +674 -480
  137. data/src/util/rbs_constant_pool.c +0 -4
  138. data/stdlib/bigdecimal/0/big_decimal.rbs +16 -16
  139. data/stdlib/cgi-escape/0/escape.rbs +4 -4
  140. data/stdlib/coverage/0/coverage.rbs +4 -3
  141. data/stdlib/date/0/date.rbs +33 -28
  142. data/stdlib/date/0/date_time.rbs +24 -23
  143. data/stdlib/did_you_mean/0/did_you_mean.rbs +17 -16
  144. data/stdlib/erb/0/erb.rbs +64 -53
  145. data/stdlib/etc/0/etc.rbs +55 -50
  146. data/stdlib/fileutils/0/fileutils.rbs +138 -125
  147. data/stdlib/forwardable/0/forwardable.rbs +10 -10
  148. data/stdlib/io-console/0/io-console.rbs +2 -2
  149. data/stdlib/json/0/json.rbs +135 -108
  150. data/stdlib/monitor/0/monitor.rbs +3 -3
  151. data/stdlib/net-http/0/net-http.rbs +159 -134
  152. data/stdlib/objspace/0/objspace.rbs +8 -7
  153. data/stdlib/open-uri/0/open-uri.rbs +8 -8
  154. data/stdlib/open3/0/open3.rbs +36 -35
  155. data/stdlib/openssl/0/openssl.rbs +144 -129
  156. data/stdlib/optparse/0/optparse.rbs +18 -14
  157. data/stdlib/pathname/0/pathname.rbs +2 -2
  158. data/stdlib/pp/0/pp.rbs +9 -8
  159. data/stdlib/prettyprint/0/prettyprint.rbs +7 -7
  160. data/stdlib/pstore/0/pstore.rbs +35 -30
  161. data/stdlib/psych/0/psych.rbs +61 -8
  162. data/stdlib/psych/0/store.rbs +2 -4
  163. data/stdlib/pty/0/pty.rbs +9 -6
  164. data/stdlib/random-formatter/0/random-formatter.rbs +2 -2
  165. data/stdlib/ripper/0/ripper.rbs +20 -17
  166. data/stdlib/securerandom/0/securerandom.rbs +1 -1
  167. data/stdlib/shellwords/0/shellwords.rbs +2 -2
  168. data/stdlib/socket/0/addrinfo.rbs +7 -7
  169. data/stdlib/socket/0/basic_socket.rbs +3 -3
  170. data/stdlib/socket/0/ip_socket.rbs +10 -8
  171. data/stdlib/socket/0/socket.rbs +10 -9
  172. data/stdlib/socket/0/tcp_server.rbs +1 -1
  173. data/stdlib/socket/0/tcp_socket.rbs +1 -1
  174. data/stdlib/socket/0/udp_socket.rbs +1 -1
  175. data/stdlib/socket/0/unix_server.rbs +1 -1
  176. data/stdlib/stringio/0/stringio.rbs +55 -54
  177. data/stdlib/strscan/0/string_scanner.rbs +46 -44
  178. data/stdlib/tempfile/0/tempfile.rbs +24 -20
  179. data/stdlib/time/0/time.rbs +7 -5
  180. data/stdlib/tsort/0/tsort.rbs +7 -6
  181. data/stdlib/uri/0/common.rbs +26 -18
  182. data/stdlib/uri/0/file.rbs +2 -2
  183. data/stdlib/uri/0/generic.rbs +2 -2
  184. data/stdlib/uri/0/http.rbs +2 -2
  185. data/stdlib/uri/0/ldap.rbs +2 -2
  186. data/stdlib/uri/0/mailto.rbs +3 -3
  187. data/stdlib/uri/0/rfc2396_parser.rbs +6 -5
  188. data/stdlib/zlib/0/deflate.rbs +4 -3
  189. data/stdlib/zlib/0/gzip_reader.rbs +4 -4
  190. data/stdlib/zlib/0/gzip_writer.rbs +14 -12
  191. data/stdlib/zlib/0/inflate.rbs +1 -1
  192. data/stdlib/zlib/0/need_dict.rbs +1 -1
  193. metadata +23 -5
  194. data/.github/workflows/valgrind.yml +0 -42
@@ -47,14 +47,18 @@ VALUE RBS_AST_Members_MethodDefinition_Overload;
47
47
  VALUE RBS_AST_Members_Prepend;
48
48
  VALUE RBS_AST_Members_Private;
49
49
  VALUE RBS_AST_Members_Public;
50
+ VALUE RBS_AST_Ruby_Annotations_BlockParamTypeAnnotation;
50
51
  VALUE RBS_AST_Ruby_Annotations_ClassAliasAnnotation;
51
52
  VALUE RBS_AST_Ruby_Annotations_ColonMethodTypeAnnotation;
53
+ VALUE RBS_AST_Ruby_Annotations_DoubleSplatParamTypeAnnotation;
52
54
  VALUE RBS_AST_Ruby_Annotations_InstanceVariableAnnotation;
53
55
  VALUE RBS_AST_Ruby_Annotations_MethodTypesAnnotation;
54
56
  VALUE RBS_AST_Ruby_Annotations_ModuleAliasAnnotation;
55
57
  VALUE RBS_AST_Ruby_Annotations_NodeTypeAssertion;
58
+ VALUE RBS_AST_Ruby_Annotations_ParamTypeAnnotation;
56
59
  VALUE RBS_AST_Ruby_Annotations_ReturnTypeAnnotation;
57
60
  VALUE RBS_AST_Ruby_Annotations_SkipAnnotation;
61
+ VALUE RBS_AST_Ruby_Annotations_SplatParamTypeAnnotation;
58
62
  VALUE RBS_AST_Ruby_Annotations_TypeApplicationAnnotation;
59
63
  VALUE RBS_AST_TypeParam;
60
64
  VALUE RBS_MethodType;
@@ -136,14 +140,18 @@ void rbs__init_constants(void) {
136
140
  IMPORT_CONSTANT(RBS_AST_Members_Prepend, RBS_AST_Members, "Prepend");
137
141
  IMPORT_CONSTANT(RBS_AST_Members_Private, RBS_AST_Members, "Private");
138
142
  IMPORT_CONSTANT(RBS_AST_Members_Public, RBS_AST_Members, "Public");
143
+ IMPORT_CONSTANT(RBS_AST_Ruby_Annotations_BlockParamTypeAnnotation, RBS_AST_Ruby_Annotations, "BlockParamTypeAnnotation");
139
144
  IMPORT_CONSTANT(RBS_AST_Ruby_Annotations_ClassAliasAnnotation, RBS_AST_Ruby_Annotations, "ClassAliasAnnotation");
140
145
  IMPORT_CONSTANT(RBS_AST_Ruby_Annotations_ColonMethodTypeAnnotation, RBS_AST_Ruby_Annotations, "ColonMethodTypeAnnotation");
146
+ IMPORT_CONSTANT(RBS_AST_Ruby_Annotations_DoubleSplatParamTypeAnnotation, RBS_AST_Ruby_Annotations, "DoubleSplatParamTypeAnnotation");
141
147
  IMPORT_CONSTANT(RBS_AST_Ruby_Annotations_InstanceVariableAnnotation, RBS_AST_Ruby_Annotations, "InstanceVariableAnnotation");
142
148
  IMPORT_CONSTANT(RBS_AST_Ruby_Annotations_MethodTypesAnnotation, RBS_AST_Ruby_Annotations, "MethodTypesAnnotation");
143
149
  IMPORT_CONSTANT(RBS_AST_Ruby_Annotations_ModuleAliasAnnotation, RBS_AST_Ruby_Annotations, "ModuleAliasAnnotation");
144
150
  IMPORT_CONSTANT(RBS_AST_Ruby_Annotations_NodeTypeAssertion, RBS_AST_Ruby_Annotations, "NodeTypeAssertion");
151
+ IMPORT_CONSTANT(RBS_AST_Ruby_Annotations_ParamTypeAnnotation, RBS_AST_Ruby_Annotations, "ParamTypeAnnotation");
145
152
  IMPORT_CONSTANT(RBS_AST_Ruby_Annotations_ReturnTypeAnnotation, RBS_AST_Ruby_Annotations, "ReturnTypeAnnotation");
146
153
  IMPORT_CONSTANT(RBS_AST_Ruby_Annotations_SkipAnnotation, RBS_AST_Ruby_Annotations, "SkipAnnotation");
154
+ IMPORT_CONSTANT(RBS_AST_Ruby_Annotations_SplatParamTypeAnnotation, RBS_AST_Ruby_Annotations, "SplatParamTypeAnnotation");
147
155
  IMPORT_CONSTANT(RBS_AST_Ruby_Annotations_TypeApplicationAnnotation, RBS_AST_Ruby_Annotations, "TypeApplicationAnnotation");
148
156
  IMPORT_CONSTANT(RBS_AST_TypeParam, RBS_AST, "TypeParam");
149
157
  IMPORT_CONSTANT(RBS_MethodType, RBS, "MethodType");
@@ -55,14 +55,18 @@ extern VALUE RBS_AST_Members_MethodDefinition_Overload;
55
55
  extern VALUE RBS_AST_Members_Prepend;
56
56
  extern VALUE RBS_AST_Members_Private;
57
57
  extern VALUE RBS_AST_Members_Public;
58
+ extern VALUE RBS_AST_Ruby_Annotations_BlockParamTypeAnnotation;
58
59
  extern VALUE RBS_AST_Ruby_Annotations_ClassAliasAnnotation;
59
60
  extern VALUE RBS_AST_Ruby_Annotations_ColonMethodTypeAnnotation;
61
+ extern VALUE RBS_AST_Ruby_Annotations_DoubleSplatParamTypeAnnotation;
60
62
  extern VALUE RBS_AST_Ruby_Annotations_InstanceVariableAnnotation;
61
63
  extern VALUE RBS_AST_Ruby_Annotations_MethodTypesAnnotation;
62
64
  extern VALUE RBS_AST_Ruby_Annotations_ModuleAliasAnnotation;
63
65
  extern VALUE RBS_AST_Ruby_Annotations_NodeTypeAssertion;
66
+ extern VALUE RBS_AST_Ruby_Annotations_ParamTypeAnnotation;
64
67
  extern VALUE RBS_AST_Ruby_Annotations_ReturnTypeAnnotation;
65
68
  extern VALUE RBS_AST_Ruby_Annotations_SkipAnnotation;
69
+ extern VALUE RBS_AST_Ruby_Annotations_SplatParamTypeAnnotation;
66
70
  extern VALUE RBS_AST_Ruby_Annotations_TypeApplicationAnnotation;
67
71
  extern VALUE RBS_AST_TypeParam;
68
72
  extern VALUE RBS_MethodType;
@@ -1,5 +1,6 @@
1
1
  #include "legacy_location.h"
2
2
  #include "rbs_extension.h"
3
+ #include "ruby/internal/symbol.h"
3
4
 
4
5
  #define RBS_LOC_REQUIRED_P(loc, i) ((loc)->children->required_p & (1 << (i)))
5
6
  #define RBS_LOC_OPTIONAL_P(loc, i) (!RBS_LOC_REQUIRED_P((loc), (i)))
@@ -9,19 +10,6 @@
9
10
  rbs_loc_range RBS_LOC_NULL_RANGE = { -1, -1 };
10
11
  VALUE RBS_Location;
11
12
 
12
- rbs_position_t rbs_loc_position(int char_pos) {
13
- return (rbs_position_t) { 0, char_pos, -1, -1 };
14
- }
15
-
16
- rbs_position_t rbs_loc_position3(int char_pos, int line, int column) {
17
- return (rbs_position_t) { 0, char_pos, line, column };
18
- }
19
-
20
- static rbs_loc_range rbs_new_loc_range(rbs_range_t rg) {
21
- rbs_loc_range r = { rg.start.char_pos, rg.end.char_pos };
22
- return r;
23
- }
24
-
25
13
  static void check_children_max(unsigned short n) {
26
14
  size_t max = sizeof(rbs_loc_entry_bitmap) * 8;
27
15
  if (n > max) {
@@ -34,7 +22,6 @@ void rbs_loc_legacy_alloc_children(rbs_loc *loc, unsigned short cap) {
34
22
 
35
23
  size_t s = RBS_LOC_CHILDREN_SIZE(cap);
36
24
  loc->children = (rbs_loc_children *) malloc(s);
37
-
38
25
  *loc->children = (rbs_loc_children) {
39
26
  .len = 0,
40
27
  .required_p = 0,
@@ -55,17 +42,17 @@ static void check_children_cap(rbs_loc *loc) {
55
42
  }
56
43
  }
57
44
 
58
- void rbs_loc_legacy_add_optional_child(rbs_loc *loc, rbs_constant_id_t name, rbs_range_t r) {
45
+ void rbs_loc_legacy_add_optional_child(rbs_loc *loc, ID name, rbs_loc_range r) {
59
46
  check_children_cap(loc);
60
47
 
61
48
  unsigned short i = loc->children->len++;
62
49
  loc->children->entries[i] = (rbs_loc_entry) {
63
50
  .name = name,
64
- .rg = rbs_new_loc_range(r),
51
+ .rg = r,
65
52
  };
66
53
  }
67
54
 
68
- void rbs_loc_legacy_add_required_child(rbs_loc *loc, rbs_constant_id_t name, rbs_range_t r) {
55
+ void rbs_loc_legacy_add_required_child(rbs_loc *loc, ID name, rbs_loc_range r) {
69
56
  rbs_loc_legacy_add_optional_child(loc, name, r);
70
57
 
71
58
  unsigned short last_index = loc->children->len - 1;
@@ -168,23 +155,15 @@ static VALUE location_end_pos(VALUE self) {
168
155
  return INT2FIX(loc->rg.end);
169
156
  }
170
157
 
171
- static rbs_constant_id_t rbs_constant_pool_insert_ruby_symbol(VALUE symbol) {
172
- VALUE name = rb_sym2str(symbol);
173
-
174
- // Constants inserted here will never be freed, but that's acceptable because:
175
- // 1. Most symbols passed into here will be the ones already inserted into the constant pool by `parser.c`.
176
- // 2. Methods like `add_required_child` and `add_optional_child` will usually only get called with a few different symbols.
177
- return rbs_constant_pool_insert_constant(RBS_GLOBAL_CONSTANT_POOL, (const uint8_t *) RSTRING_PTR(name), RSTRING_LEN(name));
178
- }
179
-
180
158
  static VALUE location_add_required_child(VALUE self, VALUE name, VALUE start, VALUE end) {
181
159
  rbs_loc *loc = rbs_check_location(self);
182
160
 
183
- rbs_range_t rg;
184
- rg.start = rbs_loc_position(FIX2INT(start));
185
- rg.end = rbs_loc_position(FIX2INT(end));
161
+ rbs_loc_range rg = {
162
+ .start = FIX2INT(start),
163
+ .end = FIX2INT(end),
164
+ };
186
165
 
187
- rbs_loc_legacy_add_required_child(loc, rbs_constant_pool_insert_ruby_symbol(name), rg);
166
+ rbs_loc_legacy_add_required_child(loc, rb_sym2id(name), rg);
188
167
 
189
168
  return Qnil;
190
169
  }
@@ -192,11 +171,12 @@ static VALUE location_add_required_child(VALUE self, VALUE name, VALUE start, VA
192
171
  static VALUE location_add_optional_child(VALUE self, VALUE name, VALUE start, VALUE end) {
193
172
  rbs_loc *loc = rbs_check_location(self);
194
173
 
195
- rbs_range_t rg;
196
- rg.start = rbs_loc_position(FIX2INT(start));
197
- rg.end = rbs_loc_position(FIX2INT(end));
174
+ rbs_loc_range rg = {
175
+ .start = FIX2INT(start),
176
+ .end = FIX2INT(end),
177
+ };
198
178
 
199
- rbs_loc_legacy_add_optional_child(loc, rbs_constant_pool_insert_ruby_symbol(name), rg);
179
+ rbs_loc_legacy_add_optional_child(loc, rb_sym2id(name), rg);
200
180
 
201
181
  return Qnil;
202
182
  }
@@ -204,7 +184,7 @@ static VALUE location_add_optional_child(VALUE self, VALUE name, VALUE start, VA
204
184
  static VALUE location_add_optional_no_child(VALUE self, VALUE name) {
205
185
  rbs_loc *loc = rbs_check_location(self);
206
186
 
207
- rbs_loc_legacy_add_optional_child(loc, rbs_constant_pool_insert_ruby_symbol(name), NULL_RANGE);
187
+ rbs_loc_legacy_add_optional_child(loc, rb_sym2id(name), RBS_LOC_NULL_RANGE);
208
188
 
209
189
  return Qnil;
210
190
  }
@@ -213,32 +193,35 @@ VALUE rbs_new_location(VALUE buffer, rbs_range_t rg) {
213
193
  rbs_loc *loc;
214
194
  VALUE obj = TypedData_Make_Struct(RBS_Location, rbs_loc, &location_type, loc);
215
195
 
216
- rbs_loc_init(loc, buffer, rbs_new_loc_range(rg));
196
+ rbs_loc_init(loc, buffer, (rbs_loc_range) { rg.start.char_pos, rg.end.char_pos });
217
197
 
218
198
  return obj;
219
199
  }
220
200
 
221
- static VALUE rbs_new_location_from_loc_range(VALUE buffer, rbs_loc_range rg) {
201
+ VALUE rbs_new_location2(VALUE buffer, int start_char, int end_char) {
222
202
  rbs_loc *loc;
223
203
  VALUE obj = TypedData_Make_Struct(RBS_Location, rbs_loc, &location_type, loc);
224
204
 
225
- rbs_loc_init(loc, buffer, rg);
205
+ rbs_loc_init(loc, buffer, (rbs_loc_range) { .start = start_char, .end = end_char });
226
206
 
227
207
  return obj;
228
208
  }
229
209
 
230
- static rbs_constant_id_t rbs_constant_pool_find_ruby_symbol(VALUE symbol) {
231
- VALUE name = rb_sym2str(symbol);
210
+ static VALUE rbs_new_location_from_loc_range(VALUE buffer, rbs_loc_range rg) {
211
+ rbs_loc *loc;
212
+ VALUE obj = TypedData_Make_Struct(RBS_Location, rbs_loc, &location_type, loc);
232
213
 
233
- return rbs_constant_pool_find(RBS_GLOBAL_CONSTANT_POOL, (const uint8_t *) RSTRING_PTR(name), RSTRING_LEN(name));
214
+ rbs_loc_init(loc, buffer, rg);
215
+
216
+ return obj;
234
217
  }
235
218
 
236
219
  static VALUE location_aref(VALUE self, VALUE name) {
237
220
  rbs_loc *loc = rbs_check_location(self);
238
221
 
239
- rbs_constant_id_t id = rbs_constant_pool_find_ruby_symbol(name);
222
+ ID id = rb_sym2id(name);
240
223
 
241
- if (loc->children != NULL && id != RBS_CONSTANT_ID_UNSET) {
224
+ if (loc->children != NULL) {
242
225
  for (unsigned short i = 0; i < loc->children->len; i++) {
243
226
  if (loc->children->entries[i].name == id) {
244
227
  rbs_loc_range result = loc->children->entries[i].rg;
@@ -256,10 +239,6 @@ static VALUE location_aref(VALUE self, VALUE name) {
256
239
  rb_raise(rb_eRuntimeError, "Unknown child name given: %s", RSTRING_PTR(string));
257
240
  }
258
241
 
259
- static VALUE rbs_constant_to_ruby_symbol(rbs_constant_t *constant) {
260
- return ID2SYM(rb_intern2((const char *) constant->start, constant->length));
261
- }
262
-
263
242
  static VALUE location_optional_keys(VALUE self) {
264
243
  VALUE keys = rb_ary_new();
265
244
 
@@ -271,8 +250,7 @@ static VALUE location_optional_keys(VALUE self) {
271
250
 
272
251
  for (unsigned short i = 0; i < children->len; i++) {
273
252
  if (RBS_LOC_OPTIONAL_P(loc, i)) {
274
- rbs_constant_t *key_id = rbs_constant_pool_id_to_constant(RBS_GLOBAL_CONSTANT_POOL, children->entries[i].name);
275
- VALUE key_sym = rbs_constant_to_ruby_symbol(key_id);
253
+ VALUE key_sym = rb_id2sym(children->entries[i].name);
276
254
  rb_ary_push(keys, key_sym);
277
255
  }
278
256
  }
@@ -291,8 +269,7 @@ static VALUE location_required_keys(VALUE self) {
291
269
 
292
270
  for (unsigned short i = 0; i < children->len; i++) {
293
271
  if (RBS_LOC_REQUIRED_P(loc, i)) {
294
- rbs_constant_t *key_id = rbs_constant_pool_id_to_constant(RBS_GLOBAL_CONSTANT_POOL, children->entries[i].name);
295
- VALUE key_sym = rbs_constant_to_ruby_symbol(key_id);
272
+ VALUE key_sym = rb_id2sym(children->entries[i].name);
296
273
  rb_ary_push(keys, key_sym);
297
274
  }
298
275
  }
@@ -9,11 +9,43 @@ SUPPRESS_RUBY_HEADER_DIAGNOSTICS_END
9
9
 
10
10
  #include "rbs.h"
11
11
 
12
+ /**
13
+ * Data structures for implementing RBS::Location class in Ruby.
14
+ *
15
+ * These structs support hierarchical locations, allowing sub-locations (children)
16
+ * to be stored under a main location. Each sub-location is identified by its
17
+ * name (Ruby Symbol ID).
18
+ */
19
+
12
20
  /**
13
21
  * RBS::Location class
14
22
  * */
15
23
  extern VALUE RBS_Location;
16
24
 
25
+ /**
26
+ * Range of character index for `rbs_loc` locations.
27
+ */
28
+ typedef struct {
29
+ int start;
30
+ int end;
31
+ } rbs_loc_range;
32
+
33
+ typedef struct {
34
+ ID name; /* Ruby ID for the name of the entry */
35
+ rbs_loc_range rg;
36
+ } rbs_loc_entry;
37
+
38
+ typedef unsigned int rbs_loc_entry_bitmap;
39
+
40
+ // The flexible array always allocates, but it's okay.
41
+ // This struct is not allocated when the `rbs_loc` doesn't have children.
42
+ typedef struct {
43
+ unsigned short len;
44
+ unsigned short cap;
45
+ rbs_loc_entry_bitmap required_p;
46
+ rbs_loc_entry entries[1];
47
+ } rbs_loc_children;
48
+
17
49
  typedef struct {
18
50
  VALUE buffer;
19
51
  rbs_loc_range rg;
@@ -25,6 +57,8 @@ typedef struct {
25
57
  * */
26
58
  VALUE rbs_new_location(VALUE buffer, rbs_range_t rg);
27
59
 
60
+ VALUE rbs_new_location2(VALUE buffer, int start_char, int end_char);
61
+
28
62
  /**
29
63
  * Return rbs_loc associated with the RBS::Location object.
30
64
  * */
@@ -37,6 +71,9 @@ rbs_loc *rbs_check_location(VALUE location);
37
71
  * */
38
72
  void rbs_loc_legacy_alloc_children(rbs_loc *loc, unsigned short cap);
39
73
 
74
+ void rbs_loc_legacy_add_optional_child(rbs_loc *loc, ID name, rbs_loc_range r);
75
+ void rbs_loc_legacy_add_required_child(rbs_loc *loc, ID name, rbs_loc_range r);
76
+
40
77
  /**
41
78
  * Define RBS::Location class.
42
79
  * */
@@ -67,10 +67,12 @@ static void declare_type_variables(rbs_parser_t *parser, VALUE variables, VALUE
67
67
  }
68
68
 
69
69
  VALUE name_str = rb_sym2str(symbol);
70
+ uint8_t *copied_name = (uint8_t *) malloc((size_t) RSTRING_LEN(name_str));
71
+ memcpy((void *) copied_name, RSTRING_PTR(name_str), RSTRING_LEN(name_str));
70
72
 
71
- rbs_constant_id_t id = rbs_constant_pool_insert_shared(
73
+ rbs_constant_id_t id = rbs_constant_pool_insert_owned(
72
74
  &parser->constant_pool,
73
- (const uint8_t *) RSTRING_PTR(name_str),
75
+ copied_name,
74
76
  RSTRING_LEN(name_str)
75
77
  );
76
78
 
@@ -87,6 +89,7 @@ struct parse_type_arg {
87
89
  VALUE require_eof;
88
90
  VALUE void_allowed;
89
91
  VALUE self_allowed;
92
+ VALUE classish_allowed;
90
93
  };
91
94
 
92
95
  struct parse_method_type_arg {
@@ -118,9 +121,10 @@ static VALUE parse_type_try(VALUE a) {
118
121
 
119
122
  bool void_allowed = RTEST(arg->void_allowed);
120
123
  bool self_allowed = RTEST(arg->self_allowed);
124
+ bool classish_allowed = RTEST(arg->classish_allowed);
121
125
 
122
126
  rbs_node_t *type;
123
- rbs_parse_type(parser, &type, void_allowed, self_allowed);
127
+ rbs_parse_type(parser, &type, void_allowed, self_allowed, classish_allowed);
124
128
 
125
129
  raise_error_if_any(parser, arg->buffer);
126
130
 
@@ -176,7 +180,7 @@ static rbs_parser_t *alloc_parser_from_buffer(VALUE buffer, int start_pos, int e
176
180
  );
177
181
  }
178
182
 
179
- static VALUE rbsparser_parse_type(VALUE self, VALUE buffer, VALUE start_pos, VALUE end_pos, VALUE variables, VALUE require_eof, VALUE void_allowed, VALUE self_allowed) {
183
+ static VALUE rbsparser_parse_type(VALUE self, VALUE buffer, VALUE start_pos, VALUE end_pos, VALUE variables, VALUE require_eof, VALUE void_allowed, VALUE self_allowed, VALUE classish_allowed) {
180
184
  VALUE string = rb_funcall(buffer, rb_intern("content"), 0);
181
185
  StringValue(string);
182
186
  rb_encoding *encoding = rb_enc_get(string);
@@ -189,7 +193,8 @@ static VALUE rbsparser_parse_type(VALUE self, VALUE buffer, VALUE start_pos, VAL
189
193
  .parser = parser,
190
194
  .require_eof = require_eof,
191
195
  .void_allowed = void_allowed,
192
- .self_allowed = self_allowed
196
+ .self_allowed = self_allowed,
197
+ .classish_allowed = classish_allowed
193
198
  };
194
199
 
195
200
  VALUE result = rb_ensure(parse_type_try, (VALUE) &arg, ensure_free_parser, (VALUE) parser);
@@ -208,7 +213,7 @@ static VALUE parse_method_type_try(VALUE a) {
208
213
  }
209
214
 
210
215
  rbs_method_type_t *method_type = NULL;
211
- rbs_parse_method_type(parser, &method_type, RB_TEST(arg->require_eof));
216
+ rbs_parse_method_type(parser, &method_type, RB_TEST(arg->require_eof), true);
212
217
 
213
218
  raise_error_if_any(parser, arg->buffer);
214
219
 
@@ -449,7 +454,7 @@ void rbs__init_parser(void) {
449
454
  EMPTY_HASH = rb_obj_freeze(rb_hash_new());
450
455
  rb_gc_register_mark_object(EMPTY_HASH);
451
456
 
452
- rb_define_singleton_method(RBS_Parser, "_parse_type", rbsparser_parse_type, 7);
457
+ rb_define_singleton_method(RBS_Parser, "_parse_type", rbsparser_parse_type, 8);
453
458
  rb_define_singleton_method(RBS_Parser, "_parse_method_type", rbsparser_parse_method_type, 5);
454
459
  rb_define_singleton_method(RBS_Parser, "_parse_signature", rbsparser_parse_signature, 3);
455
460
  rb_define_singleton_method(RBS_Parser, "_parse_type_params", rbsparser_parse_type_params, 4);
@@ -459,7 +464,6 @@ void rbs__init_parser(void) {
459
464
  }
460
465
 
461
466
  static void Deinit_rbs_extension(ruby_vm_t *_) {
462
- rbs_constant_pool_free(RBS_GLOBAL_CONSTANT_POOL);
463
467
  }
464
468
 
465
469
  void Init_rbs_extension(void) {
@@ -470,17 +474,5 @@ void Init_rbs_extension(void) {
470
474
  rbs__init_location();
471
475
  rbs__init_parser();
472
476
 
473
- /* Calculated based on the number of unique strings used with the `INTERN` macro in `parser.c`.
474
- *
475
- * ```bash
476
- * grep -o 'INTERN("\([^"]*\)")' ext/rbs_extension/parser.c \
477
- * | sed 's/INTERN("\(.*\)")/\1/' \
478
- * | sort -u \
479
- * | wc -l
480
- * ```
481
- */
482
- const size_t num_uniquely_interned_strings = 26;
483
- rbs_constant_pool_init(RBS_GLOBAL_CONSTANT_POOL, num_uniquely_interned_strings);
484
-
485
477
  ruby_vm_at_exit(Deinit_rbs_extension);
486
478
  }