steep 1.6.0 → 1.7.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +0 -1
- data/CHANGELOG.md +49 -0
- data/README.md +18 -0
- data/Rakefile +5 -0
- data/bin/output_test.rb +1 -0
- data/doc/narrowing.md +195 -0
- data/doc/shape.md +194 -0
- data/guides/src/gem-rbs-collection/gem-rbs-collection.md +7 -24
- data/guides/src/getting-started/getting-started.md +10 -11
- data/lib/steep/ast/ignore.rb +148 -0
- data/lib/steep/ast/types/factory.rb +27 -18
- data/lib/steep/ast/types/helper.rb +4 -0
- data/lib/steep/ast/types/intersection.rb +7 -0
- data/lib/steep/ast/types/proc.rb +14 -9
- data/lib/steep/ast/types/record.rb +7 -0
- data/lib/steep/ast/types/tuple.rb +7 -0
- data/lib/steep/ast/types/union.rb +7 -0
- data/lib/steep/cli.rb +6 -1
- data/lib/steep/diagnostic/ruby.rb +16 -0
- data/lib/steep/drivers/stats.rb +2 -2
- data/lib/steep/drivers/utils/driver_helper.rb +22 -11
- data/lib/steep/drivers/validate.rb +4 -2
- data/lib/steep/expectations.rb +2 -2
- data/lib/steep/interface/block.rb +1 -1
- data/lib/steep/interface/builder.rb +342 -358
- data/lib/steep/interface/function.rb +82 -11
- data/lib/steep/interface/method_type.rb +18 -10
- data/lib/steep/interface/shape.rb +69 -18
- data/lib/steep/interface/substitution.rb +4 -0
- data/lib/steep/node_helper.rb +30 -1
- data/lib/steep/project/dsl.rb +18 -21
- data/lib/steep/project/options.rb +39 -2
- data/lib/steep/project/pattern.rb +1 -2
- data/lib/steep/project.rb +11 -7
- data/lib/steep/rake_task.rb +132 -0
- data/lib/steep/server/change_buffer.rb +2 -2
- data/lib/steep/server/interaction_worker.rb +67 -11
- data/lib/steep/server/lsp_formatter.rb +2 -0
- data/lib/steep/server/worker_process.rb +3 -1
- data/lib/steep/services/completion_provider.rb +59 -26
- data/lib/steep/services/file_loader.rb +15 -19
- data/lib/steep/services/signature_help_provider.rb +37 -35
- data/lib/steep/services/type_check_service.rb +36 -8
- data/lib/steep/signature/validator.rb +185 -133
- data/lib/steep/source/ignore_ranges.rb +69 -0
- data/lib/steep/source.rb +10 -4
- data/lib/steep/subtyping/check.rb +50 -43
- data/lib/steep/subtyping/result.rb +6 -0
- data/lib/steep/subtyping/variable_variance.rb +3 -3
- data/lib/steep/test.rb +9 -0
- data/lib/steep/type_construction.rb +205 -309
- data/lib/steep/type_inference/block_params.rb +12 -4
- data/lib/steep/type_inference/case_when.rb +301 -0
- data/lib/steep/type_inference/context.rb +1 -1
- data/lib/steep/type_inference/logic_type_interpreter.rb +3 -2
- data/lib/steep/type_inference/method_params.rb +16 -0
- data/lib/steep/type_inference/send_args.rb +5 -2
- data/lib/steep/version.rb +1 -1
- data/lib/steep.rb +25 -8
- data/steep.gemspec +5 -2
- metadata +12 -396
- data/.github/dependabot.yml +0 -22
- data/.github/workflows/ruby-windows.yml +0 -34
- data/.github/workflows/ruby.yml +0 -33
- data/.vscode/steep-shared.code-snippets +0 -41
- data/Gemfile +0 -14
- data/Gemfile.lock +0 -104
- data/Gemfile.steep +0 -0
- data/gemfile_steep/Gemfile +0 -3
- data/gemfile_steep/Gemfile.lock +0 -64
- data/rbs_collection.steep.lock.yaml +0 -106
- data/rbs_collection.steep.yaml +0 -23
- data/sig/shims/bundler.rbs +0 -3
- data/sig/shims/concurrent-ruby.rbs +0 -39
- data/sig/shims/exception.rbs +0 -4
- data/sig/shims/language-server_protocol.rbs +0 -450
- data/sig/shims/parser/comment.rbs +0 -33
- data/sig/shims/parser/nodes.rbs +0 -252
- data/sig/shims/parser/source/map.rbs +0 -146
- data/sig/shims/parser/source/range.rbs +0 -237
- data/sig/shims/parser.rbs +0 -59
- data/sig/shims/string.rbs +0 -4
- data/sig/shims/tagged_logging.rbs +0 -6
- data/sig/steep/annotation_parser.rbs +0 -60
- data/sig/steep/ast/annotation/collection.rbs +0 -78
- data/sig/steep/ast/annotation.rbs +0 -121
- data/sig/steep/ast/builtin.rbs +0 -69
- data/sig/steep/ast/node/type_application.rbs +0 -31
- data/sig/steep/ast/node/type_assertion.rbs +0 -32
- data/sig/steep/ast/types/any.rbs +0 -29
- data/sig/steep/ast/types/boolean.rbs +0 -31
- data/sig/steep/ast/types/bot.rbs +0 -29
- data/sig/steep/ast/types/class.rbs +0 -33
- data/sig/steep/ast/types/factory.rbs +0 -110
- data/sig/steep/ast/types/helper.rbs +0 -22
- data/sig/steep/ast/types/instance.rbs +0 -33
- data/sig/steep/ast/types/intersection.rbs +0 -38
- data/sig/steep/ast/types/literal.rbs +0 -35
- data/sig/steep/ast/types/logic.rbs +0 -83
- data/sig/steep/ast/types/name.rbs +0 -80
- data/sig/steep/ast/types/nil.rbs +0 -31
- data/sig/steep/ast/types/proc.rbs +0 -53
- data/sig/steep/ast/types/record.rbs +0 -37
- data/sig/steep/ast/types/self.rbs +0 -33
- data/sig/steep/ast/types/top.rbs +0 -29
- data/sig/steep/ast/types/tuple.rbs +0 -35
- data/sig/steep/ast/types/union.rbs +0 -38
- data/sig/steep/ast/types/var.rbs +0 -42
- data/sig/steep/ast/types/void.rbs +0 -29
- data/sig/steep/ast/types.rbs +0 -16
- data/sig/steep/cli.rbs +0 -55
- data/sig/steep/diagnostic/deprecated/else_on_exhaustive_case.rbs +0 -13
- data/sig/steep/diagnostic/deprecated/unknown_constant_assigned.rbs +0 -15
- data/sig/steep/diagnostic/helper.rbs +0 -15
- data/sig/steep/diagnostic/lsp_formatter.rbs +0 -36
- data/sig/steep/diagnostic/ruby.rbs +0 -695
- data/sig/steep/diagnostic/signature.rbs +0 -252
- data/sig/steep/drivers/annotations.rbs +0 -17
- data/sig/steep/drivers/check.rbs +0 -33
- data/sig/steep/drivers/checkfile.rbs +0 -27
- data/sig/steep/drivers/diagnostic_printer.rbs +0 -25
- data/sig/steep/drivers/init.rbs +0 -19
- data/sig/steep/drivers/langserver.rbs +0 -36
- data/sig/steep/drivers/print_project.rbs +0 -15
- data/sig/steep/drivers/stats.rbs +0 -47
- data/sig/steep/drivers/utils/driver_helper.rbs +0 -25
- data/sig/steep/drivers/utils/jobs_option.rbs +0 -19
- data/sig/steep/drivers/validate.rbs +0 -15
- data/sig/steep/drivers/vendor.rbs +0 -19
- data/sig/steep/drivers/watch.rbs +0 -27
- data/sig/steep/drivers/worker.rbs +0 -29
- data/sig/steep/equatable.rbs +0 -11
- data/sig/steep/expectations.rbs +0 -72
- data/sig/steep/index/rbs_index.rbs +0 -141
- data/sig/steep/index/signature_symbol_provider.rbs +0 -41
- data/sig/steep/index/source_index.rbs +0 -63
- data/sig/steep/interface/block.rbs +0 -41
- data/sig/steep/interface/builder.rbs +0 -166
- data/sig/steep/interface/function.rbs +0 -265
- data/sig/steep/interface/method_type.rbs +0 -105
- data/sig/steep/interface/shape.rbs +0 -61
- data/sig/steep/interface/substitution.rbs +0 -49
- data/sig/steep/interface/type_param.rbs +0 -43
- data/sig/steep/method_name.rbs +0 -30
- data/sig/steep/module_helper.rbs +0 -16
- data/sig/steep/node_helper.rbs +0 -78
- data/sig/steep/path_helper.rbs +0 -15
- data/sig/steep/project/dsl.rbs +0 -104
- data/sig/steep/project/options.rbs +0 -27
- data/sig/steep/project/pattern.rbs +0 -47
- data/sig/steep/project/target.rbs +0 -25
- data/sig/steep/project.rbs +0 -26
- data/sig/steep/range_extension.rbs +0 -7
- data/sig/steep/server/base_worker.rbs +0 -49
- data/sig/steep/server/change_buffer.rbs +0 -36
- data/sig/steep/server/delay_queue.rbs +0 -37
- data/sig/steep/server/interaction_worker.rbs +0 -80
- data/sig/steep/server/lsp_formatter.rbs +0 -63
- data/sig/steep/server/master.rbs +0 -299
- data/sig/steep/server/type_check_worker.rbs +0 -141
- data/sig/steep/server/worker_process.rbs +0 -97
- data/sig/steep/services/completion_provider.rbs +0 -251
- data/sig/steep/services/content_change.rbs +0 -37
- data/sig/steep/services/file_loader.rbs +0 -21
- data/sig/steep/services/goto_service.rbs +0 -106
- data/sig/steep/services/hover_provider/rbs.rbs +0 -47
- data/sig/steep/services/hover_provider/ruby.rbs +0 -127
- data/sig/steep/services/hover_provider/singleton_methods.rbs +0 -11
- data/sig/steep/services/path_assignment.rbs +0 -21
- data/sig/steep/services/signature_help_provider.rbs +0 -49
- data/sig/steep/services/signature_service.rbs +0 -156
- data/sig/steep/services/stats_calculator.rbs +0 -41
- data/sig/steep/services/type_check_service.rbs +0 -107
- data/sig/steep/services/type_name_completion.rbs +0 -135
- data/sig/steep/signature/validator.rbs +0 -85
- data/sig/steep/source.rbs +0 -102
- data/sig/steep/subtyping/cache.rbs +0 -17
- data/sig/steep/subtyping/check.rbs +0 -129
- data/sig/steep/subtyping/constraints.rbs +0 -111
- data/sig/steep/subtyping/relation.rbs +0 -63
- data/sig/steep/subtyping/result.rbs +0 -175
- data/sig/steep/subtyping/variable_variance.rbs +0 -25
- data/sig/steep/thread_waiter.rbs +0 -13
- data/sig/steep/type_construction.rbs +0 -567
- data/sig/steep/type_inference/block_params.rbs +0 -170
- data/sig/steep/type_inference/constant_env.rbs +0 -29
- data/sig/steep/type_inference/context.rbs +0 -214
- data/sig/steep/type_inference/context_array.rbs +0 -38
- data/sig/steep/type_inference/logic_type_interpreter.rbs +0 -108
- data/sig/steep/type_inference/method_call.rbs +0 -124
- data/sig/steep/type_inference/method_params.rbs +0 -127
- data/sig/steep/type_inference/multiple_assignment.rbs +0 -76
- data/sig/steep/type_inference/send_args.rbs +0 -243
- data/sig/steep/type_inference/type_env.rbs +0 -160
- data/sig/steep/type_inference/type_env_builder.rbs +0 -81
- data/sig/steep/typing.rbs +0 -75
- data/sig/steep.rbs +0 -36
- data/smoke/alias/Steepfile +0 -6
- data/smoke/alias/a.rb +0 -16
- data/smoke/alias/a.rbs +0 -10
- data/smoke/alias/b.rb +0 -6
- data/smoke/alias/c.rb +0 -8
- data/smoke/alias/test_expectations.yml +0 -96
- data/smoke/and/Steepfile +0 -6
- data/smoke/and/a.rb +0 -8
- data/smoke/and/test_expectations.yml +0 -29
- data/smoke/array/Steepfile +0 -6
- data/smoke/array/a.rb +0 -18
- data/smoke/array/b.rb +0 -12
- data/smoke/array/c.rb +0 -6
- data/smoke/array/test_expectations.yml +0 -103
- data/smoke/block/Steepfile +0 -6
- data/smoke/block/a.rb +0 -10
- data/smoke/block/a.rbs +0 -6
- data/smoke/block/b.rb +0 -13
- data/smoke/block/c.rb +0 -9
- data/smoke/block/c.rbs +0 -3
- data/smoke/block/d.rb +0 -11
- data/smoke/block/e.rb +0 -12
- data/smoke/block/e.rbs +0 -4
- data/smoke/block/test_expectations.yml +0 -133
- data/smoke/case/Steepfile +0 -6
- data/smoke/case/a.rb +0 -18
- data/smoke/case/test_expectations.yml +0 -47
- data/smoke/class/Steepfile +0 -6
- data/smoke/class/a.rb +0 -25
- data/smoke/class/a.rbs +0 -23
- data/smoke/class/b.rb +0 -5
- data/smoke/class/c.rb +0 -9
- data/smoke/class/f.rb +0 -10
- data/smoke/class/g.rb +0 -6
- data/smoke/class/h.rb +0 -19
- data/smoke/class/h.rbs +0 -6
- data/smoke/class/i.rb +0 -14
- data/smoke/class/i.rbs +0 -9
- data/smoke/class/test_expectations.yml +0 -117
- data/smoke/compact/Steepfile +0 -6
- data/smoke/compact/a.rb +0 -2
- data/smoke/compact/a.rbs +0 -5
- data/smoke/compact/b.rb +0 -2
- data/smoke/compact/test_expectations.yml +0 -18
- data/smoke/const/Steepfile +0 -6
- data/smoke/const/a.rb +0 -27
- data/smoke/const/b.rb +0 -7
- data/smoke/const/b.rbs +0 -5
- data/smoke/const/test_expectations.yml +0 -134
- data/smoke/diagnostics/Steepfile +0 -6
- data/smoke/diagnostics/a.rbs +0 -22
- data/smoke/diagnostics/argument_type_mismatch.rb +0 -1
- data/smoke/diagnostics/block_body_type_mismatch.rb +0 -1
- data/smoke/diagnostics/block_type_mismatch.rb +0 -3
- data/smoke/diagnostics/break_type_mismatch.rb +0 -1
- data/smoke/diagnostics/different_method_parameter_kind.rb +0 -9
- data/smoke/diagnostics/else_on_exhaustive_case.rb +0 -12
- data/smoke/diagnostics/incompatible_annotation.rb +0 -6
- data/smoke/diagnostics/incompatible_argument.rb +0 -1
- data/smoke/diagnostics/incompatible_assignment.rb +0 -8
- data/smoke/diagnostics/method_arity_mismatch.rb +0 -11
- data/smoke/diagnostics/method_body_type_mismatch.rb +0 -6
- data/smoke/diagnostics/method_definition_missing.rb +0 -2
- data/smoke/diagnostics/method_parameter_mismatch.rb +0 -10
- data/smoke/diagnostics/method_return_type_annotation_mismatch.rb +0 -7
- data/smoke/diagnostics/missing_keyword.rb +0 -1
- data/smoke/diagnostics/no_method.rb +0 -1
- data/smoke/diagnostics/proc_type_expected.rb +0 -3
- data/smoke/diagnostics/required_block_missing.rb +0 -1
- data/smoke/diagnostics/return_type_mismatch.rb +0 -6
- data/smoke/diagnostics/test_expectations.yml +0 -591
- data/smoke/diagnostics/unexpected_block_given.rb +0 -1
- data/smoke/diagnostics/unexpected_dynamic_method.rb +0 -3
- data/smoke/diagnostics/unexpected_jump.rb +0 -4
- data/smoke/diagnostics/unexpected_jump_value.rb +0 -3
- data/smoke/diagnostics/unexpected_keyword.rb +0 -1
- data/smoke/diagnostics/unexpected_splat.rb +0 -1
- data/smoke/diagnostics/unexpected_yield.rb +0 -6
- data/smoke/diagnostics/unknown_constant_assigned.rb +0 -7
- data/smoke/diagnostics/unresolved_overloading.rb +0 -1
- data/smoke/diagnostics/unsupported_syntax.rb +0 -2
- data/smoke/diagnostics-rbs/Steepfile +0 -8
- data/smoke/diagnostics-rbs/duplicated-method-definition.rbs +0 -20
- data/smoke/diagnostics-rbs/generic-parameter-mismatch.rbs +0 -7
- data/smoke/diagnostics-rbs/inherit-module.rbs +0 -2
- data/smoke/diagnostics-rbs/invalid-method-overload.rbs +0 -3
- data/smoke/diagnostics-rbs/invalid-type-application.rbs +0 -7
- data/smoke/diagnostics-rbs/invalid_variance_annotation.rbs +0 -3
- data/smoke/diagnostics-rbs/mixin-class-error.rbs +0 -6
- data/smoke/diagnostics-rbs/nonregular-type-alias.rbs +0 -3
- data/smoke/diagnostics-rbs/recursive-alias.rbs +0 -5
- data/smoke/diagnostics-rbs/recursive-class.rbs +0 -8
- data/smoke/diagnostics-rbs/recursive-type-alias.rbs +0 -3
- data/smoke/diagnostics-rbs/superclass-mismatch.rbs +0 -7
- data/smoke/diagnostics-rbs/test_expectations.yml +0 -300
- data/smoke/diagnostics-rbs/unknown-method-alias.rbs +0 -3
- data/smoke/diagnostics-rbs/unknown-type-name-2.rbs +0 -5
- data/smoke/diagnostics-rbs/unknown-type-name.rbs +0 -13
- data/smoke/diagnostics-rbs-duplicated/Steepfile +0 -6
- data/smoke/diagnostics-rbs-duplicated/a.rbs +0 -5
- data/smoke/diagnostics-rbs-duplicated/test_expectations.yml +0 -13
- data/smoke/diagnostics-ruby-unsat/Steepfile +0 -6
- data/smoke/diagnostics-ruby-unsat/a.rbs +0 -3
- data/smoke/diagnostics-ruby-unsat/test_expectations.yml +0 -27
- data/smoke/diagnostics-ruby-unsat/unsatisfiable_constraint.rb +0 -6
- data/smoke/dstr/Steepfile +0 -6
- data/smoke/dstr/a.rb +0 -5
- data/smoke/dstr/test_expectations.yml +0 -13
- data/smoke/ensure/Steepfile +0 -6
- data/smoke/ensure/a.rb +0 -18
- data/smoke/ensure/test_expectations.yml +0 -62
- data/smoke/enumerator/Steepfile +0 -6
- data/smoke/enumerator/a.rb +0 -6
- data/smoke/enumerator/b.rb +0 -17
- data/smoke/enumerator/test_expectations.yml +0 -47
- data/smoke/extension/Steepfile +0 -6
- data/smoke/extension/a.rb +0 -10
- data/smoke/extension/a.rbs +0 -13
- data/smoke/extension/b.rb +0 -10
- data/smoke/extension/c.rb +0 -9
- data/smoke/extension/d.rb +0 -2
- data/smoke/extension/e.rb +0 -2
- data/smoke/extension/e.rbs +0 -7
- data/smoke/extension/f.rb +0 -2
- data/smoke/extension/f.rbs +0 -3
- data/smoke/extension/test_expectations.yml +0 -73
- data/smoke/hash/Steepfile +0 -6
- data/smoke/hash/a.rb +0 -17
- data/smoke/hash/a.rbs +0 -8
- data/smoke/hash/b.rb +0 -6
- data/smoke/hash/c.rb +0 -15
- data/smoke/hash/d.rb +0 -5
- data/smoke/hash/e.rb +0 -1
- data/smoke/hash/e.rbs +0 -3
- data/smoke/hash/f.rb +0 -11
- data/smoke/hash/test_expectations.yml +0 -81
- data/smoke/hello/Steepfile +0 -6
- data/smoke/hello/hello.rb +0 -11
- data/smoke/hello/hello.rbs +0 -7
- data/smoke/hello/test_expectations.yml +0 -25
- data/smoke/if/Steepfile +0 -6
- data/smoke/if/a.rb +0 -20
- data/smoke/if/test_expectations.yml +0 -34
- data/smoke/implements/Steepfile +0 -6
- data/smoke/implements/a.rb +0 -12
- data/smoke/implements/a.rbs +0 -6
- data/smoke/implements/b.rb +0 -13
- data/smoke/implements/b.rbs +0 -12
- data/smoke/implements/test_expectations.yml +0 -23
- data/smoke/initialize/Steepfile +0 -6
- data/smoke/initialize/a.rb +0 -12
- data/smoke/initialize/a.rbs +0 -3
- data/smoke/initialize/test_expectations.yml +0 -1
- data/smoke/integer/Steepfile +0 -6
- data/smoke/integer/a.rb +0 -26
- data/smoke/integer/test_expectations.yml +0 -110
- data/smoke/interface/Steepfile +0 -6
- data/smoke/interface/a.rb +0 -12
- data/smoke/interface/a.rbs +0 -12
- data/smoke/interface/test_expectations.yml +0 -23
- data/smoke/kwbegin/Steepfile +0 -6
- data/smoke/kwbegin/a.rb +0 -7
- data/smoke/kwbegin/test_expectations.yml +0 -17
- data/smoke/lambda/Steepfile +0 -6
- data/smoke/lambda/a.rb +0 -10
- data/smoke/lambda/test_expectations.yml +0 -17
- data/smoke/literal/Steepfile +0 -6
- data/smoke/literal/a.rb +0 -11
- data/smoke/literal/b.rb +0 -7
- data/smoke/literal/literal_methods.rbs +0 -4
- data/smoke/literal/test_expectations.yml +0 -106
- data/smoke/map/Steepfile +0 -6
- data/smoke/map/a.rb +0 -5
- data/smoke/map/test_expectations.yml +0 -1
- data/smoke/method/Steepfile +0 -6
- data/smoke/method/a.rb +0 -21
- data/smoke/method/a.rbs +0 -4
- data/smoke/method/b.rb +0 -25
- data/smoke/method/c.rb +0 -5
- data/smoke/method/d.rb +0 -1
- data/smoke/method/d.rbs +0 -3
- data/smoke/method/test_expectations.yml +0 -121
- data/smoke/module/Steepfile +0 -6
- data/smoke/module/a.rb +0 -19
- data/smoke/module/a.rbs +0 -16
- data/smoke/module/b.rb +0 -6
- data/smoke/module/c.rb +0 -22
- data/smoke/module/d.rb +0 -4
- data/smoke/module/e.rb +0 -13
- data/smoke/module/f.rb +0 -11
- data/smoke/module/test_expectations.yml +0 -75
- data/smoke/regexp/Steepfile +0 -6
- data/smoke/regexp/a.rb +0 -109
- data/smoke/regexp/b.rb +0 -79
- data/smoke/regexp/test_expectations.yml +0 -615
- data/smoke/regression/Steepfile +0 -6
- data/smoke/regression/array.rb +0 -7
- data/smoke/regression/block_param_split.rb +0 -7
- data/smoke/regression/block_param_split.rbs +0 -3
- data/smoke/regression/empty_yield.rb +0 -5
- data/smoke/regression/empty_yield.rbs +0 -3
- data/smoke/regression/enumerator_product.rb +0 -1
- data/smoke/regression/fun.rb +0 -8
- data/smoke/regression/fun.rbs +0 -4
- data/smoke/regression/hash.rb +0 -7
- data/smoke/regression/hello world.rb +0 -1
- data/smoke/regression/issue_328.rb +0 -1
- data/smoke/regression/issue_328.rbs +0 -0
- data/smoke/regression/issue_332.rb +0 -11
- data/smoke/regression/issue_332.rbs +0 -19
- data/smoke/regression/issue_372.rb +0 -8
- data/smoke/regression/issue_372.rbs +0 -4
- data/smoke/regression/lambda.rb +0 -3
- data/smoke/regression/masgn.rb +0 -4
- data/smoke/regression/poly_new.rb +0 -2
- data/smoke/regression/poly_new.rbs +0 -4
- data/smoke/regression/range.rb +0 -5
- data/smoke/regression/set_divide.rb +0 -12
- data/smoke/regression/test_expectations.yml +0 -120
- data/smoke/regression/thread.rb +0 -7
- data/smoke/rescue/Steepfile +0 -6
- data/smoke/rescue/a.rb +0 -48
- data/smoke/rescue/test_expectations.yml +0 -79
- data/smoke/self/Steepfile +0 -6
- data/smoke/self/a.rb +0 -21
- data/smoke/self/a.rbs +0 -4
- data/smoke/self/test_expectations.yml +0 -23
- data/smoke/skip/Steepfile +0 -6
- data/smoke/skip/skip.rb +0 -13
- data/smoke/skip/test_expectations.yml +0 -23
- data/smoke/stdout/Steepfile +0 -6
- data/smoke/stdout/a.rb +0 -8
- data/smoke/stdout/a.rbs +0 -7
- data/smoke/stdout/test_expectations.yml +0 -1
- data/smoke/super/Steepfile +0 -6
- data/smoke/super/a.rb +0 -30
- data/smoke/super/a.rbs +0 -10
- data/smoke/super/test_expectations.yml +0 -69
- data/smoke/toplevel/Steepfile +0 -6
- data/smoke/toplevel/a.rb +0 -3
- data/smoke/toplevel/a.rbs +0 -3
- data/smoke/toplevel/test_expectations.yml +0 -15
- data/smoke/tsort/Steepfile +0 -7
- data/smoke/tsort/a.rb +0 -12
- data/smoke/tsort/test_expectations.yml +0 -1
- data/smoke/type_case/Steepfile +0 -6
- data/smoke/type_case/a.rb +0 -24
- data/smoke/type_case/test_expectations.yml +0 -58
- data/smoke/unexpected/Steepfile +0 -6
- data/smoke/unexpected/test_expectations.yml +0 -13
- data/smoke/unexpected/unexpected.rbs +0 -3
- data/smoke/yield/Steepfile +0 -6
- data/smoke/yield/a.rb +0 -15
- data/smoke/yield/b.rb +0 -6
- data/smoke/yield/test_expectations.yml +0 -88
@@ -0,0 +1,148 @@
|
|
1
|
+
module Steep
|
2
|
+
module AST
|
3
|
+
module Ignore
|
4
|
+
class BufferScanner
|
5
|
+
attr_reader :scanner, :location
|
6
|
+
|
7
|
+
def initialize(location)
|
8
|
+
@location = location
|
9
|
+
|
10
|
+
@scanner = StringScanner.new(location.source)
|
11
|
+
end
|
12
|
+
|
13
|
+
def offset
|
14
|
+
@location.start_pos
|
15
|
+
end
|
16
|
+
|
17
|
+
def charpos
|
18
|
+
scanner.charpos + offset
|
19
|
+
end
|
20
|
+
|
21
|
+
def scan(regexp)
|
22
|
+
if matched = scanner.scan(regexp)
|
23
|
+
end_pos = charpos()
|
24
|
+
begin_pos = end_pos - matched.size
|
25
|
+
RBS::Location.new(location.buffer, begin_pos, end_pos)
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
def skip(regexp)
|
30
|
+
scanner.skip(regexp)
|
31
|
+
end
|
32
|
+
|
33
|
+
def eos?
|
34
|
+
scanner.eos?
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
class IgnoreStart
|
39
|
+
attr_reader :comment, :location
|
40
|
+
|
41
|
+
def initialize(comment, location)
|
42
|
+
@comment = comment
|
43
|
+
@location = location
|
44
|
+
end
|
45
|
+
|
46
|
+
def line
|
47
|
+
location.start_line
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
class IgnoreEnd
|
52
|
+
attr_reader :comment, :location
|
53
|
+
|
54
|
+
def initialize(comment, location)
|
55
|
+
@comment = comment
|
56
|
+
@location = location
|
57
|
+
end
|
58
|
+
|
59
|
+
def line
|
60
|
+
location.start_line
|
61
|
+
end
|
62
|
+
end
|
63
|
+
|
64
|
+
class IgnoreLine
|
65
|
+
attr_reader :comment, :location, :raw_diagnostics
|
66
|
+
|
67
|
+
def initialize(comment, diagnostics, location)
|
68
|
+
@comment = comment
|
69
|
+
@raw_diagnostics = diagnostics
|
70
|
+
@location = location
|
71
|
+
end
|
72
|
+
|
73
|
+
def line
|
74
|
+
location.start_line
|
75
|
+
end
|
76
|
+
|
77
|
+
def ignored_diagnostics
|
78
|
+
if raw_diagnostics.empty?
|
79
|
+
return :all
|
80
|
+
end
|
81
|
+
|
82
|
+
if raw_diagnostics.size == 1 && raw_diagnostics[0].source == "all"
|
83
|
+
return :all
|
84
|
+
end
|
85
|
+
|
86
|
+
raw_diagnostics.map do |diagnostic|
|
87
|
+
name = diagnostic[:name].source
|
88
|
+
name.gsub(/\ARuby::/, "")
|
89
|
+
end
|
90
|
+
end
|
91
|
+
end
|
92
|
+
|
93
|
+
def self.parse(comment, buffer)
|
94
|
+
return unless comment.inline?
|
95
|
+
|
96
|
+
comment_location = RBS::Location.new(buffer, comment.loc.expression.begin_pos, comment.loc.expression.end_pos)
|
97
|
+
scanner = BufferScanner.new(comment_location)
|
98
|
+
|
99
|
+
scanner.scan(/#/)
|
100
|
+
scanner.skip(/\s*/)
|
101
|
+
|
102
|
+
begin_pos = comment.location.expression.begin_pos
|
103
|
+
end_pos = comment.location.expression.end_pos
|
104
|
+
|
105
|
+
case
|
106
|
+
when loc = scanner.scan(/steep:ignore:start\b/)
|
107
|
+
scanner.skip(/\s*/)
|
108
|
+
return unless scanner.eos?
|
109
|
+
|
110
|
+
IgnoreStart.new(comment, loc)
|
111
|
+
when loc = scanner.scan(/steep:ignore:end\b/)
|
112
|
+
scanner.skip(/\s*/)
|
113
|
+
return unless scanner.eos?
|
114
|
+
|
115
|
+
IgnoreEnd.new(comment, loc)
|
116
|
+
when keyword_loc = scanner.scan(/steep:ignore\b/)
|
117
|
+
# @type var diagnostics: IgnoreLine::diagnostics
|
118
|
+
diagnostics = []
|
119
|
+
|
120
|
+
scanner.skip(/\s*/)
|
121
|
+
|
122
|
+
while true
|
123
|
+
name = scanner.scan(/[A-Z]\w*/) or break
|
124
|
+
scanner.skip(/\s*/)
|
125
|
+
comma = scanner.scan(/,/)
|
126
|
+
scanner.skip(/\s*/)
|
127
|
+
|
128
|
+
diagnostic = RBS::Location.new(buffer, name.start_pos, comma&.end_pos || name.end_pos) #: IgnoreLine::diagnostic
|
129
|
+
diagnostic.add_required_child(:name, name.range)
|
130
|
+
diagnostic.add_optional_child(:following_comma, comma&.range)
|
131
|
+
diagnostics << diagnostic
|
132
|
+
|
133
|
+
break unless comma
|
134
|
+
end
|
135
|
+
|
136
|
+
return unless scanner.eos?
|
137
|
+
|
138
|
+
loc = RBS::Location.new(
|
139
|
+
buffer,
|
140
|
+
keyword_loc.start_pos,
|
141
|
+
diagnostics.last&.end_pos || keyword_loc.end_pos
|
142
|
+
)
|
143
|
+
IgnoreLine.new(comment, diagnostics, loc)
|
144
|
+
end
|
145
|
+
end
|
146
|
+
end
|
147
|
+
end
|
148
|
+
end
|
@@ -212,27 +212,36 @@ module Steep
|
|
212
212
|
params = func.params
|
213
213
|
return_type = func.return_type
|
214
214
|
|
215
|
-
|
216
|
-
|
217
|
-
|
218
|
-
|
219
|
-
|
220
|
-
|
221
|
-
|
222
|
-
|
223
|
-
|
224
|
-
|
215
|
+
if params
|
216
|
+
RBS::Types::Function.new(
|
217
|
+
required_positionals: params.required.map {|type| RBS::Types::Function::Param.new(name: nil, type: type_1(type)) },
|
218
|
+
optional_positionals: params.optional.map {|type| RBS::Types::Function::Param.new(name: nil, type: type_1(type)) },
|
219
|
+
rest_positionals: params.rest&.yield_self {|type| RBS::Types::Function::Param.new(name: nil, type: type_1(type)) },
|
220
|
+
trailing_positionals: [],
|
221
|
+
required_keywords: params.required_keywords.transform_values {|type| RBS::Types::Function::Param.new(name: nil, type: type_1(type)) },
|
222
|
+
optional_keywords: params.optional_keywords.transform_values {|type| RBS::Types::Function::Param.new(name: nil, type: type_1(type)) },
|
223
|
+
rest_keywords: params.rest_keywords&.yield_self {|type| RBS::Types::Function::Param.new(name: nil, type: type_1(type)) },
|
224
|
+
return_type: type_1(return_type)
|
225
|
+
)
|
226
|
+
else
|
227
|
+
RBS::Types::UntypedFunction.new(return_type: type_1(return_type))
|
228
|
+
end
|
225
229
|
end
|
226
230
|
|
227
231
|
def params(type)
|
228
|
-
|
229
|
-
|
230
|
-
|
231
|
-
|
232
|
-
|
233
|
-
|
234
|
-
|
235
|
-
|
232
|
+
case type
|
233
|
+
when RBS::Types::Function
|
234
|
+
Interface::Function::Params.build(
|
235
|
+
required: type.required_positionals.map {|param| type(param.type) },
|
236
|
+
optional: type.optional_positionals.map {|param| type(param.type) },
|
237
|
+
rest: type.rest_positionals&.yield_self {|param| type(param.type) },
|
238
|
+
required_keywords: type.required_keywords.transform_values {|param| type(param.type) },
|
239
|
+
optional_keywords: type.optional_keywords.transform_values {|param| type(param.type) },
|
240
|
+
rest_keywords: type.rest_keywords&.yield_self {|param| type(param.type) }
|
241
|
+
)
|
242
|
+
when RBS::Types::UntypedFunction
|
243
|
+
nil
|
244
|
+
end
|
236
245
|
end
|
237
246
|
|
238
247
|
def type_param(type_param)
|
data/lib/steep/ast/types/proc.rb
CHANGED
@@ -57,9 +57,11 @@ module Steep
|
|
57
57
|
include Helper::ChildrenLevel
|
58
58
|
|
59
59
|
def level
|
60
|
-
children = type.params
|
60
|
+
children = type.params&.each_type.to_a + [type.return_type]
|
61
61
|
if block
|
62
|
-
|
62
|
+
if block.type.params
|
63
|
+
children.push(*block.type.params.each_type.to_a)
|
64
|
+
end
|
63
65
|
children.push(block.type.return_type)
|
64
66
|
end
|
65
67
|
if self_type
|
@@ -83,13 +85,16 @@ module Steep
|
|
83
85
|
|
84
86
|
def one_arg?
|
85
87
|
params = type.params
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
88
|
+
if params
|
89
|
+
params.required.size == 1 &&
|
90
|
+
params.optional.empty? &&
|
91
|
+
!params.rest &&
|
92
|
+
params.required_keywords.empty? &&
|
93
|
+
params.optional_keywords.empty? &&
|
94
|
+
!params.rest_keywords
|
95
|
+
else
|
96
|
+
true
|
97
|
+
end
|
93
98
|
end
|
94
99
|
|
95
100
|
def back_type
|
data/lib/steep/cli.rb
CHANGED
@@ -63,6 +63,7 @@ module Steep
|
|
63
63
|
def handle_logging_options(opts)
|
64
64
|
opts.on("--log-level=LEVEL", "Specify log level: debug, info, warn, error, fatal") do |level|
|
65
65
|
Steep.logger.level = level
|
66
|
+
Steep.ui_logger.level = level
|
66
67
|
end
|
67
68
|
|
68
69
|
opts.on("--log-output=PATH", "Print logs to given path") do |file|
|
@@ -71,6 +72,7 @@ module Steep
|
|
71
72
|
|
72
73
|
opts.on("--verbose", "Set log level to debug") do
|
73
74
|
Steep.logger.level = Logger::DEBUG
|
75
|
+
Steep.ui_logger.level = Logger::DEBUG
|
74
76
|
end
|
75
77
|
end
|
76
78
|
|
@@ -129,7 +131,7 @@ module Steep
|
|
129
131
|
end.parse!(argv)
|
130
132
|
|
131
133
|
setup_jobs_for_ci(command.jobs_option)
|
132
|
-
|
134
|
+
|
133
135
|
command.command_line_patterns.push *argv
|
134
136
|
end.run
|
135
137
|
end
|
@@ -349,6 +351,9 @@ TEMPLATE
|
|
349
351
|
opts.on("--index=INDEX") {|index| command.index = Integer(index) }
|
350
352
|
end.parse!(argv)
|
351
353
|
|
354
|
+
# Disable any `ui_logger` output in workers
|
355
|
+
Steep.ui_logger.level = :fatal
|
356
|
+
|
352
357
|
command.commandline_args.push(*argv)
|
353
358
|
end.run
|
354
359
|
end
|
@@ -997,6 +997,19 @@ module Steep
|
|
997
997
|
end
|
998
998
|
end
|
999
999
|
|
1000
|
+
class InvalidIgnoreComment < Base
|
1001
|
+
attr_reader :comment
|
1002
|
+
|
1003
|
+
def initialize(comment:)
|
1004
|
+
@comment = comment
|
1005
|
+
super(node: nil, location: comment.location.expression)
|
1006
|
+
end
|
1007
|
+
|
1008
|
+
def header_line
|
1009
|
+
"Invalid ignore comment"
|
1010
|
+
end
|
1011
|
+
end
|
1012
|
+
|
1000
1013
|
ALL = ObjectSpace.each_object(Class).with_object([]) do |klass, array|
|
1001
1014
|
if klass < Base
|
1002
1015
|
array << klass
|
@@ -1028,6 +1041,7 @@ module Steep
|
|
1028
1041
|
InsufficientKeywordArguments => :error,
|
1029
1042
|
InsufficientPositionalArguments => :error,
|
1030
1043
|
InsufficientTypeArgument => :hint,
|
1044
|
+
InvalidIgnoreComment => :warning,
|
1031
1045
|
MethodArityMismatch => :error,
|
1032
1046
|
MethodBodyTypeMismatch => :error,
|
1033
1047
|
MethodDefinitionMissing => nil,
|
@@ -1086,6 +1100,7 @@ module Steep
|
|
1086
1100
|
InsufficientKeywordArguments => :error,
|
1087
1101
|
InsufficientPositionalArguments => :error,
|
1088
1102
|
InsufficientTypeArgument => :error,
|
1103
|
+
InvalidIgnoreComment => :warning,
|
1089
1104
|
MethodArityMismatch => :error,
|
1090
1105
|
MethodBodyTypeMismatch => :error,
|
1091
1106
|
MethodDefinitionMissing => :hint,
|
@@ -1144,6 +1159,7 @@ module Steep
|
|
1144
1159
|
InsufficientKeywordArguments => :information,
|
1145
1160
|
InsufficientPositionalArguments => :information,
|
1146
1161
|
InsufficientTypeArgument => nil,
|
1162
|
+
InvalidIgnoreComment => :warning,
|
1147
1163
|
MethodArityMismatch => :information,
|
1148
1164
|
MethodBodyTypeMismatch => :warning,
|
1149
1165
|
MethodDefinitionMissing => nil,
|
data/lib/steep/drivers/stats.rb
CHANGED
@@ -83,7 +83,7 @@ module Steep
|
|
83
83
|
end
|
84
84
|
end
|
85
85
|
|
86
|
-
table = Terminal::Table.new(
|
86
|
+
table = Terminal::Table.new( # steep:ignore UnknownConstant
|
87
87
|
headings: ["Target", "File", "Status", "Typed calls", "Untyped calls", "All calls", "Typed %"],
|
88
88
|
rows: rows
|
89
89
|
)
|
@@ -166,7 +166,7 @@ module Steep
|
|
166
166
|
{
|
167
167
|
id: stats_id,
|
168
168
|
method: "workspace/executeCommand",
|
169
|
-
params: { command: "steep/stats", arguments: [] }
|
169
|
+
params: { command: "steep/stats", arguments: _ = [] }
|
170
170
|
})
|
171
171
|
|
172
172
|
stats_response = wait_for_response_id(reader: client_reader, id: stats_id)
|
@@ -5,18 +5,29 @@ module Steep
|
|
5
5
|
attr_accessor :steepfile
|
6
6
|
|
7
7
|
def load_config(path: steepfile || Pathname("Steepfile"))
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
8
|
+
if path.file?
|
9
|
+
steep_file_path = path.absolute? ? path : Pathname.pwd + path
|
10
|
+
Project.new(steepfile_path: steep_file_path).tap do |project|
|
11
|
+
Project::DSL.parse(project, path.read, filename: path.to_s)
|
12
|
+
end
|
13
|
+
else
|
14
|
+
Steep.ui_logger.error { "Cannot find a configuration at #{path}: `steep init` to scaffold. Using current directory..." }
|
15
|
+
Project.new(steepfile_path: nil, base_dir: Pathname.pwd).tap do |project|
|
16
|
+
Project::DSL.new(project: project).target :'.' do
|
17
|
+
check '.'
|
18
|
+
signature '.'
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end.tap do |project|
|
14
22
|
project.targets.each do |target|
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
23
|
+
case result = target.options.load_collection_lock
|
24
|
+
when nil, RBS::Collection::Config::Lockfile
|
25
|
+
# ok
|
26
|
+
else
|
27
|
+
if result == target.options.collection_config_path
|
28
|
+
Steep.ui_logger.error { "rbs-collection setup is broken: `#{result}` is missing" }
|
29
|
+
else
|
30
|
+
Steep.ui_logger.error { "Run `rbs collection install` to install type definitions" }
|
20
31
|
end
|
21
32
|
end
|
22
33
|
end
|
data/lib/steep/expectations.rb
CHANGED
@@ -23,7 +23,7 @@ module Steep
|
|
23
23
|
:information
|
24
24
|
when "HINT"
|
25
25
|
:hint
|
26
|
-
end #: Diagnostic::LSPFormatter::severity
|
26
|
+
end #: Steep::Diagnostic::LSPFormatter::severity
|
27
27
|
|
28
28
|
Diagnostic.new(
|
29
29
|
start_position: start_position,
|
@@ -56,7 +56,7 @@ module Steep
|
|
56
56
|
:hint
|
57
57
|
else
|
58
58
|
:error
|
59
|
-
end #: Diagnostic::LSPFormatter::severity
|
59
|
+
end #: Steep::Diagnostic::LSPFormatter::severity
|
60
60
|
|
61
61
|
Diagnostic.new(
|
62
62
|
start_position: start_position,
|
@@ -82,7 +82,7 @@ module Steep
|
|
82
82
|
def +(other)
|
83
83
|
optional = self.optional? || other.optional?
|
84
84
|
type = Function.new(
|
85
|
-
params: self.type.params + other.type.params,
|
85
|
+
params: self.type.params && other.type.params ? self.type.params + other.type.params : nil,
|
86
86
|
return_type: AST::Types::Union.build(types: [self.type.return_type, other.type.return_type]),
|
87
87
|
location: nil
|
88
88
|
)
|