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.
- checksums.yaml +4 -4
- data/.clang-format +1 -0
- data/.github/workflows/c-check.yml +8 -4
- data/.github/workflows/comments.yml +3 -1
- data/.github/workflows/dependabot.yml +1 -1
- data/.github/workflows/ruby.yml +10 -0
- data/.github/workflows/rust.yml +95 -0
- data/CHANGELOG.md +323 -0
- data/Rakefile +12 -29
- data/Steepfile +1 -0
- data/config.yml +393 -37
- data/core/array.rbs +218 -188
- data/core/basic_object.rbs +9 -8
- data/core/class.rbs +6 -5
- data/core/comparable.rbs +45 -31
- data/core/complex.rbs +52 -40
- data/core/dir.rbs +57 -45
- data/core/encoding.rbs +5 -5
- data/core/enumerable.rbs +96 -91
- data/core/enumerator.rbs +4 -3
- data/core/errno.rbs +3 -2
- data/core/errors.rbs +31 -29
- data/core/exception.rbs +12 -12
- data/core/fiber.rbs +36 -36
- data/core/file.rbs +186 -113
- data/core/file_test.rbs +2 -2
- data/core/float.rbs +41 -32
- data/core/gc.rbs +78 -70
- data/core/hash.rbs +70 -60
- data/core/integer.rbs +32 -28
- data/core/io/buffer.rbs +36 -36
- data/core/io/wait.rbs +7 -7
- data/core/io.rbs +120 -135
- data/core/kernel.rbs +189 -139
- data/core/marshal.rbs +3 -3
- data/core/match_data.rbs +14 -12
- data/core/math.rbs +69 -67
- data/core/method.rbs +6 -6
- data/core/module.rbs +146 -85
- data/core/nil_class.rbs +4 -3
- data/core/numeric.rbs +35 -32
- data/core/object.rbs +6 -8
- data/core/object_space.rbs +11 -10
- data/core/pathname.rbs +131 -81
- data/core/proc.rbs +65 -33
- data/core/process.rbs +219 -201
- data/core/ractor.rbs +15 -11
- data/core/random.rbs +4 -3
- data/core/range.rbs +52 -47
- data/core/rational.rbs +5 -5
- data/core/rbs/unnamed/argf.rbs +58 -51
- data/core/rbs/unnamed/env_class.rbs +18 -13
- data/core/rbs/unnamed/main_class.rbs +123 -0
- data/core/rbs/unnamed/random.rbs +7 -5
- data/core/regexp.rbs +236 -197
- data/core/ruby.rbs +1 -1
- data/core/ruby_vm.rbs +32 -30
- data/core/rubygems/config_file.rbs +5 -5
- data/core/rubygems/errors.rbs +1 -1
- data/core/rubygems/requirement.rbs +5 -5
- data/core/rubygems/rubygems.rbs +5 -3
- data/core/set.rbs +17 -16
- data/core/signal.rbs +2 -2
- data/core/string.rbs +311 -292
- data/core/struct.rbs +26 -25
- data/core/symbol.rbs +25 -24
- data/core/thread.rbs +40 -34
- data/core/time.rbs +47 -42
- data/core/trace_point.rbs +34 -31
- data/core/true_class.rbs +2 -2
- data/core/unbound_method.rbs +10 -10
- data/core/warning.rbs +7 -7
- data/docs/collection.md +1 -1
- data/docs/config.md +171 -0
- data/docs/inline.md +110 -4
- data/docs/syntax.md +13 -12
- data/ext/rbs_extension/ast_translation.c +489 -135
- data/ext/rbs_extension/class_constants.c +8 -0
- data/ext/rbs_extension/class_constants.h +4 -0
- data/ext/rbs_extension/legacy_location.c +28 -51
- data/ext/rbs_extension/legacy_location.h +37 -0
- data/ext/rbs_extension/main.c +12 -20
- data/include/rbs/ast.h +423 -195
- data/include/rbs/lexer.h +2 -2
- data/include/rbs/location.h +25 -44
- data/include/rbs/parser.h +2 -2
- data/include/rbs/util/rbs_constant_pool.h +0 -3
- data/include/rbs.h +8 -0
- data/lib/rbs/ast/ruby/annotations.rb +157 -4
- data/lib/rbs/ast/ruby/members.rb +374 -22
- data/lib/rbs/cli/validate.rb +5 -60
- data/lib/rbs/collection/config/lockfile_generator.rb +6 -2
- data/lib/rbs/definition_builder.rb +60 -27
- data/lib/rbs/errors.rb +0 -11
- data/lib/rbs/inline_parser.rb +1 -1
- data/lib/rbs/parser_aux.rb +20 -7
- data/lib/rbs/prototype/helpers.rb +57 -0
- data/lib/rbs/prototype/rb.rb +1 -26
- data/lib/rbs/prototype/rbi.rb +1 -20
- data/lib/rbs/test/type_check.rb +3 -0
- data/lib/rbs/types.rb +62 -52
- data/lib/rbs/unit_test/type_assertions.rb +35 -8
- data/lib/rbs/version.rb +1 -1
- data/lib/rbs.rb +0 -1
- data/rbs.gemspec +1 -1
- data/rust/.gitignore +1 -0
- data/rust/Cargo.lock +378 -0
- data/rust/Cargo.toml +7 -0
- data/rust/ruby-rbs/Cargo.toml +22 -0
- data/rust/ruby-rbs/build.rs +764 -0
- data/rust/ruby-rbs/examples/locations.rs +60 -0
- data/rust/ruby-rbs/src/lib.rs +1 -0
- data/rust/ruby-rbs/src/node/mod.rs +742 -0
- data/rust/ruby-rbs/tests/sanity.rs +47 -0
- data/rust/ruby-rbs/vendor/rbs/config.yml +1 -0
- data/rust/ruby-rbs-sys/Cargo.toml +23 -0
- data/rust/ruby-rbs-sys/build.rs +204 -0
- data/rust/ruby-rbs-sys/src/lib.rs +50 -0
- data/rust/ruby-rbs-sys/vendor/rbs/include +1 -0
- data/rust/ruby-rbs-sys/vendor/rbs/src +1 -0
- data/rust/ruby-rbs-sys/wrapper.h +1 -0
- data/sig/ast/ruby/annotations.rbs +191 -4
- data/sig/ast/ruby/members.rbs +21 -1
- data/sig/cli/validate.rbs +1 -6
- data/sig/definition_builder.rbs +2 -0
- data/sig/errors.rbs +0 -8
- data/sig/method_types.rbs +1 -1
- data/sig/parser.rbs +17 -13
- data/sig/prototype/helpers.rbs +2 -0
- data/sig/types.rbs +10 -11
- data/sig/unit_test/spy.rbs +0 -8
- data/sig/unit_test/type_assertions.rbs +11 -0
- data/src/ast.c +339 -161
- data/src/lexstate.c +1 -1
- data/src/location.c +7 -47
- data/src/parser.c +674 -480
- data/src/util/rbs_constant_pool.c +0 -4
- data/stdlib/bigdecimal/0/big_decimal.rbs +16 -16
- data/stdlib/cgi-escape/0/escape.rbs +4 -4
- data/stdlib/coverage/0/coverage.rbs +4 -3
- data/stdlib/date/0/date.rbs +33 -28
- data/stdlib/date/0/date_time.rbs +24 -23
- data/stdlib/did_you_mean/0/did_you_mean.rbs +17 -16
- data/stdlib/erb/0/erb.rbs +64 -53
- data/stdlib/etc/0/etc.rbs +55 -50
- data/stdlib/fileutils/0/fileutils.rbs +138 -125
- data/stdlib/forwardable/0/forwardable.rbs +10 -10
- data/stdlib/io-console/0/io-console.rbs +2 -2
- data/stdlib/json/0/json.rbs +135 -108
- data/stdlib/monitor/0/monitor.rbs +3 -3
- data/stdlib/net-http/0/net-http.rbs +159 -134
- data/stdlib/objspace/0/objspace.rbs +8 -7
- data/stdlib/open-uri/0/open-uri.rbs +8 -8
- data/stdlib/open3/0/open3.rbs +36 -35
- data/stdlib/openssl/0/openssl.rbs +144 -129
- data/stdlib/optparse/0/optparse.rbs +18 -14
- data/stdlib/pathname/0/pathname.rbs +2 -2
- data/stdlib/pp/0/pp.rbs +9 -8
- data/stdlib/prettyprint/0/prettyprint.rbs +7 -7
- data/stdlib/pstore/0/pstore.rbs +35 -30
- data/stdlib/psych/0/psych.rbs +61 -8
- data/stdlib/psych/0/store.rbs +2 -4
- data/stdlib/pty/0/pty.rbs +9 -6
- data/stdlib/random-formatter/0/random-formatter.rbs +2 -2
- data/stdlib/ripper/0/ripper.rbs +20 -17
- data/stdlib/securerandom/0/securerandom.rbs +1 -1
- data/stdlib/shellwords/0/shellwords.rbs +2 -2
- data/stdlib/socket/0/addrinfo.rbs +7 -7
- data/stdlib/socket/0/basic_socket.rbs +3 -3
- data/stdlib/socket/0/ip_socket.rbs +10 -8
- data/stdlib/socket/0/socket.rbs +10 -9
- data/stdlib/socket/0/tcp_server.rbs +1 -1
- data/stdlib/socket/0/tcp_socket.rbs +1 -1
- data/stdlib/socket/0/udp_socket.rbs +1 -1
- data/stdlib/socket/0/unix_server.rbs +1 -1
- data/stdlib/stringio/0/stringio.rbs +55 -54
- data/stdlib/strscan/0/string_scanner.rbs +46 -44
- data/stdlib/tempfile/0/tempfile.rbs +24 -20
- data/stdlib/time/0/time.rbs +7 -5
- data/stdlib/tsort/0/tsort.rbs +7 -6
- data/stdlib/uri/0/common.rbs +26 -18
- data/stdlib/uri/0/file.rbs +2 -2
- data/stdlib/uri/0/generic.rbs +2 -2
- data/stdlib/uri/0/http.rbs +2 -2
- data/stdlib/uri/0/ldap.rbs +2 -2
- data/stdlib/uri/0/mailto.rbs +3 -3
- data/stdlib/uri/0/rfc2396_parser.rbs +6 -5
- data/stdlib/zlib/0/deflate.rbs +4 -3
- data/stdlib/zlib/0/gzip_reader.rbs +4 -4
- data/stdlib/zlib/0/gzip_writer.rbs +14 -12
- data/stdlib/zlib/0/inflate.rbs +1 -1
- data/stdlib/zlib/0/need_dict.rbs +1 -1
- metadata +23 -5
- 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,
|
|
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 =
|
|
51
|
+
.rg = r,
|
|
65
52
|
};
|
|
66
53
|
}
|
|
67
54
|
|
|
68
|
-
void rbs_loc_legacy_add_required_child(rbs_loc *loc,
|
|
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
|
-
|
|
184
|
-
|
|
185
|
-
|
|
161
|
+
rbs_loc_range rg = {
|
|
162
|
+
.start = FIX2INT(start),
|
|
163
|
+
.end = FIX2INT(end),
|
|
164
|
+
};
|
|
186
165
|
|
|
187
|
-
rbs_loc_legacy_add_required_child(loc,
|
|
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
|
-
|
|
196
|
-
|
|
197
|
-
|
|
174
|
+
rbs_loc_range rg = {
|
|
175
|
+
.start = FIX2INT(start),
|
|
176
|
+
.end = FIX2INT(end),
|
|
177
|
+
};
|
|
198
178
|
|
|
199
|
-
rbs_loc_legacy_add_optional_child(loc,
|
|
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,
|
|
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,
|
|
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
|
-
|
|
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,
|
|
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
|
|
231
|
-
|
|
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
|
-
|
|
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
|
-
|
|
222
|
+
ID id = rb_sym2id(name);
|
|
240
223
|
|
|
241
|
-
if (loc->children != NULL
|
|
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
|
-
|
|
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
|
-
|
|
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
|
* */
|
data/ext/rbs_extension/main.c
CHANGED
|
@@ -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 =
|
|
73
|
+
rbs_constant_id_t id = rbs_constant_pool_insert_owned(
|
|
72
74
|
&parser->constant_pool,
|
|
73
|
-
|
|
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,
|
|
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
|
}
|