paperback 0.0.4 → 0.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (61) hide show
  1. checksums.yaml +5 -5
  2. data/.github/workflows/tests.yml +46 -0
  3. data/.rubocop-disables.yml +26 -9
  4. data/CHANGELOG.md +7 -0
  5. data/README.md +4 -1
  6. data/lib/paperback/cli.rb +17 -0
  7. data/lib/paperback/document.rb +74 -11
  8. data/lib/paperback/preparer.rb +76 -21
  9. data/lib/paperback/version.rb +2 -1
  10. data/lib/paperback.rb +12 -0
  11. data/paperback.gemspec +10 -7
  12. data/sorbet/config +3 -0
  13. data/sorbet/rbi/annotations/rainbow.rbi +269 -0
  14. data/sorbet/rbi/gems/ast@2.4.2.rbi +584 -0
  15. data/sorbet/rbi/gems/chunky_png@1.4.0.rbi +4498 -0
  16. data/sorbet/rbi/gems/coderay@1.1.3.rbi +3426 -0
  17. data/sorbet/rbi/gems/diff-lcs@1.5.0.rbi +1083 -0
  18. data/sorbet/rbi/gems/method_source@1.0.0.rbi +272 -0
  19. data/sorbet/rbi/gems/netrc@0.11.0.rbi +158 -0
  20. data/sorbet/rbi/gems/parallel@1.22.1.rbi +277 -0
  21. data/sorbet/rbi/gems/parser@3.2.0.0.rbi +6963 -0
  22. data/sorbet/rbi/gems/pdf-core@0.4.0.rbi +1682 -0
  23. data/sorbet/rbi/gems/prawn@1.3.0.rbi +5567 -0
  24. data/sorbet/rbi/gems/pry@0.14.1.rbi +9990 -0
  25. data/sorbet/rbi/gems/rainbow@3.1.1.rbi +408 -0
  26. data/sorbet/rbi/gems/rake@13.0.6.rbi +3023 -0
  27. data/sorbet/rbi/gems/rbi@0.0.16.rbi +3008 -0
  28. data/sorbet/rbi/gems/regexp_parser@2.6.1.rbi +3481 -0
  29. data/sorbet/rbi/gems/rexml@3.2.5.rbi +4717 -0
  30. data/sorbet/rbi/gems/rqrcode@0.10.1.rbi +617 -0
  31. data/sorbet/rbi/gems/rspec-core@3.12.0.rbi +10791 -0
  32. data/sorbet/rbi/gems/rspec-expectations@3.12.1.rbi +8106 -0
  33. data/sorbet/rbi/gems/rspec-mocks@3.12.1.rbi +5305 -0
  34. data/sorbet/rbi/gems/rspec-support@3.12.0.rbi +1617 -0
  35. data/sorbet/rbi/gems/rspec@3.12.0.rbi +88 -0
  36. data/sorbet/rbi/gems/rubocop-ast@1.24.1.rbi +6617 -0
  37. data/sorbet/rbi/gems/rubocop@0.93.1.rbi +40848 -0
  38. data/sorbet/rbi/gems/ruby-progressbar@1.11.0.rbi +1234 -0
  39. data/sorbet/rbi/gems/sixword@0.4.0.rbi +536 -0
  40. data/sorbet/rbi/gems/spoom@1.1.15.rbi +2383 -0
  41. data/sorbet/rbi/gems/subprocess@1.5.6.rbi +391 -0
  42. data/sorbet/rbi/gems/tapioca@0.10.5.rbi +3207 -0
  43. data/sorbet/rbi/gems/thor@1.2.1.rbi +3956 -0
  44. data/sorbet/rbi/gems/ttfunk@1.4.0.rbi +1951 -0
  45. data/sorbet/rbi/gems/unicode-display_width@1.8.0.rbi +40 -0
  46. data/sorbet/rbi/gems/unparser@0.6.7.rbi +4524 -0
  47. data/sorbet/rbi/gems/webrick@1.7.0.rbi +2555 -0
  48. data/sorbet/rbi/gems/yard-sorbet@0.8.0.rbi +441 -0
  49. data/sorbet/rbi/gems/yard@0.9.28.rbi +17816 -0
  50. data/sorbet/tapioca/config.yml +13 -0
  51. data/sorbet/tapioca/require.rb +4 -0
  52. data/spec/functional/paperback/cli_spec.rb +54 -25
  53. data/spec/spec_helper.rb +1 -0
  54. data/spec/unit/paperback_spec.rb +1 -0
  55. metadata +89 -13
  56. data/sample/aes.key +0 -1
  57. data/sample/aes.pdf +0 -14413
  58. data/sample/aes.pdf.passphrase.txt +0 -1
  59. data/sample/rsa2048.pdf +0 -106803
  60. data/sample/rsa2048.pdf.passphrase.txt +0 -1
  61. data/sample/rsa2048.pem +0 -27
@@ -0,0 +1,272 @@
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#127
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
+ # Helper method responsible for opening source file and buffering up
19
+ # the comments for a specified method. Defined here to avoid polluting
20
+ # `Method` class.
21
+ #
22
+ # @param source_location [Array] The array returned by Method#source_location
23
+ # @param method_name [String]
24
+ # @raise [SourceNotFoundError]
25
+ # @return [String] The comments up to the point of the method.
26
+ #
27
+ # source://method_source//lib/method_source.rb#38
28
+ def comment_helper(source_location, name = T.unsafe(nil)); end
29
+
30
+ # @deprecated — use MethodSource::CodeHelpers#expression_at
31
+ #
32
+ # source://method_source//lib/method_source.rb#66
33
+ def extract_code(source_location); end
34
+
35
+ # Load a memoized copy of the lines in a file.
36
+ #
37
+ # @param file_name [String]
38
+ # @param method_name [String]
39
+ # @raise [SourceNotFoundError]
40
+ # @return [Array<String>] the contents of the file
41
+ #
42
+ # source://method_source//lib/method_source.rb#51
43
+ def lines_for(file_name, name = T.unsafe(nil)); end
44
+
45
+ # Helper method responsible for extracting method body.
46
+ # Defined here to avoid polluting `Method` class.
47
+ #
48
+ # @param source_location [Array] The array returned by Method#source_location
49
+ # @param method_name [String]
50
+ # @return [String] The method body
51
+ #
52
+ # source://method_source//lib/method_source.rb#23
53
+ def source_helper(source_location, name = T.unsafe(nil)); end
54
+
55
+ # @deprecated — use MethodSource::CodeHelpers#complete_expression?
56
+ # @return [Boolean]
57
+ #
58
+ # source://method_source//lib/method_source.rb#59
59
+ def valid_expression?(str); end
60
+ end
61
+ end
62
+
63
+ # source://method_source//lib/method_source/code_helpers.rb#3
64
+ module MethodSource::CodeHelpers
65
+ # Retrieve the comment describing the expression on the given line of the given file.
66
+ #
67
+ # This is useful to get module or method documentation.
68
+ #
69
+ # @param file [Array<String>, File, String] The file to parse, either as a File or as
70
+ # a String or an Array of lines.
71
+ # @param line_number [Integer] The line number at which to look.
72
+ # NOTE: The first line in a file is line 1!
73
+ # @return [String] The comment
74
+ #
75
+ # source://method_source//lib/method_source/code_helpers.rb#52
76
+ def comment_describing(file, line_number); end
77
+
78
+ # Determine if a string of code is a complete Ruby expression.
79
+ #
80
+ # @example
81
+ # complete_expression?("class Hello") #=> false
82
+ # complete_expression?("class Hello; end") #=> true
83
+ # complete_expression?("class 123") #=> SyntaxError: unexpected tINTEGER
84
+ # @param code [String] The code to validate.
85
+ # @raise [SyntaxError] Any SyntaxError that does not represent incompleteness.
86
+ # @return [Boolean] Whether or not the code is a complete Ruby expression.
87
+ #
88
+ # source://method_source//lib/method_source/code_helpers.rb#66
89
+ def complete_expression?(str); end
90
+
91
+ # Retrieve the first expression starting on the given line of the given file.
92
+ #
93
+ # This is useful to get module or method source code.
94
+ #
95
+ # line 1!
96
+ #
97
+ # @option options
98
+ # @option options
99
+ # @param file [Array<String>, File, String] The file to parse, either as a File or as
100
+ # @param line_number [Integer] The line number at which to look.
101
+ # NOTE: The first line in a file is
102
+ # @param options [Hash] The optional configuration parameters.
103
+ # @raise [SyntaxError] If the first complete expression can't be identified
104
+ # @return [String] The first complete expression
105
+ #
106
+ # source://method_source//lib/method_source/code_helpers.rb#20
107
+ def expression_at(file, line_number, options = T.unsafe(nil)); end
108
+
109
+ private
110
+
111
+ # Get the first expression from the input.
112
+ #
113
+ # @param lines [Array<String>]
114
+ # @param consume [Integer] A number of lines to automatically
115
+ # consume (add to the expression buffer) without checking for validity.
116
+ # @raise [SyntaxError]
117
+ # @return [String] a valid ruby expression
118
+ # @yield a clean-up function to run before checking for complete_expression
119
+ #
120
+ # source://method_source//lib/method_source/code_helpers.rb#92
121
+ def extract_first_expression(lines, consume = T.unsafe(nil), &block); end
122
+
123
+ # Get the last comment from the input.
124
+ #
125
+ # @param lines [Array<String>]
126
+ # @return [String]
127
+ #
128
+ # source://method_source//lib/method_source/code_helpers.rb#106
129
+ def extract_last_comment(lines); end
130
+ end
131
+
132
+ # An exception matcher that matches only subsets of SyntaxErrors that can be
133
+ # fixed by adding more input to the buffer.
134
+ #
135
+ # source://method_source//lib/method_source/code_helpers.rb#124
136
+ module MethodSource::CodeHelpers::IncompleteExpression
137
+ class << self
138
+ # source://method_source//lib/method_source/code_helpers.rb#137
139
+ def ===(ex); end
140
+
141
+ # @return [Boolean]
142
+ #
143
+ # source://method_source//lib/method_source/code_helpers.rb#149
144
+ def rbx?; end
145
+ end
146
+ end
147
+
148
+ # source://method_source//lib/method_source/code_helpers.rb#125
149
+ MethodSource::CodeHelpers::IncompleteExpression::GENERIC_REGEXPS = T.let(T.unsafe(nil), Array)
150
+
151
+ # source://method_source//lib/method_source/code_helpers.rb#133
152
+ MethodSource::CodeHelpers::IncompleteExpression::RBX_ONLY_REGEXPS = T.let(T.unsafe(nil), Array)
153
+
154
+ # This module is to be included by `Method` and `UnboundMethod` and
155
+ # provides the `#source` functionality
156
+ #
157
+ # source://method_source//lib/method_source.rb#72
158
+ module MethodSource::MethodExtensions
159
+ # Return the comments associated with the method as a string.
160
+ #
161
+ # @example
162
+ # Set.instance_method(:clear).comment.display
163
+ # =>
164
+ # # Removes all elements and returns self.
165
+ # @raise SourceNotFoundException
166
+ # @return [String] The method's comments as a string
167
+ #
168
+ # source://method_source//lib/method_source.rb#121
169
+ def comment; end
170
+
171
+ # Return the sourcecode for the method as a string
172
+ #
173
+ # @example
174
+ # Set.instance_method(:clear).source.display
175
+ # =>
176
+ # def clear
177
+ # @hash.clear
178
+ # self
179
+ # end
180
+ # @raise SourceNotFoundException
181
+ # @return [String] The method sourcecode as a string
182
+ #
183
+ # source://method_source//lib/method_source.rb#109
184
+ def source; end
185
+
186
+ class << self
187
+ # We use the included hook to patch Method#source on rubinius.
188
+ # We need to use the included hook as Rubinius defines a `source`
189
+ # on Method so including a module will have no effect (as it's
190
+ # higher up the MRO).
191
+ #
192
+ # @param klass [Class] The class that includes the module.
193
+ #
194
+ # source://method_source//lib/method_source.rb#79
195
+ def included(klass); end
196
+ end
197
+ end
198
+
199
+ # source://method_source//lib/method_source/source_location.rb#2
200
+ module MethodSource::ReeSourceLocation
201
+ # Ruby enterprise edition provides all the information that's
202
+ # needed, in a slightly different way.
203
+ #
204
+ # source://method_source//lib/method_source/source_location.rb#5
205
+ def source_location; end
206
+ end
207
+
208
+ # source://method_source//lib/method_source/source_location.rb#10
209
+ module MethodSource::SourceLocation; end
210
+
211
+ # source://method_source//lib/method_source/source_location.rb#11
212
+ module MethodSource::SourceLocation::MethodExtensions
213
+ # Return the source location of a method for Ruby 1.8.
214
+ #
215
+ # @return [Array] A two element array. First element is the
216
+ # file, second element is the line in the file where the
217
+ # method definition is found.
218
+ #
219
+ # source://method_source//lib/method_source/source_location.rb#40
220
+ def source_location; end
221
+
222
+ private
223
+
224
+ # source://method_source//lib/method_source/source_location.rb#26
225
+ def trace_func(event, file, line, id, binding, classname); end
226
+ end
227
+
228
+ # source://method_source//lib/method_source/source_location.rb#54
229
+ module MethodSource::SourceLocation::ProcExtensions
230
+ # Return the source location for a Proc (in implementations
231
+ # without Proc#source_location)
232
+ #
233
+ # @return [Array] A two element array. First element is the
234
+ # file, second element is the line in the file where the
235
+ # proc definition is found.
236
+ #
237
+ # source://method_source//lib/method_source/source_location.rb#74
238
+ def source_location; end
239
+ end
240
+
241
+ # source://method_source//lib/method_source/source_location.rb#81
242
+ module MethodSource::SourceLocation::UnboundMethodExtensions
243
+ # Return the source location of an instance method for Ruby 1.8.
244
+ #
245
+ # @return [Array] A two element array. First element is the
246
+ # file, second element is the line in the file where the
247
+ # method definition is found.
248
+ #
249
+ # source://method_source//lib/method_source/source_location.rb#101
250
+ def source_location; end
251
+ end
252
+
253
+ # An Exception to mark errors that were raised trying to find the source from
254
+ # a given source_location.
255
+ #
256
+ # source://method_source//lib/method_source.rb#16
257
+ class MethodSource::SourceNotFoundError < ::StandardError; end
258
+
259
+ # source://method_source//lib/method_source/version.rb#2
260
+ MethodSource::VERSION = T.let(T.unsafe(nil), String)
261
+
262
+ # source://method_source//lib/method_source.rb#137
263
+ class Proc
264
+ include ::MethodSource::SourceLocation::ProcExtensions
265
+ include ::MethodSource::MethodExtensions
266
+ end
267
+
268
+ # source://method_source//lib/method_source.rb#132
269
+ class UnboundMethod
270
+ include ::MethodSource::SourceLocation::UnboundMethodExtensions
271
+ include ::MethodSource::MethodExtensions
272
+ end
@@ -0,0 +1,158 @@
1
+ # typed: true
2
+
3
+ # DO NOT EDIT MANUALLY
4
+ # This is an autogenerated file for types exported from the `netrc` gem.
5
+ # Please instead update this file by running `bin/tapioca gem netrc`.
6
+
7
+ # source://netrc//lib/netrc.rb#3
8
+ class Netrc
9
+ # @return [Netrc] a new instance of Netrc
10
+ #
11
+ # source://netrc//lib/netrc.rb#166
12
+ def initialize(path, data); end
13
+
14
+ # source://netrc//lib/netrc.rb#180
15
+ def [](k); end
16
+
17
+ # source://netrc//lib/netrc.rb#188
18
+ def []=(k, info); end
19
+
20
+ # source://netrc//lib/netrc.rb#200
21
+ def delete(key); end
22
+
23
+ # source://netrc//lib/netrc.rb#211
24
+ def each(&block); end
25
+
26
+ # source://netrc//lib/netrc.rb#196
27
+ def length; end
28
+
29
+ # source://netrc//lib/netrc.rb#215
30
+ def new_item(m, l, p); end
31
+
32
+ # Returns the value of attribute new_item_prefix.
33
+ #
34
+ # source://netrc//lib/netrc.rb#178
35
+ def new_item_prefix; end
36
+
37
+ # Sets the attribute new_item_prefix
38
+ #
39
+ # @param value the value to set the attribute new_item_prefix to.
40
+ #
41
+ # source://netrc//lib/netrc.rb#178
42
+ def new_item_prefix=(_arg0); end
43
+
44
+ # source://netrc//lib/netrc.rb#219
45
+ def save; end
46
+
47
+ # source://netrc//lib/netrc.rb#233
48
+ def unparse; end
49
+
50
+ class << self
51
+ # source://netrc//lib/netrc.rb#42
52
+ def check_permissions(path); end
53
+
54
+ # source://netrc//lib/netrc.rb#33
55
+ def config; end
56
+
57
+ # @yield [self.config]
58
+ #
59
+ # source://netrc//lib/netrc.rb#37
60
+ def configure; end
61
+
62
+ # source://netrc//lib/netrc.rb#10
63
+ def default_path; end
64
+
65
+ # source://netrc//lib/netrc.rb#14
66
+ def home_path; end
67
+
68
+ # source://netrc//lib/netrc.rb#85
69
+ def lex(lines); end
70
+
71
+ # source://netrc//lib/netrc.rb#29
72
+ def netrc_filename; end
73
+
74
+ # Returns two values, a header and a list of items.
75
+ # Each item is a tuple, containing some or all of:
76
+ # - machine keyword (including trailing whitespace+comments)
77
+ # - machine name
78
+ # - login keyword (including surrounding whitespace+comments)
79
+ # - login
80
+ # - password keyword (including surrounding whitespace+comments)
81
+ # - password
82
+ # - trailing chars
83
+ # This lets us change individual fields, then write out the file
84
+ # with all its original formatting.
85
+ #
86
+ # source://netrc//lib/netrc.rb#129
87
+ def parse(ts); end
88
+
89
+ # Reads path and parses it as a .netrc file. If path doesn't
90
+ # exist, returns an empty object. Decrypt paths ending in .gpg.
91
+ #
92
+ # source://netrc//lib/netrc.rb#51
93
+ def read(path = T.unsafe(nil)); end
94
+
95
+ # @return [Boolean]
96
+ #
97
+ # source://netrc//lib/netrc.rb#112
98
+ def skip?(s); end
99
+ end
100
+ end
101
+
102
+ # source://netrc//lib/netrc.rb#8
103
+ Netrc::CYGWIN = T.let(T.unsafe(nil), T.untyped)
104
+
105
+ # source://netrc//lib/netrc.rb#244
106
+ class Netrc::Entry < ::Struct
107
+ # Returns the value of attribute login
108
+ #
109
+ # @return [Object] the current value of login
110
+ def login; end
111
+
112
+ # Sets the attribute login
113
+ #
114
+ # @param value [Object] the value to set the attribute login to.
115
+ # @return [Object] the newly set value
116
+ def login=(_); end
117
+
118
+ # Returns the value of attribute password
119
+ #
120
+ # @return [Object] the current value of password
121
+ def password; end
122
+
123
+ # Sets the attribute password
124
+ #
125
+ # @param value [Object] the value to set the attribute password to.
126
+ # @return [Object] the newly set value
127
+ def password=(_); end
128
+
129
+ def to_ary; end
130
+
131
+ class << self
132
+ def [](*_arg0); end
133
+ def inspect; end
134
+ def keyword_init?; end
135
+ def members; end
136
+ def new(*_arg0); end
137
+ end
138
+ end
139
+
140
+ # source://netrc//lib/netrc.rb#250
141
+ class Netrc::Error < ::StandardError; end
142
+
143
+ # source://netrc//lib/netrc.rb#68
144
+ class Netrc::TokenArray < ::Array
145
+ # source://netrc//lib/netrc.rb#76
146
+ def readto; end
147
+
148
+ # source://netrc//lib/netrc.rb#69
149
+ def take; end
150
+ end
151
+
152
+ # source://netrc//lib/netrc.rb#4
153
+ Netrc::VERSION = T.let(T.unsafe(nil), String)
154
+
155
+ # see http://stackoverflow.com/questions/4871309/what-is-the-correct-way-to-detect-if-ruby-is-running-on-windows
156
+ #
157
+ # source://netrc//lib/netrc.rb#7
158
+ Netrc::WINDOWS = T.let(T.unsafe(nil), T.untyped)
@@ -0,0 +1,277 @@
1
+ # typed: true
2
+
3
+ # DO NOT EDIT MANUALLY
4
+ # This is an autogenerated file for types exported from the `parallel` gem.
5
+ # Please instead update this file by running `bin/tapioca gem parallel`.
6
+
7
+ # source://parallel//lib/parallel/version.rb#2
8
+ module Parallel
9
+ extend ::Parallel::ProcessorCount
10
+
11
+ class << self
12
+ # @return [Boolean]
13
+ #
14
+ # source://parallel//lib/parallel.rb#246
15
+ def all?(*args, &block); end
16
+
17
+ # @return [Boolean]
18
+ #
19
+ # source://parallel//lib/parallel.rb#241
20
+ def any?(*args, &block); end
21
+
22
+ # source://parallel//lib/parallel.rb#237
23
+ def each(array, options = T.unsafe(nil), &block); end
24
+
25
+ # source://parallel//lib/parallel.rb#251
26
+ def each_with_index(array, options = T.unsafe(nil), &block); end
27
+
28
+ # source://parallel//lib/parallel.rb#306
29
+ def flat_map(*args, &block); end
30
+
31
+ # source://parallel//lib/parallel.rb#231
32
+ def in_processes(options = T.unsafe(nil), &block); end
33
+
34
+ # source://parallel//lib/parallel.rb#215
35
+ def in_threads(options = T.unsafe(nil)); end
36
+
37
+ # source://parallel//lib/parallel.rb#255
38
+ def map(source, options = T.unsafe(nil), &block); end
39
+
40
+ # source://parallel//lib/parallel.rb#302
41
+ def map_with_index(array, options = T.unsafe(nil), &block); end
42
+
43
+ # source://parallel//lib/parallel.rb#310
44
+ def worker_number; end
45
+
46
+ # TODO: this does not work when doing threads in forks, so should remove and yield the number instead if needed
47
+ #
48
+ # source://parallel//lib/parallel.rb#315
49
+ def worker_number=(worker_num); end
50
+
51
+ private
52
+
53
+ # source://parallel//lib/parallel.rb#321
54
+ def add_progress_bar!(job_factory, options); end
55
+
56
+ # source://parallel//lib/parallel.rb#584
57
+ def call_with_index(item, index, options, &block); end
58
+
59
+ # source://parallel//lib/parallel.rb#516
60
+ def create_workers(job_factory, options, &block); end
61
+
62
+ # options is either a Integer or a Hash with :count
63
+ #
64
+ # source://parallel//lib/parallel.rb#574
65
+ def extract_count_from_options(options); end
66
+
67
+ # source://parallel//lib/parallel.rb#602
68
+ def instrument_finish(item, index, result, options); end
69
+
70
+ # source://parallel//lib/parallel.rb#607
71
+ def instrument_start(item, index, options); end
72
+
73
+ # source://parallel//lib/parallel.rb#550
74
+ def process_incoming_jobs(read, write, job_factory, options, &block); end
75
+
76
+ # source://parallel//lib/parallel.rb#504
77
+ def replace_worker(job_factory, workers, index, options, blk); end
78
+
79
+ # source://parallel//lib/parallel.rb#595
80
+ def with_instrumentation(item, index, options); end
81
+
82
+ # source://parallel//lib/parallel.rb#346
83
+ def work_direct(job_factory, options, &block); end
84
+
85
+ # source://parallel//lib/parallel.rb#456
86
+ def work_in_processes(job_factory, options, &blk); end
87
+
88
+ # source://parallel//lib/parallel.rb#390
89
+ def work_in_ractors(job_factory, options); end
90
+
91
+ # source://parallel//lib/parallel.rb#365
92
+ def work_in_threads(job_factory, options, &block); end
93
+
94
+ # source://parallel//lib/parallel.rb#524
95
+ def worker(job_factory, options, &block); end
96
+ end
97
+ end
98
+
99
+ # source://parallel//lib/parallel.rb#14
100
+ class Parallel::Break < ::StandardError
101
+ # @return [Break] a new instance of Break
102
+ #
103
+ # source://parallel//lib/parallel.rb#17
104
+ def initialize(value = T.unsafe(nil)); end
105
+
106
+ # Returns the value of attribute value.
107
+ #
108
+ # source://parallel//lib/parallel.rb#15
109
+ def value; end
110
+ end
111
+
112
+ # source://parallel//lib/parallel.rb#11
113
+ class Parallel::DeadWorker < ::StandardError; end
114
+
115
+ # source://parallel//lib/parallel.rb#35
116
+ class Parallel::ExceptionWrapper
117
+ # @return [ExceptionWrapper] a new instance of ExceptionWrapper
118
+ #
119
+ # source://parallel//lib/parallel.rb#38
120
+ def initialize(exception); end
121
+
122
+ # Returns the value of attribute exception.
123
+ #
124
+ # source://parallel//lib/parallel.rb#36
125
+ def exception; end
126
+ end
127
+
128
+ # source://parallel//lib/parallel.rb#101
129
+ class Parallel::JobFactory
130
+ # @return [JobFactory] a new instance of JobFactory
131
+ #
132
+ # source://parallel//lib/parallel.rb#102
133
+ def initialize(source, mutex); end
134
+
135
+ # source://parallel//lib/parallel.rb#110
136
+ def next; end
137
+
138
+ # generate item that is sent to workers
139
+ # just index is faster + less likely to blow up with unserializable errors
140
+ #
141
+ # source://parallel//lib/parallel.rb#139
142
+ def pack(item, index); end
143
+
144
+ # source://parallel//lib/parallel.rb#129
145
+ def size; end
146
+
147
+ # unpack item that is sent to workers
148
+ #
149
+ # source://parallel//lib/parallel.rb#144
150
+ def unpack(data); end
151
+
152
+ private
153
+
154
+ # @return [Boolean]
155
+ #
156
+ # source://parallel//lib/parallel.rb#150
157
+ def producer?; end
158
+
159
+ # source://parallel//lib/parallel.rb#154
160
+ def queue_wrapper(array); end
161
+ end
162
+
163
+ # source://parallel//lib/parallel.rb#23
164
+ class Parallel::Kill < ::Parallel::Break; end
165
+
166
+ # TODO: inline this method into parallel.rb and kill physical_processor_count in next major release
167
+ #
168
+ # source://parallel//lib/parallel/processor_count.rb#4
169
+ module Parallel::ProcessorCount
170
+ # Number of physical processor cores on the current system.
171
+ #
172
+ # source://parallel//lib/parallel/processor_count.rb#12
173
+ def physical_processor_count; end
174
+
175
+ # Number of processors seen by the OS, used for process scheduling
176
+ #
177
+ # source://parallel//lib/parallel/processor_count.rb#6
178
+ def processor_count; end
179
+ end
180
+
181
+ # source://parallel//lib/parallel.rb#9
182
+ Parallel::Stop = T.let(T.unsafe(nil), Object)
183
+
184
+ # source://parallel//lib/parallel.rb#26
185
+ class Parallel::UndumpableException < ::StandardError
186
+ # @return [UndumpableException] a new instance of UndumpableException
187
+ #
188
+ # source://parallel//lib/parallel.rb#29
189
+ def initialize(original); end
190
+
191
+ # Returns the value of attribute backtrace.
192
+ #
193
+ # source://parallel//lib/parallel.rb#27
194
+ def backtrace; end
195
+ end
196
+
197
+ # source://parallel//lib/parallel.rb#159
198
+ class Parallel::UserInterruptHandler
199
+ class << self
200
+ # source://parallel//lib/parallel.rb#184
201
+ def kill(thing); end
202
+
203
+ # kill all these pids or threads if user presses Ctrl+c
204
+ #
205
+ # source://parallel//lib/parallel.rb#164
206
+ def kill_on_ctrl_c(pids, options); end
207
+
208
+ private
209
+
210
+ # source://parallel//lib/parallel.rb#208
211
+ def restore_interrupt(old, signal); end
212
+
213
+ # source://parallel//lib/parallel.rb#193
214
+ def trap_interrupt(signal); end
215
+ end
216
+ end
217
+
218
+ # source://parallel//lib/parallel.rb#160
219
+ Parallel::UserInterruptHandler::INTERRUPT_SIGNAL = T.let(T.unsafe(nil), Symbol)
220
+
221
+ # source://parallel//lib/parallel/version.rb#3
222
+ Parallel::VERSION = T.let(T.unsafe(nil), String)
223
+
224
+ # source://parallel//lib/parallel/version.rb#3
225
+ Parallel::Version = T.let(T.unsafe(nil), String)
226
+
227
+ # source://parallel//lib/parallel.rb#54
228
+ class Parallel::Worker
229
+ # @return [Worker] a new instance of Worker
230
+ #
231
+ # source://parallel//lib/parallel.rb#58
232
+ def initialize(read, write, pid); end
233
+
234
+ # might be passed to started_processes and simultaneously closed by another thread
235
+ # when running in isolation mode, so we have to check if it is closed before closing
236
+ #
237
+ # source://parallel//lib/parallel.rb#71
238
+ def close_pipes; end
239
+
240
+ # Returns the value of attribute pid.
241
+ #
242
+ # source://parallel//lib/parallel.rb#55
243
+ def pid; end
244
+
245
+ # Returns the value of attribute read.
246
+ #
247
+ # source://parallel//lib/parallel.rb#55
248
+ def read; end
249
+
250
+ # source://parallel//lib/parallel.rb#64
251
+ def stop; end
252
+
253
+ # Returns the value of attribute thread.
254
+ #
255
+ # source://parallel//lib/parallel.rb#56
256
+ def thread; end
257
+
258
+ # Sets the attribute thread
259
+ #
260
+ # @param value the value to set the attribute thread to.
261
+ #
262
+ # source://parallel//lib/parallel.rb#56
263
+ def thread=(_arg0); end
264
+
265
+ # source://parallel//lib/parallel.rb#76
266
+ def work(data); end
267
+
268
+ # Returns the value of attribute write.
269
+ #
270
+ # source://parallel//lib/parallel.rb#55
271
+ def write; end
272
+
273
+ private
274
+
275
+ # source://parallel//lib/parallel.rb#94
276
+ def wait; end
277
+ end