packwerk 3.2.0 → 3.2.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (126) hide show
  1. checksums.yaml +4 -4
  2. data/lib/packwerk/checker.rb +3 -3
  3. data/lib/packwerk/offenses_formatter.rb +3 -3
  4. data/lib/packwerk/package_todo.rb +1 -4
  5. data/lib/packwerk/parsers/factory.rb +3 -3
  6. data/lib/packwerk/parsers/ruby.rb +7 -0
  7. data/lib/packwerk/reference_offense.rb +1 -1
  8. data/lib/packwerk/validator.rb +3 -3
  9. data/lib/packwerk/version.rb +1 -1
  10. data/sorbet/rbi/gems/actionpack@7.0.3.1.rbi +3280 -3450
  11. data/sorbet/rbi/gems/actionview@7.0.3.1.rbi +2322 -1782
  12. data/sorbet/rbi/gems/activesupport@7.0.3.1.rbi +2654 -3268
  13. data/sorbet/rbi/gems/ast@2.4.2.rbi +535 -6
  14. data/sorbet/rbi/gems/better_html@2.0.1.rbi +529 -0
  15. data/sorbet/rbi/gems/builder@3.2.4.rbi +4 -4
  16. data/sorbet/rbi/gems/byebug@11.1.3.rbi +32 -4
  17. data/sorbet/rbi/gems/concurrent-ruby@1.1.10.rbi +1750 -1840
  18. data/sorbet/rbi/gems/constant_resolver@0.2.0.rbi +15 -15
  19. data/sorbet/rbi/gems/crass@1.0.6.rbi +489 -5
  20. data/sorbet/rbi/gems/erubi@1.11.0.rbi +24 -21
  21. data/sorbet/rbi/gems/i18n@1.12.0.rbi +395 -395
  22. data/sorbet/rbi/gems/json@2.6.2.rbi +70 -77
  23. data/sorbet/rbi/gems/language_server-protocol@3.16.0.3.rbi +1 -1
  24. data/sorbet/rbi/gems/loofah@2.18.0.rbi +134 -134
  25. data/sorbet/rbi/gems/m@1.6.0.rbi +60 -60
  26. data/sorbet/rbi/gems/method_source@1.1.0.rbi +303 -0
  27. data/sorbet/rbi/gems/minitest-focus@1.3.1.rbi +22 -28
  28. data/sorbet/rbi/gems/minitest@5.16.2.rbi +384 -396
  29. data/sorbet/rbi/gems/mocha@1.14.0.rbi +589 -589
  30. data/sorbet/rbi/gems/netrc@0.11.0.rbi +37 -32
  31. data/sorbet/rbi/gems/nokogiri@1.15.3.rbi +962 -946
  32. data/sorbet/rbi/gems/{parallel@1.22.1.rbi → parallel@1.24.0.rbi} +85 -82
  33. data/sorbet/rbi/gems/{parser@3.2.2.0.rbi → parser@3.3.1.0.rbi} +1679 -1609
  34. data/sorbet/rbi/gems/prettier_print@0.1.0.rbi +1 -1
  35. data/sorbet/rbi/gems/{prism@0.24.0.rbi → prism@0.27.0.rbi} +13473 -6472
  36. data/sorbet/rbi/gems/{racc@1.6.0.rbi → racc@1.7.1.rbi} +42 -33
  37. data/sorbet/rbi/gems/rack-test@2.0.2.rbi +148 -338
  38. data/sorbet/rbi/gems/rack@2.2.4.rbi +1079 -1130
  39. data/sorbet/rbi/gems/rails-dom-testing@2.0.3.rbi +354 -22
  40. data/sorbet/rbi/gems/rails-html-sanitizer@1.4.3.rbi +113 -259
  41. data/sorbet/rbi/gems/railties@7.0.3.1.rbi +642 -638
  42. data/sorbet/rbi/gems/rainbow@3.1.1.rbi +109 -99
  43. data/sorbet/rbi/gems/rake@13.0.6.rbi +714 -599
  44. data/sorbet/rbi/gems/{rbi@0.0.15.rbi → rbi@0.1.12.rbi} +865 -801
  45. data/sorbet/rbi/gems/regexp_parser@2.5.0.rbi +853 -870
  46. data/sorbet/rbi/gems/rexml@3.2.5.rbi +480 -477
  47. data/sorbet/rbi/gems/rubocop-ast@1.21.0.rbi +1621 -1622
  48. data/sorbet/rbi/gems/rubocop-performance@1.14.3.rbi +507 -526
  49. data/sorbet/rbi/gems/rubocop-shopify@2.9.0.rbi +1 -1
  50. data/sorbet/rbi/gems/rubocop-sorbet@0.6.11.rbi +186 -203
  51. data/sorbet/rbi/gems/rubocop@1.34.1.rbi +8126 -8367
  52. data/sorbet/rbi/gems/{ruby-lsp@0.2.1.rbi → ruby-lsp@0.2.3.rbi} +2 -2
  53. data/sorbet/rbi/gems/ruby-progressbar@1.11.0.rbi +1235 -4
  54. data/sorbet/rbi/gems/smart_properties@1.17.0.rbi +90 -90
  55. data/sorbet/rbi/gems/spoom@1.3.2.rbi +4420 -0
  56. data/sorbet/rbi/gems/spring@4.0.0.rbi +104 -104
  57. data/sorbet/rbi/gems/syntax_tree@3.3.0.rbi +1 -1
  58. data/sorbet/rbi/gems/{tapioca@0.9.2.rbi → tapioca@0.13.3.rbi} +1596 -1253
  59. data/sorbet/rbi/gems/{thor@1.2.1.rbi → thor@1.3.1.rbi} +1047 -652
  60. data/sorbet/rbi/gems/tzinfo@2.0.5.rbi +531 -513
  61. data/sorbet/rbi/gems/unicode-display_width@2.2.0.rbi +13 -13
  62. data/sorbet/rbi/gems/{yard-sorbet@0.6.1.rbi → yard-sorbet@0.8.1.rbi} +132 -92
  63. data/sorbet/rbi/gems/{yard@0.9.28.rbi → yard@0.9.36.rbi} +3158 -3067
  64. data/sorbet/rbi/gems/zeitwerk@2.6.4.rbi +149 -145
  65. metadata +18 -76
  66. data/.github/ISSUE_TEMPLATE/bug_report.md +0 -27
  67. data/.github/pull_request_template.md +0 -28
  68. data/.github/workflows/ci.yml +0 -93
  69. data/.github/workflows/cla.yml +0 -22
  70. data/.gitignore +0 -13
  71. data/.rubocop.yml +0 -75
  72. data/.ruby-version +0 -1
  73. data/CODEOWNERS +0 -1
  74. data/CODE_OF_CONDUCT.md +0 -76
  75. data/CONTRIBUTING.md +0 -17
  76. data/Gemfile +0 -27
  77. data/Gemfile.lock +0 -206
  78. data/RESOLVING_VIOLATIONS.md +0 -76
  79. data/Rakefile +0 -22
  80. data/TROUBLESHOOT.md +0 -44
  81. data/UPGRADING.md +0 -66
  82. data/USAGE.md +0 -364
  83. data/bin/console +0 -15
  84. data/bin/m +0 -29
  85. data/bin/rake +0 -29
  86. data/bin/rubocop +0 -29
  87. data/bin/setup +0 -8
  88. data/bin/srb +0 -29
  89. data/bin/tapioca +0 -29
  90. data/dev.yml +0 -32
  91. data/docs/cohesion.png +0 -0
  92. data/gemfiles/Gemfile-rails-6-0 +0 -22
  93. data/gemfiles/Gemfile-rails-6-1 +0 -22
  94. data/packwerk.gemspec +0 -59
  95. data/shipit.rubygems.yml +0 -5
  96. data/sorbet/rbi/gems/actioncable@7.0.3.1.rbi +0 -2754
  97. data/sorbet/rbi/gems/actionmailbox@7.0.3.1.rbi +0 -1496
  98. data/sorbet/rbi/gems/actionmailer@7.0.3.1.rbi +0 -2362
  99. data/sorbet/rbi/gems/actiontext@7.0.3.1.rbi +0 -1569
  100. data/sorbet/rbi/gems/activejob@7.0.3.1.rbi +0 -2553
  101. data/sorbet/rbi/gems/activemodel@7.0.3.1.rbi +0 -5999
  102. data/sorbet/rbi/gems/activerecord@7.0.3.1.rbi +0 -37832
  103. data/sorbet/rbi/gems/activestorage@7.0.3.1.rbi +0 -2321
  104. data/sorbet/rbi/gems/better_html@1.0.16.rbi +0 -317
  105. data/sorbet/rbi/gems/coderay@1.1.3.rbi +0 -8
  106. data/sorbet/rbi/gems/diff-lcs@1.5.0.rbi +0 -1079
  107. data/sorbet/rbi/gems/digest@3.1.0.rbi +0 -189
  108. data/sorbet/rbi/gems/globalid@1.0.0.rbi +0 -572
  109. data/sorbet/rbi/gems/mail@2.7.1.rbi +0 -2490
  110. data/sorbet/rbi/gems/marcel@1.0.2.rbi +0 -220
  111. data/sorbet/rbi/gems/method_source@1.0.0.rbi +0 -76
  112. data/sorbet/rbi/gems/mini_mime@1.1.2.rbi +0 -170
  113. data/sorbet/rbi/gems/net-imap@0.2.3.rbi +0 -2147
  114. data/sorbet/rbi/gems/net-pop@0.1.1.rbi +0 -926
  115. data/sorbet/rbi/gems/net-protocol@0.1.3.rbi +0 -11
  116. data/sorbet/rbi/gems/net-smtp@0.3.1.rbi +0 -1108
  117. data/sorbet/rbi/gems/nio4r@2.5.8.rbi +0 -292
  118. data/sorbet/rbi/gems/pry@0.14.1.rbi +0 -8
  119. data/sorbet/rbi/gems/rails@7.0.3.1.rbi +0 -8
  120. data/sorbet/rbi/gems/spoom@1.1.11.rbi +0 -2181
  121. data/sorbet/rbi/gems/strscan@3.0.4.rbi +0 -8
  122. data/sorbet/rbi/gems/timeout@0.3.0.rbi +0 -142
  123. data/sorbet/rbi/gems/unparser@0.6.5.rbi +0 -4529
  124. data/sorbet/rbi/gems/webrick@1.7.0.rbi +0 -2582
  125. data/sorbet/rbi/gems/websocket-driver@0.7.5.rbi +0 -993
  126. data/sorbet/rbi/gems/websocket-extensions@0.1.5.rbi +0 -71
@@ -7,251 +7,251 @@
7
7
  # Runners are in charge of running your tests, depending on the framework
8
8
  # Instead of slamming all of this junk in an `M` class, it's here instead.
9
9
  #
10
- # source://m-1.6.0/lib/m/version.rb:1
10
+ # source://m//lib/m/version.rb#1
11
11
  module M
12
12
  class << self
13
13
  # Accept arguments coming from bin/m and run tests, then bail out immediately.
14
14
  #
15
- # source://m-1.6.0/lib/m.rb:9
15
+ # source://m//lib/m.rb#9
16
16
  def run(argv); end
17
17
  end
18
18
  end
19
19
 
20
- # source://m-1.6.0/lib/m/executor.rb:8
20
+ # source://m//lib/m/executor.rb#8
21
21
  class M::Executor
22
22
  # @return [Executor] a new instance of Executor
23
23
  #
24
- # source://m-1.6.0/lib/m/executor.rb:9
24
+ # source://m//lib/m/executor.rb#9
25
25
  def initialize(testable); end
26
26
 
27
- # source://m-1.6.0/lib/m/executor.rb:13
27
+ # source://m//lib/m/executor.rb#13
28
28
  def execute; end
29
29
 
30
30
  private
31
31
 
32
- # source://m-1.6.0/lib/m/executor.rb:96
32
+ # source://m//lib/m/executor.rb#96
33
33
  def runner; end
34
34
 
35
35
  # Finds all test suites in this test file, with test methods included.
36
36
  #
37
- # source://m-1.6.0/lib/m/executor.rb:72
37
+ # source://m//lib/m/executor.rb#72
38
38
  def suites; end
39
39
 
40
40
  # Returns the value of attribute testable.
41
41
  #
42
- # source://m-1.6.0/lib/m/executor.rb:50
42
+ # source://m//lib/m/executor.rb#50
43
43
  def testable; end
44
44
 
45
45
  # Shoves tests together in our custom container and collection classes.
46
46
  # Memoize it since it's unnecessary to do this more than one for a given file.
47
47
  #
48
- # source://m-1.6.0/lib/m/executor.rb:54
48
+ # source://m//lib/m/executor.rb#54
49
49
  def tests; end
50
50
  end
51
51
 
52
- # source://m-1.6.0/lib/m/frameworks.rb:2
52
+ # source://m//lib/m/frameworks.rb#2
53
53
  class M::Frameworks
54
- # source://m-1.6.0/lib/m/frameworks.rb:7
54
+ # source://m//lib/m/frameworks.rb#7
55
55
  def framework_runner; end
56
56
 
57
57
  private
58
58
 
59
59
  # @return [Boolean]
60
60
  #
61
- # source://m-1.6.0/lib/m/frameworks.rb:25
61
+ # source://m//lib/m/frameworks.rb#25
62
62
  def minitest4?; end
63
63
 
64
64
  # @return [Boolean]
65
65
  #
66
- # source://m-1.6.0/lib/m/frameworks.rb:21
66
+ # source://m//lib/m/frameworks.rb#21
67
67
  def minitest5?; end
68
68
 
69
69
  # @return [Boolean]
70
70
  #
71
- # source://m-1.6.0/lib/m/frameworks.rb:29
71
+ # source://m//lib/m/frameworks.rb#29
72
72
  def test_unit?; end
73
73
 
74
74
  class << self
75
- # source://m-1.6.0/lib/m/frameworks.rb:3
75
+ # source://m//lib/m/frameworks.rb#3
76
76
  def framework_runner; end
77
77
 
78
78
  # @return [Boolean]
79
79
  #
80
- # source://m-1.6.0/lib/m/frameworks.rb:41
80
+ # source://m//lib/m/frameworks.rb#41
81
81
  def minitest4?; end
82
82
 
83
83
  # @return [Boolean]
84
84
  #
85
- # source://m-1.6.0/lib/m/frameworks.rb:37
85
+ # source://m//lib/m/frameworks.rb#37
86
86
  def minitest5?; end
87
87
 
88
- # source://m-1.6.0/lib/m/frameworks.rb:33
88
+ # source://m//lib/m/frameworks.rb#33
89
89
  def minitest_version_major; end
90
90
 
91
91
  # @return [Boolean]
92
92
  #
93
- # source://m-1.6.0/lib/m/frameworks.rb:45
93
+ # source://m//lib/m/frameworks.rb#45
94
94
  def test_unit?; end
95
95
  end
96
96
  end
97
97
 
98
- # source://m-1.6.0/lib/m/parser.rb:4
98
+ # source://m//lib/m/parser.rb#4
99
99
  class M::Parser
100
100
  # @return [Parser] a new instance of Parser
101
101
  #
102
- # source://m-1.6.0/lib/m/parser.rb:5
102
+ # source://m//lib/m/parser.rb#5
103
103
  def initialize(argv); end
104
104
 
105
- # source://m-1.6.0/lib/m/parser.rb:10
105
+ # source://m//lib/m/parser.rb#10
106
106
  def parse; end
107
107
 
108
108
  private
109
109
 
110
110
  # Returns the value of attribute argv.
111
111
  #
112
- # source://m-1.6.0/lib/m/parser.rb:56
112
+ # source://m//lib/m/parser.rb#56
113
113
  def argv; end
114
114
 
115
- # source://m-1.6.0/lib/m/parser.rb:58
115
+ # source://m//lib/m/parser.rb#58
116
116
  def parse_options!(argv); end
117
117
 
118
118
  # Returns the value of attribute testable.
119
119
  #
120
- # source://m-1.6.0/lib/m/parser.rb:56
120
+ # source://m//lib/m/parser.rb#56
121
121
  def testable; end
122
122
 
123
- # source://m-1.6.0/lib/m/parser.rb:89
123
+ # source://m//lib/m/parser.rb#89
124
124
  def wildcard(type); end
125
125
  end
126
126
 
127
- # source://m-1.6.0/lib/m/runner.rb:7
127
+ # source://m//lib/m/runner.rb#7
128
128
  class M::Runner
129
129
  # @return [Runner] a new instance of Runner
130
130
  #
131
- # source://m-1.6.0/lib/m/runner.rb:8
131
+ # source://m//lib/m/runner.rb#8
132
132
  def initialize(argv); end
133
133
 
134
134
  # There's two steps to running our tests:
135
135
  # 1. Parsing the given input for the tests we need to find (or groups of tests)
136
136
  # 2. Run those tests we found that match what you wanted
137
137
  #
138
- # source://m-1.6.0/lib/m/runner.rb:15
138
+ # source://m//lib/m/runner.rb#15
139
139
  def run; end
140
140
  end
141
141
 
142
- # source://m-1.6.0/lib/m/runners/base.rb:2
142
+ # source://m//lib/m/runners/base.rb#2
143
143
  module M::Runners; end
144
144
 
145
- # source://m-1.6.0/lib/m/runners/base.rb:3
145
+ # source://m//lib/m/runners/base.rb#3
146
146
  class M::Runners::Base
147
- # source://m-1.6.0/lib/m/runners/base.rb:8
147
+ # source://m//lib/m/runners/base.rb#8
148
148
  def run(_test_arguments); end
149
149
 
150
- # source://m-1.6.0/lib/m/runners/base.rb:4
150
+ # source://m//lib/m/runners/base.rb#4
151
151
  def suites; end
152
152
 
153
- # source://m-1.6.0/lib/m/runners/base.rb:12
153
+ # source://m//lib/m/runners/base.rb#12
154
154
  def test_methods(suite_class); end
155
155
  end
156
156
 
157
- # source://m-1.6.0/lib/m/runners/minitest_4.rb:3
157
+ # source://m//lib/m/runners/minitest_4.rb#3
158
158
  class M::Runners::Minitest4 < ::M::Runners::Base
159
- # source://m-1.6.0/lib/m/runners/minitest_4.rb:8
159
+ # source://m//lib/m/runners/minitest_4.rb#8
160
160
  def run(test_arguments); end
161
161
 
162
- # source://m-1.6.0/lib/m/runners/minitest_4.rb:4
162
+ # source://m//lib/m/runners/minitest_4.rb#4
163
163
  def suites; end
164
164
  end
165
165
 
166
- # source://m-1.6.0/lib/m/runners/minitest_5.rb:3
166
+ # source://m//lib/m/runners/minitest_5.rb#3
167
167
  class M::Runners::Minitest5 < ::M::Runners::Base
168
- # source://m-1.6.0/lib/m/runners/minitest_5.rb:8
168
+ # source://m//lib/m/runners/minitest_5.rb#8
169
169
  def run(test_arguments); end
170
170
 
171
- # source://m-1.6.0/lib/m/runners/minitest_5.rb:4
171
+ # source://m//lib/m/runners/minitest_5.rb#4
172
172
  def suites; end
173
173
 
174
- # source://m-1.6.0/lib/m/runners/minitest_5.rb:14
174
+ # source://m//lib/m/runners/minitest_5.rb#14
175
175
  def test_methods(suite_class); end
176
176
  end
177
177
 
178
- # source://m-1.6.0/lib/m/runners/test_unit.rb:3
178
+ # source://m//lib/m/runners/test_unit.rb#3
179
179
  class M::Runners::TestUnit < ::M::Runners::Base
180
- # source://m-1.6.0/lib/m/runners/test_unit.rb:12
180
+ # source://m//lib/m/runners/test_unit.rb#12
181
181
  def run(test_arguments); end
182
182
 
183
- # source://m-1.6.0/lib/m/runners/test_unit.rb:4
183
+ # source://m//lib/m/runners/test_unit.rb#4
184
184
  def suites; end
185
185
 
186
- # source://m-1.6.0/lib/m/runners/test_unit.rb:16
186
+ # source://m//lib/m/runners/test_unit.rb#16
187
187
  def test_methods(suite_class); end
188
188
  end
189
189
 
190
- # source://m-1.6.0/lib/m/runners/unsupported_framework.rb:3
190
+ # source://m//lib/m/runners/unsupported_framework.rb#3
191
191
  class M::Runners::UnsupportedFramework < ::M::Runners::Base
192
- # source://m-1.6.0/lib/m/runners/unsupported_framework.rb:9
192
+ # source://m//lib/m/runners/unsupported_framework.rb#9
193
193
  def run(_test_arguments); end
194
194
 
195
- # source://m-1.6.0/lib/m/runners/unsupported_framework.rb:4
195
+ # source://m//lib/m/runners/unsupported_framework.rb#4
196
196
  def suites; end
197
197
 
198
198
  private
199
199
 
200
- # source://m-1.6.0/lib/m/runners/unsupported_framework.rb:15
200
+ # source://m//lib/m/runners/unsupported_framework.rb#15
201
201
  def not_supported; end
202
202
  end
203
203
 
204
- # source://m-1.6.0/lib/m/testable.rb:2
204
+ # source://m//lib/m/testable.rb#2
205
205
  class M::Testable
206
206
  # @return [Testable] a new instance of Testable
207
207
  #
208
- # source://m-1.6.0/lib/m/testable.rb:6
208
+ # source://m//lib/m/testable.rb#6
209
209
  def initialize(file = T.unsafe(nil), lines = T.unsafe(nil), recursive = T.unsafe(nil)); end
210
210
 
211
211
  # Returns the value of attribute file.
212
212
  #
213
- # source://m-1.6.0/lib/m/testable.rb:3
213
+ # source://m//lib/m/testable.rb#3
214
214
  def file; end
215
215
 
216
216
  # Sets the attribute file
217
217
  #
218
218
  # @param value the value to set the attribute file to.
219
219
  #
220
- # source://m-1.6.0/lib/m/testable.rb:3
220
+ # source://m//lib/m/testable.rb#3
221
221
  def file=(_arg0); end
222
222
 
223
223
  # Returns the value of attribute lines.
224
224
  #
225
- # source://m-1.6.0/lib/m/testable.rb:4
225
+ # source://m//lib/m/testable.rb#4
226
226
  def lines; end
227
227
 
228
- # source://m-1.6.0/lib/m/testable.rb:13
228
+ # source://m//lib/m/testable.rb#13
229
229
  def lines=(lines); end
230
230
 
231
231
  # Returns the value of attribute passthrough_options.
232
232
  #
233
- # source://m-1.6.0/lib/m/testable.rb:3
233
+ # source://m//lib/m/testable.rb#3
234
234
  def passthrough_options; end
235
235
 
236
236
  # Sets the attribute passthrough_options
237
237
  #
238
238
  # @param value the value to set the attribute passthrough_options to.
239
239
  #
240
- # source://m-1.6.0/lib/m/testable.rb:3
240
+ # source://m//lib/m/testable.rb#3
241
241
  def passthrough_options=(_arg0); end
242
242
 
243
243
  # Returns the value of attribute recursive.
244
244
  #
245
- # source://m-1.6.0/lib/m/testable.rb:3
245
+ # source://m//lib/m/testable.rb#3
246
246
  def recursive; end
247
247
 
248
248
  # Sets the attribute recursive
249
249
  #
250
250
  # @param value the value to set the attribute recursive to.
251
251
  #
252
- # source://m-1.6.0/lib/m/testable.rb:3
252
+ # source://m//lib/m/testable.rb#3
253
253
  def recursive=(_arg0); end
254
254
  end
255
255
 
256
- # source://m-1.6.0/lib/m/version.rb:2
256
+ # source://m//lib/m/version.rb#2
257
257
  M::VERSION = T.let(T.unsafe(nil), String)
@@ -0,0 +1,303 @@
1
+ # typed: true
2
+
3
+ # DO NOT EDIT MANUALLY
4
+ # This is an autogenerated file for types exported from the `method_source` gem.
5
+ # Please instead update this file by running `bin/tapioca gem method_source`.
6
+
7
+ # source://method_source//lib/method_source.rb#163
8
+ class Method
9
+ include ::MethodSource::SourceLocation::MethodExtensions
10
+ include ::MethodSource::MethodExtensions
11
+ end
12
+
13
+ # source://method_source//lib/method_source/version.rb#1
14
+ module MethodSource
15
+ extend ::MethodSource::CodeHelpers
16
+
17
+ class << self
18
+ # Clear cache.
19
+ #
20
+ # source://method_source//lib/method_source.rb#59
21
+ def clear_cache; end
22
+
23
+ # Helper method responsible for opening source file and buffering up
24
+ # the comments for a specified method. Defined here to avoid polluting
25
+ # `Method` class.
26
+ #
27
+ # @param source_location [Array] The array returned by Method#source_location
28
+ # @param method_name [String]
29
+ # @raise [SourceNotFoundError]
30
+ # @return [String] The comments up to the point of the method.
31
+ #
32
+ # source://method_source//lib/method_source.rb#38
33
+ def comment_helper(source_location, name = T.unsafe(nil)); end
34
+
35
+ # @deprecated — use MethodSource::CodeHelpers#expression_at
36
+ #
37
+ # source://method_source//lib/method_source.rb#71
38
+ def extract_code(source_location); end
39
+
40
+ # Load a memoized copy of the lines in a file.
41
+ #
42
+ # @param file_name [String]
43
+ # @param method_name [String]
44
+ # @raise [SourceNotFoundError]
45
+ # @return [Array<String>] the contents of the file
46
+ #
47
+ # source://method_source//lib/method_source.rb#51
48
+ def lines_for(file_name, name = T.unsafe(nil)); end
49
+
50
+ # Helper method responsible for extracting method body.
51
+ # Defined here to avoid polluting `Method` class.
52
+ #
53
+ # @param source_location [Array] The array returned by Method#source_location
54
+ # @param method_name [String]
55
+ # @return [String] The method body
56
+ #
57
+ # source://method_source//lib/method_source.rb#23
58
+ def source_helper(source_location, name = T.unsafe(nil)); end
59
+
60
+ # @deprecated — use MethodSource::CodeHelpers#complete_expression?
61
+ # @return [Boolean]
62
+ #
63
+ # source://method_source//lib/method_source.rb#64
64
+ def valid_expression?(str); end
65
+ end
66
+ end
67
+
68
+ # source://method_source//lib/method_source/code_helpers.rb#3
69
+ module MethodSource::CodeHelpers
70
+ # Retrieve the comment describing the expression on the given line of the given file.
71
+ #
72
+ # This is useful to get module or method documentation.
73
+ #
74
+ # @param file [Array<String>, File, String] The file to parse, either as a File or as
75
+ # a String or an Array of lines.
76
+ # @param line_number [Integer] The line number at which to look.
77
+ # NOTE: The first line in a file is line 1!
78
+ # @return [String] The comment
79
+ #
80
+ # source://method_source//lib/method_source/code_helpers.rb#52
81
+ def comment_describing(file, line_number); end
82
+
83
+ # Determine if a string of code is a complete Ruby expression.
84
+ #
85
+ # @example
86
+ # complete_expression?("class Hello") #=> false
87
+ # complete_expression?("class Hello; end") #=> true
88
+ # complete_expression?("class 123") #=> SyntaxError: unexpected tINTEGER
89
+ # @param code [String] The code to validate.
90
+ # @raise [SyntaxError] Any SyntaxError that does not represent incompleteness.
91
+ # @return [Boolean] Whether or not the code is a complete Ruby expression.
92
+ #
93
+ # source://method_source//lib/method_source/code_helpers.rb#66
94
+ def complete_expression?(str); end
95
+
96
+ # Retrieve the first expression starting on the given line of the given file.
97
+ #
98
+ # This is useful to get module or method source code.
99
+ #
100
+ # line 1!
101
+ #
102
+ # @option options
103
+ # @option options
104
+ # @param file [Array<String>, File, String] The file to parse, either as a File or as
105
+ # @param line_number [Integer] The line number at which to look.
106
+ # NOTE: The first line in a file is
107
+ # @param options [Hash] The optional configuration parameters.
108
+ # @raise [SyntaxError] If the first complete expression can't be identified
109
+ # @return [String] The first complete expression
110
+ #
111
+ # source://method_source//lib/method_source/code_helpers.rb#20
112
+ def expression_at(file, line_number, options = T.unsafe(nil)); end
113
+
114
+ private
115
+
116
+ # Get the first expression from the input.
117
+ #
118
+ # @param lines [Array<String>]
119
+ # @param consume [Integer] A number of lines to automatically
120
+ # consume (add to the expression buffer) without checking for validity.
121
+ # @raise [SyntaxError]
122
+ # @return [String] a valid ruby expression
123
+ # @yield a clean-up function to run before checking for complete_expression
124
+ #
125
+ # source://method_source//lib/method_source/code_helpers.rb#92
126
+ def extract_first_expression(lines, consume = T.unsafe(nil), &block); end
127
+
128
+ # Get the last comment from the input.
129
+ #
130
+ # @param lines [Array<String>]
131
+ # @return [String]
132
+ #
133
+ # source://method_source//lib/method_source/code_helpers.rb#106
134
+ def extract_last_comment(lines); end
135
+ end
136
+
137
+ # An exception matcher that matches only subsets of SyntaxErrors that can be
138
+ # fixed by adding more input to the buffer.
139
+ #
140
+ # source://method_source//lib/method_source/code_helpers.rb#124
141
+ module MethodSource::CodeHelpers::IncompleteExpression
142
+ class << self
143
+ # source://method_source//lib/method_source/code_helpers.rb#137
144
+ def ===(ex); end
145
+
146
+ # @return [Boolean]
147
+ #
148
+ # source://method_source//lib/method_source/code_helpers.rb#149
149
+ def rbx?; end
150
+ end
151
+ end
152
+
153
+ # source://method_source//lib/method_source/code_helpers.rb#125
154
+ MethodSource::CodeHelpers::IncompleteExpression::GENERIC_REGEXPS = T.let(T.unsafe(nil), Array)
155
+
156
+ # source://method_source//lib/method_source/code_helpers.rb#133
157
+ MethodSource::CodeHelpers::IncompleteExpression::RBX_ONLY_REGEXPS = T.let(T.unsafe(nil), Array)
158
+
159
+ # This module is to be included by `Method` and `UnboundMethod` and
160
+ # provides the `#source` functionality
161
+ #
162
+ # source://method_source//lib/method_source.rb#77
163
+ module MethodSource::MethodExtensions
164
+ # Return the comments associated with the method class/module.
165
+ #
166
+ # @example
167
+ # MethodSource::MethodExtensions.method(:included).module_comment
168
+ # =>
169
+ # # This module is to be included by `Method` and `UnboundMethod` and
170
+ # # provides the `#source` functionality
171
+ # @raise SourceNotFoundException
172
+ # @return [String] The method's comments as a string
173
+ #
174
+ # source://method_source//lib/method_source.rb#139
175
+ def class_comment; end
176
+
177
+ # Return the comments associated with the method as a string.
178
+ #
179
+ # @example
180
+ # Set.instance_method(:clear).comment.display
181
+ # =>
182
+ # # Removes all elements and returns self.
183
+ # @raise SourceNotFoundException
184
+ # @return [String] The method's comments as a string
185
+ #
186
+ # source://method_source//lib/method_source.rb#126
187
+ def comment; end
188
+
189
+ # Return the comments associated with the method class/module.
190
+ #
191
+ # @example
192
+ # MethodSource::MethodExtensions.method(:included).module_comment
193
+ # =>
194
+ # # This module is to be included by `Method` and `UnboundMethod` and
195
+ # # provides the `#source` functionality
196
+ # @raise SourceNotFoundException
197
+ # @return [String] The method's comments as a string
198
+ #
199
+ # source://method_source//lib/method_source.rb#139
200
+ def module_comment; end
201
+
202
+ # Return the sourcecode for the method as a string
203
+ #
204
+ # @example
205
+ # Set.instance_method(:clear).source.display
206
+ # =>
207
+ # def clear
208
+ # @hash.clear
209
+ # self
210
+ # end
211
+ # @raise SourceNotFoundException
212
+ # @return [String] The method sourcecode as a string
213
+ #
214
+ # source://method_source//lib/method_source.rb#114
215
+ def source; end
216
+
217
+ class << self
218
+ # We use the included hook to patch Method#source on rubinius.
219
+ # We need to use the included hook as Rubinius defines a `source`
220
+ # on Method so including a module will have no effect (as it's
221
+ # higher up the MRO).
222
+ #
223
+ # @param klass [Class] The class that includes the module.
224
+ #
225
+ # source://method_source//lib/method_source.rb#84
226
+ def included(klass); end
227
+ end
228
+ end
229
+
230
+ # source://method_source//lib/method_source/source_location.rb#2
231
+ module MethodSource::ReeSourceLocation
232
+ # Ruby enterprise edition provides all the information that's
233
+ # needed, in a slightly different way.
234
+ #
235
+ # source://method_source//lib/method_source/source_location.rb#5
236
+ def source_location; end
237
+ end
238
+
239
+ # source://method_source//lib/method_source/source_location.rb#10
240
+ module MethodSource::SourceLocation; end
241
+
242
+ # source://method_source//lib/method_source/source_location.rb#11
243
+ module MethodSource::SourceLocation::MethodExtensions
244
+ # Return the source location of a method for Ruby 1.8.
245
+ #
246
+ # @return [Array] A two element array. First element is the
247
+ # file, second element is the line in the file where the
248
+ # method definition is found.
249
+ #
250
+ # source://method_source//lib/method_source/source_location.rb#40
251
+ def source_location; end
252
+
253
+ private
254
+
255
+ # source://method_source//lib/method_source/source_location.rb#26
256
+ def trace_func(event, file, line, id, binding, classname); end
257
+ end
258
+
259
+ # source://method_source//lib/method_source/source_location.rb#54
260
+ module MethodSource::SourceLocation::ProcExtensions
261
+ # Return the source location for a Proc (in implementations
262
+ # without Proc#source_location)
263
+ #
264
+ # @return [Array] A two element array. First element is the
265
+ # file, second element is the line in the file where the
266
+ # proc definition is found.
267
+ #
268
+ # source://method_source//lib/method_source/source_location.rb#74
269
+ def source_location; end
270
+ end
271
+
272
+ # source://method_source//lib/method_source/source_location.rb#81
273
+ module MethodSource::SourceLocation::UnboundMethodExtensions
274
+ # Return the source location of an instance method for Ruby 1.8.
275
+ #
276
+ # @return [Array] A two element array. First element is the
277
+ # file, second element is the line in the file where the
278
+ # method definition is found.
279
+ #
280
+ # source://method_source//lib/method_source/source_location.rb#101
281
+ def source_location; end
282
+ end
283
+
284
+ # An Exception to mark errors that were raised trying to find the source from
285
+ # a given source_location.
286
+ #
287
+ # source://method_source//lib/method_source.rb#16
288
+ class MethodSource::SourceNotFoundError < ::StandardError; end
289
+
290
+ # source://method_source//lib/method_source/version.rb#2
291
+ MethodSource::VERSION = T.let(T.unsafe(nil), String)
292
+
293
+ # source://method_source//lib/method_source.rb#173
294
+ class Proc
295
+ include ::MethodSource::SourceLocation::ProcExtensions
296
+ include ::MethodSource::MethodExtensions
297
+ end
298
+
299
+ # source://method_source//lib/method_source.rb#168
300
+ class UnboundMethod
301
+ include ::MethodSource::SourceLocation::UnboundMethodExtensions
302
+ include ::MethodSource::MethodExtensions
303
+ end