rbs 3.10.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.
- checksums.yaml +4 -4
- data/.github/dependabot.yml +14 -14
- data/.github/workflows/bundle-update.yml +60 -0
- data/.github/workflows/c-check.yml +7 -5
- data/.github/workflows/comments.yml +2 -2
- data/.github/workflows/dependabot.yml +2 -2
- data/.github/workflows/ruby.yml +16 -26
- data/.github/workflows/rust.yml +95 -0
- data/.github/workflows/typecheck.yml +1 -1
- data/.github/workflows/windows.yml +2 -2
- data/.rubocop.yml +2 -2
- data/.vscode/extensions.json +5 -0
- data/.vscode/settings.json +19 -0
- data/CHANGELOG.md +202 -2
- data/Rakefile +9 -23
- data/Steepfile +2 -0
- data/config.yml +457 -13
- data/core/array.rbs +218 -188
- data/core/basic_object.rbs +9 -8
- data/core/binding.rbs +0 -2
- data/core/builtin.rbs +2 -2
- data/core/class.rbs +6 -5
- data/core/comparable.rbs +45 -31
- data/core/complex.rbs +66 -55
- data/core/dir.rbs +57 -45
- data/core/encoding.rbs +6 -6
- data/core/enumerable.rbs +105 -91
- data/core/enumerator/arithmetic_sequence.rbs +70 -0
- data/core/enumerator.rbs +24 -3
- data/core/errno.rbs +3 -2
- data/core/errors.rbs +31 -29
- data/core/exception.rbs +12 -12
- data/core/fiber.rbs +47 -36
- data/core/file.rbs +242 -169
- data/core/file_test.rbs +2 -2
- data/core/float.rbs +42 -68
- data/core/gc.rbs +78 -70
- data/core/hash.rbs +70 -60
- data/core/integer.rbs +32 -75
- data/core/io/buffer.rbs +36 -36
- data/core/io/wait.rbs +7 -7
- data/core/io.rbs +192 -146
- data/core/kernel.rbs +198 -147
- data/core/marshal.rbs +3 -3
- data/core/match_data.rbs +14 -12
- data/core/math.rbs +69 -67
- data/core/method.rbs +6 -8
- data/core/module.rbs +148 -88
- data/core/nil_class.rbs +4 -3
- data/core/numeric.rbs +53 -50
- data/core/object.rbs +6 -8
- data/core/object_space.rbs +11 -10
- data/core/pathname.rbs +131 -81
- data/core/proc.rbs +65 -34
- data/core/process.rbs +221 -201
- data/core/ractor.rbs +15 -11
- data/core/random.rbs +21 -3
- data/core/range.rbs +152 -49
- data/core/rational.rbs +5 -56
- 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 -116
- 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 +318 -298
- data/core/struct.rbs +26 -25
- data/core/symbol.rbs +25 -24
- data/core/thread.rbs +40 -41
- 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 +576 -0
- data/docs/syntax.md +46 -16
- data/docs/type_fingerprint.md +21 -0
- data/exe/rbs +1 -1
- data/ext/rbs_extension/ast_translation.c +595 -98
- data/ext/rbs_extension/class_constants.c +30 -0
- data/ext/rbs_extension/class_constants.h +15 -0
- data/ext/rbs_extension/legacy_location.c +30 -53
- data/ext/rbs_extension/legacy_location.h +37 -0
- data/ext/rbs_extension/main.c +125 -24
- data/include/rbs/ast.h +485 -150
- data/include/rbs/lexer.h +11 -4
- data/include/rbs/location.h +25 -44
- data/include/rbs/parser.h +20 -2
- data/include/rbs/util/rbs_constant_pool.h +0 -3
- data/include/rbs.h +8 -0
- data/lib/rbs/ast/annotation.rb +1 -1
- data/lib/rbs/ast/comment.rb +1 -1
- data/lib/rbs/ast/declarations.rb +10 -10
- data/lib/rbs/ast/members.rb +14 -14
- data/lib/rbs/ast/ruby/annotations.rb +409 -0
- data/lib/rbs/ast/ruby/comment_block.rb +245 -0
- data/lib/rbs/ast/ruby/declarations.rb +281 -0
- data/lib/rbs/ast/ruby/helpers/constant_helper.rb +28 -0
- data/lib/rbs/ast/ruby/helpers/location_helper.rb +15 -0
- data/lib/rbs/ast/ruby/members.rb +723 -0
- data/lib/rbs/ast/type_param.rb +24 -4
- data/lib/rbs/buffer.rb +105 -20
- data/lib/rbs/cli/diff.rb +16 -15
- data/lib/rbs/cli/validate.rb +62 -125
- data/lib/rbs/cli.rb +55 -23
- data/lib/rbs/collection/config/lockfile_generator.rb +8 -4
- data/lib/rbs/collection/sources/git.rb +1 -0
- data/lib/rbs/collection.rb +0 -1
- data/lib/rbs/definition.rb +6 -1
- data/lib/rbs/definition_builder/ancestor_builder.rb +119 -63
- data/lib/rbs/definition_builder/method_builder.rb +65 -30
- data/lib/rbs/definition_builder.rb +177 -20
- data/lib/rbs/diff.rb +7 -1
- data/lib/rbs/environment/class_entry.rb +69 -0
- data/lib/rbs/environment/module_entry.rb +66 -0
- data/lib/rbs/environment.rb +338 -155
- data/lib/rbs/environment_loader.rb +2 -2
- data/lib/rbs/errors.rb +30 -20
- data/lib/rbs/inline_parser/comment_association.rb +117 -0
- data/lib/rbs/inline_parser.rb +542 -0
- data/lib/rbs/location_aux.rb +36 -4
- data/lib/rbs/locator.rb +5 -1
- data/lib/rbs/method_type.rb +5 -3
- data/lib/rbs/namespace.rb +0 -7
- data/lib/rbs/parser_aux.rb +31 -8
- data/lib/rbs/prototype/helpers.rb +57 -0
- data/lib/rbs/prototype/rb.rb +3 -28
- data/lib/rbs/prototype/rbi.rb +3 -20
- data/lib/rbs/prototype/runtime.rb +10 -2
- data/lib/rbs/resolver/type_name_resolver.rb +0 -8
- data/lib/rbs/source.rb +99 -0
- data/lib/rbs/subtractor.rb +4 -3
- data/lib/rbs/test/type_check.rb +5 -2
- data/lib/rbs/type_name.rb +1 -8
- data/lib/rbs/types.rb +88 -78
- data/lib/rbs/unit_test/convertibles.rb +1 -0
- data/lib/rbs/unit_test/type_assertions.rb +35 -8
- data/lib/rbs/validator.rb +2 -2
- data/lib/rbs/version.rb +1 -1
- data/lib/rbs.rb +12 -1
- data/rbs.gemspec +3 -2
- 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/schema/typeParam.json +17 -1
- data/sig/ancestor_builder.rbs +1 -1
- data/sig/ast/ruby/annotations.rbs +421 -0
- data/sig/ast/ruby/comment_block.rbs +127 -0
- data/sig/ast/ruby/declarations.rbs +158 -0
- data/sig/ast/ruby/helpers/constant_helper.rbs +11 -0
- data/sig/ast/ruby/helpers/location_helper.rbs +15 -0
- data/sig/ast/ruby/members.rbs +178 -0
- data/sig/buffer.rbs +63 -5
- data/sig/cli/diff.rbs +5 -11
- data/sig/cli/validate.rbs +12 -8
- data/sig/cli.rbs +18 -18
- data/sig/definition.rbs +6 -0
- data/sig/definition_builder.rbs +3 -1
- data/sig/environment/class_entry.rbs +50 -0
- data/sig/environment/module_entry.rbs +50 -0
- data/sig/environment.rbs +37 -81
- data/sig/errors.rbs +26 -20
- data/sig/inline_parser/comment_association.rbs +71 -0
- data/sig/inline_parser.rbs +124 -0
- data/sig/location.rbs +32 -7
- data/sig/locator.rbs +0 -2
- data/sig/method_builder.rbs +9 -4
- data/sig/namespace.rbs +0 -5
- data/sig/parser.rbs +47 -13
- data/sig/prototype/helpers.rbs +2 -0
- data/sig/resolver/type_name_resolver.rbs +0 -3
- data/sig/source.rbs +48 -0
- data/sig/type_param.rbs +13 -8
- data/sig/typename.rbs +0 -5
- data/sig/types.rbs +6 -7
- data/sig/unit_test/spy.rbs +0 -8
- data/sig/unit_test/type_assertions.rbs +11 -0
- data/src/ast.c +491 -143
- data/src/lexer.c +1552 -1314
- data/src/lexer.re +7 -0
- data/src/lexstate.c +8 -1
- data/src/location.c +8 -48
- data/src/parser.c +1107 -409
- 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/digest/0/digest.rbs +110 -0
- data/stdlib/erb/0/erb.rbs +64 -53
- data/stdlib/etc/0/etc.rbs +55 -50
- data/stdlib/fileutils/0/fileutils.rbs +140 -126
- data/stdlib/forwardable/0/forwardable.rbs +10 -10
- data/stdlib/io-console/0/io-console.rbs +2 -2
- data/stdlib/json/0/json.rbs +158 -131
- 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 -30
- data/stdlib/open-uri/0/open-uri.rbs +8 -8
- data/stdlib/open3/0/open3.rbs +469 -10
- data/stdlib/openssl/0/openssl.rbs +144 -129
- data/stdlib/optparse/0/optparse.rbs +23 -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 +62 -9
- data/stdlib/psych/0/store.rbs +2 -4
- data/stdlib/pty/0/pty.rbs +9 -6
- data/stdlib/random-formatter/0/random-formatter.rbs +277 -0
- data/stdlib/rdoc/0/code_object.rbs +2 -1
- data/stdlib/rdoc/0/parser.rbs +1 -1
- data/stdlib/rdoc/0/store.rbs +1 -1
- data/stdlib/ripper/0/ripper.rbs +20 -17
- data/stdlib/securerandom/0/manifest.yaml +2 -0
- data/stdlib/securerandom/0/securerandom.rbs +7 -20
- data/stdlib/shellwords/0/shellwords.rbs +2 -2
- data/stdlib/socket/0/addrinfo.rbs +9 -9
- 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 +31 -18
- data/stdlib/uri/0/file.rbs +2 -2
- data/stdlib/uri/0/generic.rbs +9 -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 +6 -6
- 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 +66 -3
data/lib/rbs/parser_aux.rb
CHANGED
|
@@ -5,14 +5,16 @@ require_relative "parser/token"
|
|
|
5
5
|
|
|
6
6
|
module RBS
|
|
7
7
|
class Parser
|
|
8
|
-
def self.parse_type(source, range: 0..., variables: [], require_eof: false)
|
|
8
|
+
def self.parse_type(source, range: nil, byte_range: 0..., variables: [], require_eof: false, void_allowed: true, self_allowed: true, classish_allowed: true)
|
|
9
9
|
buf = buffer(source)
|
|
10
|
-
|
|
10
|
+
byte_range = byte_range(range, buf.content) if range
|
|
11
|
+
_parse_type(buf, byte_range.begin || 0, byte_range.end || buf.content.bytesize, variables, require_eof, void_allowed, self_allowed, classish_allowed)
|
|
11
12
|
end
|
|
12
13
|
|
|
13
|
-
def self.parse_method_type(source, range: 0..., variables: [], require_eof: false)
|
|
14
|
+
def self.parse_method_type(source, range: nil, byte_range: 0..., variables: [], require_eof: false)
|
|
14
15
|
buf = buffer(source)
|
|
15
|
-
|
|
16
|
+
byte_range = byte_range(range, buf.content) if range
|
|
17
|
+
_parse_method_type(buf, byte_range.begin || 0, byte_range.end || buf.content.bytesize, variables, require_eof)
|
|
16
18
|
end
|
|
17
19
|
|
|
18
20
|
def self.parse_signature(source)
|
|
@@ -25,7 +27,8 @@ module RBS
|
|
|
25
27
|
else
|
|
26
28
|
0
|
|
27
29
|
end
|
|
28
|
-
|
|
30
|
+
content = buf.content
|
|
31
|
+
dirs, decls = _parse_signature(buf, start_pos, content.bytesize)
|
|
29
32
|
|
|
30
33
|
if resolved
|
|
31
34
|
dirs = dirs.dup if dirs.frozen?
|
|
@@ -37,7 +40,7 @@ module RBS
|
|
|
37
40
|
|
|
38
41
|
def self.parse_type_params(source, module_type_params: true)
|
|
39
42
|
buf = buffer(source)
|
|
40
|
-
_parse_type_params(buf, 0, buf.
|
|
43
|
+
_parse_type_params(buf, 0, buf.content.bytesize, module_type_params)
|
|
41
44
|
end
|
|
42
45
|
|
|
43
46
|
def self.magic_comment(buf)
|
|
@@ -66,7 +69,7 @@ module RBS
|
|
|
66
69
|
|
|
67
70
|
def self.lex(source)
|
|
68
71
|
buf = buffer(source)
|
|
69
|
-
list = _lex(buf, buf.
|
|
72
|
+
list = _lex(buf, buf.content.bytesize)
|
|
70
73
|
value = list.map do |type, location|
|
|
71
74
|
Token.new(type: type, location: location)
|
|
72
75
|
end
|
|
@@ -76,7 +79,7 @@ module RBS
|
|
|
76
79
|
def self.buffer(source)
|
|
77
80
|
case source
|
|
78
81
|
when String
|
|
79
|
-
Buffer.new(content: source, name: "a.rbs")
|
|
82
|
+
Buffer.new(content: source, name: Pathname("a.rbs"))
|
|
80
83
|
when Buffer
|
|
81
84
|
source
|
|
82
85
|
end
|
|
@@ -115,5 +118,25 @@ module RBS
|
|
|
115
118
|
).each_with_object({}) do |keyword, hash| #$ Hash[String, bot]
|
|
116
119
|
hash[keyword] = _ = nil
|
|
117
120
|
end
|
|
121
|
+
|
|
122
|
+
def self.parse_inline_leading_annotation(source, range, variables: [])
|
|
123
|
+
buf = buffer(source)
|
|
124
|
+
_parse_inline_leading_annotation(buf, range.begin || 0, range.end || buf.last_position, variables)
|
|
125
|
+
end
|
|
126
|
+
|
|
127
|
+
def self.parse_inline_trailing_annotation(source, range, variables: [])
|
|
128
|
+
buf = buffer(source)
|
|
129
|
+
_parse_inline_trailing_annotation(buf, range.begin || 0, range.end || buf.last_position, variables)
|
|
130
|
+
end
|
|
131
|
+
|
|
132
|
+
def self.byte_range(char_range, content)
|
|
133
|
+
start_offset = char_range.begin
|
|
134
|
+
end_offset = char_range.end
|
|
135
|
+
|
|
136
|
+
start_prefix = content[0, start_offset] or raise if start_offset
|
|
137
|
+
end_prefix = content[0, end_offset] or raise if end_offset
|
|
138
|
+
|
|
139
|
+
start_prefix&.bytesize...end_prefix&.bytesize
|
|
140
|
+
end
|
|
118
141
|
end
|
|
119
142
|
end
|
|
@@ -5,6 +5,63 @@ module RBS
|
|
|
5
5
|
module Helpers
|
|
6
6
|
private
|
|
7
7
|
|
|
8
|
+
# Prism can't parse Ruby 3.2 code
|
|
9
|
+
if RUBY_VERSION >= "3.3"
|
|
10
|
+
def parse_comments(string, include_trailing:)
|
|
11
|
+
Prism.parse_comments(string, version: "current").yield_self do |prism_comments| # steep:ignore UnexpectedKeywordArgument
|
|
12
|
+
prism_comments.each_with_object({}) do |comment, hash| #$ Hash[Integer, AST::Comment]
|
|
13
|
+
# Skip EmbDoc comments
|
|
14
|
+
next unless comment.is_a?(Prism::InlineComment)
|
|
15
|
+
# skip like `module Foo # :nodoc:`
|
|
16
|
+
next if comment.trailing? && !include_trailing
|
|
17
|
+
|
|
18
|
+
line = comment.location.start_line
|
|
19
|
+
body = "#{comment.location.slice}\n"
|
|
20
|
+
body = body[2..-1] or raise
|
|
21
|
+
body = "\n" if body.empty?
|
|
22
|
+
|
|
23
|
+
comment = AST::Comment.new(string: body, location: nil)
|
|
24
|
+
if prev_comment = hash.delete(line - 1)
|
|
25
|
+
hash[line] = AST::Comment.new(string: prev_comment.string + comment.string,
|
|
26
|
+
location: nil)
|
|
27
|
+
else
|
|
28
|
+
hash[line] = comment
|
|
29
|
+
end
|
|
30
|
+
end
|
|
31
|
+
end
|
|
32
|
+
end
|
|
33
|
+
else
|
|
34
|
+
require "ripper"
|
|
35
|
+
def parse_comments(string, include_trailing:)
|
|
36
|
+
Ripper.lex(string).yield_self do |tokens|
|
|
37
|
+
code_lines = {} #: Hash[Integer, bool]
|
|
38
|
+
tokens.each.with_object({}) do |token, hash| #$ Hash[Integer, AST::Comment]
|
|
39
|
+
case token[1]
|
|
40
|
+
when :on_sp, :on_ignored_nl
|
|
41
|
+
# skip
|
|
42
|
+
when :on_comment
|
|
43
|
+
line = token[0][0]
|
|
44
|
+
# skip like `module Foo # :nodoc:`
|
|
45
|
+
next if code_lines[line] && !include_trailing
|
|
46
|
+
body = token[2][2..-1] or raise
|
|
47
|
+
|
|
48
|
+
body = "\n" if body.empty?
|
|
49
|
+
|
|
50
|
+
comment = AST::Comment.new(string: body, location: nil)
|
|
51
|
+
if prev_comment = hash.delete(line - 1)
|
|
52
|
+
hash[line] = AST::Comment.new(string: prev_comment.string + comment.string,
|
|
53
|
+
location: nil)
|
|
54
|
+
else
|
|
55
|
+
hash[line] = comment
|
|
56
|
+
end
|
|
57
|
+
else
|
|
58
|
+
code_lines[token[0][0]] = true
|
|
59
|
+
end
|
|
60
|
+
end
|
|
61
|
+
end
|
|
62
|
+
end
|
|
63
|
+
end
|
|
64
|
+
|
|
8
65
|
def block_from_body(node)
|
|
9
66
|
_, args_node, body_node = node.children
|
|
10
67
|
_pre_num, _pre_init, _opt, _first_post, _post_num, _post_init, _rest, _kw, _kwrest, block_var = args_from_node(args_node)
|
data/lib/rbs/prototype/rb.rb
CHANGED
|
@@ -74,32 +74,7 @@ module RBS
|
|
|
74
74
|
|
|
75
75
|
def parse(string)
|
|
76
76
|
# @type var comments: Hash[Integer, AST::Comment]
|
|
77
|
-
comments =
|
|
78
|
-
code_lines = {} #: Hash[Integer, bool]
|
|
79
|
-
tokens.each.with_object({}) do |token, hash| #$ Hash[Integer, AST::Comment]
|
|
80
|
-
case token[1]
|
|
81
|
-
when :on_sp, :on_ignored_nl
|
|
82
|
-
# skip
|
|
83
|
-
when :on_comment
|
|
84
|
-
line = token[0][0]
|
|
85
|
-
# skip like `module Foo # :nodoc:`
|
|
86
|
-
next if code_lines[line]
|
|
87
|
-
body = token[2][2..-1] or raise
|
|
88
|
-
|
|
89
|
-
body = "\n" if body.empty?
|
|
90
|
-
|
|
91
|
-
comment = AST::Comment.new(string: body, location: nil)
|
|
92
|
-
if prev_comment = hash.delete(line - 1)
|
|
93
|
-
hash[line] = AST::Comment.new(string: prev_comment.string + comment.string,
|
|
94
|
-
location: nil)
|
|
95
|
-
else
|
|
96
|
-
hash[line] = comment
|
|
97
|
-
end
|
|
98
|
-
else
|
|
99
|
-
code_lines[token[0][0]] = true
|
|
100
|
-
end
|
|
101
|
-
end
|
|
102
|
-
end
|
|
77
|
+
comments = parse_comments(string, include_trailing: false)
|
|
103
78
|
|
|
104
79
|
process RubyVM::AbstractSyntaxTree.parse(string), decls: source_decls, comments: comments, context: Context.initial
|
|
105
80
|
end
|
|
@@ -372,8 +347,8 @@ module RBS
|
|
|
372
347
|
end
|
|
373
348
|
|
|
374
349
|
value_node = node.children.last
|
|
375
|
-
type = if value_node.nil?
|
|
376
|
-
# Give up type prediction when node is MASGN.
|
|
350
|
+
type = if value_node.nil? || value_node.type == :SELF
|
|
351
|
+
# Give up type prediction when node is MASGN or SELF.
|
|
377
352
|
Types::Bases::Any.new(location: nil)
|
|
378
353
|
else
|
|
379
354
|
literal_to_type(value_node)
|
data/lib/rbs/prototype/rbi.rb
CHANGED
|
@@ -16,26 +16,7 @@ module RBS
|
|
|
16
16
|
end
|
|
17
17
|
|
|
18
18
|
def parse(string)
|
|
19
|
-
comments =
|
|
20
|
-
tokens.each.with_object({}) do |token, hash| #$ Hash[Integer, AST::Comment]
|
|
21
|
-
if token[1] == :on_comment
|
|
22
|
-
line = token[0][0]
|
|
23
|
-
body = token[2][2..-1] or raise
|
|
24
|
-
|
|
25
|
-
body = "\n" if body.empty?
|
|
26
|
-
|
|
27
|
-
comment = AST::Comment.new(string: body, location: nil)
|
|
28
|
-
if (prev_comment = hash.delete(line - 1))
|
|
29
|
-
hash[line] = AST::Comment.new(
|
|
30
|
-
string: prev_comment.string + comment.string,
|
|
31
|
-
location: nil
|
|
32
|
-
)
|
|
33
|
-
else
|
|
34
|
-
hash[line] = comment
|
|
35
|
-
end
|
|
36
|
-
end
|
|
37
|
-
end
|
|
38
|
-
end
|
|
19
|
+
comments = parse_comments(string, include_trailing: true)
|
|
39
20
|
process RubyVM::AbstractSyntaxTree.parse(string), comments: comments
|
|
40
21
|
end
|
|
41
22
|
|
|
@@ -235,6 +216,7 @@ module RBS
|
|
|
235
216
|
variance: variance || :invariant,
|
|
236
217
|
location: nil,
|
|
237
218
|
upper_bound: nil,
|
|
219
|
+
lower_bound: nil,
|
|
238
220
|
default_type: nil
|
|
239
221
|
)
|
|
240
222
|
end
|
|
@@ -332,6 +314,7 @@ module RBS
|
|
|
332
314
|
name: name,
|
|
333
315
|
variance: :invariant,
|
|
334
316
|
upper_bound: nil,
|
|
317
|
+
lower_bound: nil,
|
|
335
318
|
location: nil,
|
|
336
319
|
default_type: nil
|
|
337
320
|
)
|
|
@@ -27,6 +27,10 @@ module RBS
|
|
|
27
27
|
method_definition = @builder.build_singleton(module_name.absolute!).methods[method.name]
|
|
28
28
|
return false unless method_definition
|
|
29
29
|
|
|
30
|
+
return false unless method_definition.defs.any? do |type_def|
|
|
31
|
+
type_def.implemented_in&.relative!.to_s == method.owner.to_s.delete_prefix("#<Class:").delete_suffix(">")
|
|
32
|
+
end
|
|
33
|
+
|
|
30
34
|
method_definition.accessibility == accessibility
|
|
31
35
|
end
|
|
32
36
|
|
|
@@ -36,6 +40,10 @@ module RBS
|
|
|
36
40
|
method_definition = @builder.build_instance(module_name.absolute!).methods[method.name]
|
|
37
41
|
return false unless method_definition
|
|
38
42
|
|
|
43
|
+
return false unless method_definition.defs.any? do |type_def|
|
|
44
|
+
type_def.implemented_in&.relative!.to_s == method.owner.to_s
|
|
45
|
+
end
|
|
46
|
+
|
|
39
47
|
method_definition.accessibility == accessibility
|
|
40
48
|
end
|
|
41
49
|
|
|
@@ -50,8 +58,8 @@ module RBS
|
|
|
50
58
|
type_name_absolute = type_name.absolute!
|
|
51
59
|
@mixin_decls_cache ||= {} #: Hash[TypeName, Array[AST::Members::Mixin]]
|
|
52
60
|
@mixin_decls_cache.fetch(type_name_absolute) do
|
|
53
|
-
@mixin_decls_cache[type_name_absolute] = @builder.env.class_decls[type_name_absolute].
|
|
54
|
-
|
|
61
|
+
@mixin_decls_cache[type_name_absolute] = @builder.env.class_decls[type_name_absolute].each_decl.flat_map do |decl|
|
|
62
|
+
decl.members.select { |m| m.kind_of?(AST::Members::Mixin) }
|
|
55
63
|
end
|
|
56
64
|
end
|
|
57
65
|
end
|
data/lib/rbs/source.rb
ADDED
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module RBS
|
|
4
|
+
module Source
|
|
5
|
+
class RBS
|
|
6
|
+
attr_reader :buffer, :directives, :declarations
|
|
7
|
+
|
|
8
|
+
def initialize(buffer, directives, decls)
|
|
9
|
+
@buffer = buffer
|
|
10
|
+
@directives = directives
|
|
11
|
+
@declarations = decls
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
def each_type_name(&block)
|
|
15
|
+
if block
|
|
16
|
+
set = Set[] #: Set[TypeName]
|
|
17
|
+
declarations.each do |decl|
|
|
18
|
+
each_declaration_type_name(set, decl, &block)
|
|
19
|
+
end
|
|
20
|
+
else
|
|
21
|
+
enum_for :each_type_name
|
|
22
|
+
end
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
def each_declaration_type_name(names, decl, &block)
|
|
26
|
+
case decl
|
|
27
|
+
when AST::Declarations::Class
|
|
28
|
+
decl.each_decl { each_declaration_type_name(names, _1, &block) }
|
|
29
|
+
type_name = decl.name
|
|
30
|
+
when AST::Declarations::Module
|
|
31
|
+
decl.each_decl { each_declaration_type_name(names, _1, &block) }
|
|
32
|
+
type_name = decl.name
|
|
33
|
+
when AST::Declarations::Interface
|
|
34
|
+
type_name = decl.name
|
|
35
|
+
when AST::Declarations::TypeAlias
|
|
36
|
+
type_name = decl.name
|
|
37
|
+
when AST::Declarations::ModuleAlias
|
|
38
|
+
type_name = decl.new_name
|
|
39
|
+
when AST::Declarations::ClassAlias
|
|
40
|
+
type_name = decl.new_name
|
|
41
|
+
end
|
|
42
|
+
|
|
43
|
+
if type_name
|
|
44
|
+
unless names.include?(type_name)
|
|
45
|
+
yield type_name
|
|
46
|
+
names << type_name
|
|
47
|
+
end
|
|
48
|
+
end
|
|
49
|
+
end
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
class Ruby
|
|
53
|
+
attr_reader :buffer
|
|
54
|
+
attr_reader :prism_result
|
|
55
|
+
attr_reader :declarations
|
|
56
|
+
attr_reader :diagnostics
|
|
57
|
+
|
|
58
|
+
def initialize(buffer, prism, declarations, diagnostics)
|
|
59
|
+
@buffer = buffer
|
|
60
|
+
@prism_result = prism
|
|
61
|
+
@declarations = declarations
|
|
62
|
+
@diagnostics = diagnostics
|
|
63
|
+
end
|
|
64
|
+
|
|
65
|
+
def each_type_name(&block)
|
|
66
|
+
if block
|
|
67
|
+
names = Set[] #: Set[TypeName]
|
|
68
|
+
declarations.each do |decl|
|
|
69
|
+
each_declaration_type_name(names, decl, &block)
|
|
70
|
+
end
|
|
71
|
+
else
|
|
72
|
+
enum_for :each_type_name
|
|
73
|
+
end
|
|
74
|
+
end
|
|
75
|
+
|
|
76
|
+
def each_declaration_type_name(names, decl, &block)
|
|
77
|
+
case decl
|
|
78
|
+
when AST::Ruby::Declarations::ClassDecl
|
|
79
|
+
decl.each_decl do |d|
|
|
80
|
+
each_declaration_type_name(names, d, &block)
|
|
81
|
+
end
|
|
82
|
+
type_name = decl.class_name
|
|
83
|
+
when AST::Ruby::Declarations::ModuleDecl
|
|
84
|
+
decl.each_decl do |d|
|
|
85
|
+
each_declaration_type_name(names, d, &block)
|
|
86
|
+
end
|
|
87
|
+
type_name = decl.module_name
|
|
88
|
+
end
|
|
89
|
+
|
|
90
|
+
if type_name
|
|
91
|
+
unless names.include?(type_name)
|
|
92
|
+
yield type_name
|
|
93
|
+
names << type_name
|
|
94
|
+
end
|
|
95
|
+
end
|
|
96
|
+
end
|
|
97
|
+
end
|
|
98
|
+
end
|
|
99
|
+
end
|
data/lib/rbs/subtractor.rb
CHANGED
|
@@ -131,9 +131,10 @@ module RBS
|
|
|
131
131
|
|
|
132
132
|
entry = @subtrahend.class_decls[owner]
|
|
133
133
|
return unless entry
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
134
|
+
entry.each_decl do |d|
|
|
135
|
+
next unless d.is_a?(AST::Declarations::Base)
|
|
136
|
+
d.members.each { |m| block.call(m) }
|
|
137
|
+
end
|
|
137
138
|
end
|
|
138
139
|
|
|
139
140
|
private def mixin_exist?(owner, mixin, context:)
|
data/lib/rbs/test/type_check.rb
CHANGED
|
@@ -245,7 +245,7 @@ module RBS
|
|
|
245
245
|
when Types::Bases::Any
|
|
246
246
|
true
|
|
247
247
|
when Types::Bases::Bool
|
|
248
|
-
|
|
248
|
+
Test.call(val, IS_AP, TrueClass) || Test.call(val, IS_AP, FalseClass)
|
|
249
249
|
when Types::Bases::Top
|
|
250
250
|
true
|
|
251
251
|
when Types::Bases::Bottom
|
|
@@ -264,6 +264,9 @@ module RBS
|
|
|
264
264
|
klass = get_class(type.name) or return false
|
|
265
265
|
if params = builder.env.normalized_module_class_entry(type.name.absolute!)&.type_params
|
|
266
266
|
args = AST::TypeParam.normalize_args(params, type.args)
|
|
267
|
+
if args.size != params.size
|
|
268
|
+
return false
|
|
269
|
+
end
|
|
267
270
|
unless args == type.args
|
|
268
271
|
type = Types::ClassInstance.new(name: type.name, args: args, location: type.location)
|
|
269
272
|
end
|
|
@@ -336,7 +339,7 @@ module RBS
|
|
|
336
339
|
rescue TypeError
|
|
337
340
|
return false
|
|
338
341
|
end
|
|
339
|
-
|
|
342
|
+
Test.call(val, IS_AP, singleton_class)
|
|
340
343
|
when Types::Interface
|
|
341
344
|
if (definition = builder.build_interface(type.name.absolute!))
|
|
342
345
|
definition.methods.each.all? do |method_name, method|
|
data/lib/rbs/type_name.rb
CHANGED
|
@@ -36,7 +36,7 @@ module RBS
|
|
|
36
36
|
"#{namespace.to_s}#{name}"
|
|
37
37
|
end
|
|
38
38
|
|
|
39
|
-
def to_json(state =
|
|
39
|
+
def to_json(state = nil)
|
|
40
40
|
to_s.to_json(state)
|
|
41
41
|
end
|
|
42
42
|
|
|
@@ -100,10 +100,3 @@ module RBS
|
|
|
100
100
|
end
|
|
101
101
|
end
|
|
102
102
|
end
|
|
103
|
-
|
|
104
|
-
module Kernel
|
|
105
|
-
def TypeName(string)
|
|
106
|
-
warn "Kernel#TypeName() is deprecated. Use RBS::TypeName.parse instead.", category: :deprecated
|
|
107
|
-
RBS::TypeName.parse(string)
|
|
108
|
-
end
|
|
109
|
-
end
|