pry 0.10.3 → 0.14.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/CHANGELOG.md +439 -16
- data/LICENSE +1 -1
- data/README.md +362 -302
- data/bin/pry +4 -7
- data/lib/pry/basic_object.rb +10 -0
- data/lib/pry/block_command.rb +22 -0
- data/lib/pry/class_command.rb +194 -0
- data/lib/pry/cli.rb +84 -97
- data/lib/pry/code/code_file.rb +37 -26
- data/lib/pry/code/code_range.rb +7 -5
- data/lib/pry/code/loc.rb +26 -13
- data/lib/pry/code.rb +42 -31
- data/lib/pry/code_object.rb +53 -28
- data/lib/pry/color_printer.rb +46 -35
- data/lib/pry/command.rb +197 -369
- data/lib/pry/command_set.rb +89 -114
- data/lib/pry/command_state.rb +31 -0
- data/lib/pry/commands/amend_line.rb +86 -82
- data/lib/pry/commands/bang.rb +18 -14
- data/lib/pry/commands/bang_pry.rb +15 -11
- data/lib/pry/commands/cat/abstract_formatter.rb +23 -18
- data/lib/pry/commands/cat/exception_formatter.rb +85 -72
- data/lib/pry/commands/cat/file_formatter.rb +56 -46
- data/lib/pry/commands/cat/input_expression_formatter.rb +35 -30
- data/lib/pry/commands/cat.rb +62 -54
- data/lib/pry/commands/cd.rb +40 -35
- data/lib/pry/commands/change_inspector.rb +29 -22
- data/lib/pry/commands/change_prompt.rb +48 -23
- data/lib/pry/commands/clear_screen.rb +20 -0
- data/lib/pry/commands/code_collector.rb +148 -131
- data/lib/pry/commands/disable_pry.rb +23 -19
- data/lib/pry/commands/easter_eggs.rb +23 -34
- data/lib/pry/commands/edit/exception_patcher.rb +21 -17
- data/lib/pry/commands/edit/file_and_line_locator.rb +34 -23
- data/lib/pry/commands/edit.rb +185 -157
- data/lib/pry/commands/exit.rb +40 -35
- data/lib/pry/commands/exit_all.rb +24 -20
- data/lib/pry/commands/exit_program.rb +20 -16
- data/lib/pry/commands/find_method.rb +168 -162
- data/lib/pry/commands/fix_indent.rb +16 -12
- data/lib/pry/commands/help.rb +140 -133
- data/lib/pry/commands/hist.rb +151 -149
- data/lib/pry/commands/import_set.rb +20 -15
- data/lib/pry/commands/jump_to.rb +25 -21
- data/lib/pry/commands/list_inspectors.rb +35 -28
- data/lib/pry/commands/ls/constants.rb +59 -31
- data/lib/pry/commands/ls/formatter.rb +42 -36
- data/lib/pry/commands/ls/globals.rb +38 -36
- data/lib/pry/commands/ls/grep.rb +17 -15
- data/lib/pry/commands/ls/instance_vars.rb +29 -28
- data/lib/pry/commands/ls/interrogatable.rb +18 -12
- data/lib/pry/commands/ls/jruby_hacks.rb +47 -41
- data/lib/pry/commands/ls/local_names.rb +26 -24
- data/lib/pry/commands/ls/local_vars.rb +38 -30
- data/lib/pry/commands/ls/ls_entity.rb +47 -52
- data/lib/pry/commands/ls/methods.rb +49 -51
- data/lib/pry/commands/ls/methods_helper.rb +46 -42
- data/lib/pry/commands/ls/self_methods.rb +23 -21
- data/lib/pry/commands/ls.rb +124 -103
- data/lib/pry/commands/nesting.rb +21 -17
- data/lib/pry/commands/play.rb +92 -82
- data/lib/pry/commands/pry_backtrace.rb +22 -17
- data/lib/pry/commands/pry_version.rb +15 -11
- data/lib/pry/commands/raise_up.rb +33 -27
- data/lib/pry/commands/reload_code.rb +60 -48
- data/lib/pry/commands/reset.rb +16 -12
- data/lib/pry/commands/ri.rb +57 -42
- data/lib/pry/commands/save_file.rb +45 -43
- data/lib/pry/commands/shell_command.rb +56 -29
- data/lib/pry/commands/shell_mode.rb +22 -18
- data/lib/pry/commands/show_doc.rb +80 -70
- data/lib/pry/commands/show_info.rb +194 -155
- data/lib/pry/commands/show_input.rb +16 -11
- data/lib/pry/commands/show_source.rb +110 -42
- data/lib/pry/commands/stat.rb +35 -31
- data/lib/pry/commands/switch_to.rb +21 -15
- data/lib/pry/commands/toggle_color.rb +20 -16
- data/lib/pry/commands/watch_expression/expression.rb +32 -27
- data/lib/pry/commands/watch_expression.rb +89 -84
- data/lib/pry/commands/whereami.rb +156 -141
- data/lib/pry/commands/wtf.rb +78 -40
- data/lib/pry/config/attributable.rb +22 -0
- data/lib/pry/config/lazy_value.rb +29 -0
- data/lib/pry/config/memoized_value.rb +34 -0
- data/lib/pry/config/value.rb +24 -0
- data/lib/pry/config.rb +310 -20
- data/lib/pry/control_d_handler.rb +28 -0
- data/lib/pry/core_extensions.rb +22 -9
- data/lib/pry/editor.rb +56 -34
- data/lib/pry/env.rb +18 -0
- data/lib/pry/exception_handler.rb +43 -0
- data/lib/pry/exceptions.rb +13 -18
- data/lib/pry/forwardable.rb +27 -0
- data/lib/pry/helpers/base_helpers.rb +20 -62
- data/lib/pry/helpers/command_helpers.rb +52 -62
- data/lib/pry/helpers/documentation_helpers.rb +21 -12
- data/lib/pry/helpers/options_helpers.rb +15 -8
- data/lib/pry/helpers/platform.rb +55 -0
- data/lib/pry/helpers/table.rb +44 -32
- data/lib/pry/helpers/text.rb +96 -85
- data/lib/pry/helpers.rb +3 -0
- data/lib/pry/history.rb +81 -55
- data/lib/pry/hooks.rb +60 -110
- data/lib/pry/indent.rb +74 -68
- data/lib/pry/input_completer.rb +199 -158
- data/lib/pry/input_lock.rb +7 -10
- data/lib/pry/inspector.rb +36 -24
- data/lib/pry/last_exception.rb +45 -45
- data/lib/pry/method/disowned.rb +19 -5
- data/lib/pry/method/patcher.rb +14 -8
- data/lib/pry/method/weird_method_locator.rb +79 -45
- data/lib/pry/method.rb +178 -124
- data/lib/pry/object_path.rb +37 -28
- data/lib/pry/output.rb +102 -16
- data/lib/pry/pager.rb +187 -174
- data/lib/pry/prompt.rb +213 -25
- data/lib/pry/pry_class.rb +119 -98
- data/lib/pry/pry_instance.rb +261 -224
- data/lib/pry/repl.rb +83 -29
- data/lib/pry/repl_file_loader.rb +27 -22
- data/lib/pry/ring.rb +89 -0
- data/lib/pry/slop/LICENSE +20 -0
- data/lib/pry/slop/commands.rb +190 -0
- data/lib/pry/slop/option.rb +210 -0
- data/lib/pry/slop.rb +672 -0
- data/lib/pry/syntax_highlighter.rb +26 -0
- data/lib/pry/system_command_handler.rb +17 -0
- data/lib/pry/testable/evalable.rb +24 -0
- data/lib/pry/testable/mockable.rb +22 -0
- data/lib/pry/testable/pry_tester.rb +88 -0
- data/lib/pry/testable/utility.rb +34 -0
- data/lib/pry/testable/variables.rb +52 -0
- data/lib/pry/testable.rb +68 -0
- data/lib/pry/version.rb +3 -1
- data/lib/pry/warning.rb +20 -0
- data/lib/pry/{module_candidate.rb → wrapped_module/candidate.rb} +35 -32
- data/lib/pry/wrapped_module.rb +68 -63
- data/lib/pry.rb +133 -149
- metadata +58 -69
- data/lib/pry/commands/disabled_commands.rb +0 -2
- data/lib/pry/commands/gem_cd.rb +0 -26
- data/lib/pry/commands/gem_install.rb +0 -32
- data/lib/pry/commands/gem_list.rb +0 -33
- data/lib/pry/commands/gem_open.rb +0 -29
- data/lib/pry/commands/gist.rb +0 -101
- data/lib/pry/commands/install_command.rb +0 -53
- data/lib/pry/commands/list_prompts.rb +0 -35
- data/lib/pry/commands/simple_prompt.rb +0 -22
- data/lib/pry/commands.rb +0 -6
- data/lib/pry/config/behavior.rb +0 -139
- data/lib/pry/config/convenience.rb +0 -25
- data/lib/pry/config/default.rb +0 -161
- data/lib/pry/history_array.rb +0 -121
- data/lib/pry/plugins.rb +0 -103
- data/lib/pry/rbx_path.rb +0 -22
- data/lib/pry/rubygem.rb +0 -82
- data/lib/pry/terminal.rb +0 -79
- data/lib/pry/test/helper.rb +0 -170
data/lib/pry/config.rb
CHANGED
@@ -1,24 +1,314 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'ostruct'
|
4
|
+
|
5
|
+
class Pry
|
6
|
+
# @api private
|
7
|
+
class Config
|
8
|
+
extend Attributable
|
9
|
+
|
10
|
+
# @return [IO, #readline] he object from which Pry retrieves its lines of
|
11
|
+
# input
|
12
|
+
attribute :input
|
13
|
+
|
14
|
+
# @return [IO, #puts] where Pry should output results provided by {input}
|
15
|
+
attribute :output
|
16
|
+
|
17
|
+
# @return [Pry::CommandSet]
|
18
|
+
attribute :commands
|
19
|
+
|
20
|
+
# @return [Proc] the printer for Ruby expressions (not commands)
|
21
|
+
attribute :print
|
22
|
+
|
23
|
+
# @return [Proc] the printer for exceptions
|
24
|
+
attribute :exception_handler
|
25
|
+
|
26
|
+
# @return [Array] Exception that Pry shouldn't rescue
|
27
|
+
attribute :unrescued_exceptions
|
28
|
+
|
29
|
+
# @deprecated
|
30
|
+
# @return [Array] Exception that Pry shouldn't rescue
|
31
|
+
attribute :exception_whitelist
|
32
|
+
|
33
|
+
# @return [Integer] The number of lines of context to show before and after
|
34
|
+
# exceptions
|
35
|
+
attribute :default_window_size
|
36
|
+
|
37
|
+
# @return [Pry::Hooks]
|
38
|
+
attribute :hooks
|
39
|
+
|
40
|
+
# @return [Pry::Prompt]
|
41
|
+
attribute :prompt
|
42
|
+
|
43
|
+
# @return [String] The display name that is part of the prompt
|
44
|
+
attribute :prompt_name
|
45
|
+
|
46
|
+
# @return [Array<Object>] the list of objects that are known to have a
|
47
|
+
# 1-line #inspect output suitable for prompt
|
48
|
+
attribute :prompt_safe_contexts
|
49
|
+
|
50
|
+
# If it is a String, then that String is used as the shell
|
51
|
+
# command to invoke the editor.
|
52
|
+
#
|
53
|
+
# If it responds to #call is callable then `file`, `line`, and `reloading`
|
54
|
+
# are passed to it. `reloading` indicates whether Pry will be reloading code
|
55
|
+
# after the shell command returns. All parameters are optional.
|
56
|
+
# @return [String, #call]
|
57
|
+
attribute :editor
|
58
|
+
|
59
|
+
# A string that must precede all commands. For example, if is is
|
60
|
+
# set to "%", the "cd" command must be invoked as "%cd").
|
61
|
+
# @return [String]
|
62
|
+
attribute :command_prefix
|
63
|
+
|
64
|
+
# @return [Boolean]
|
65
|
+
attribute :color
|
66
|
+
|
67
|
+
# @return [Boolean]
|
68
|
+
attribute :pager
|
69
|
+
|
70
|
+
# @return [Boolean] whether the global ~/.pryrc should be loaded
|
71
|
+
attribute :should_load_rc
|
72
|
+
|
73
|
+
# @return [Boolean] whether the local ./.pryrc should be loaded
|
74
|
+
attribute :should_load_local_rc
|
75
|
+
|
76
|
+
# @return [Boolean] whether to load files specified with the -r flag
|
77
|
+
attribute :should_load_requires
|
78
|
+
|
79
|
+
# @return [Boolean] whether to disable edit-method's auto-reloading behavior
|
80
|
+
attribute :disable_auto_reload
|
81
|
+
|
82
|
+
# Whether Pry should trap SIGINT and cause it to raise an Interrupt
|
83
|
+
# exception. This is only useful on JRuby, MRI does this for us.
|
84
|
+
# @return [Boolean]
|
85
|
+
attribute :should_trap_interrupts
|
86
|
+
|
87
|
+
# @return [Pry::History]
|
88
|
+
attribute :history
|
89
|
+
|
90
|
+
# @return [Boolean]
|
91
|
+
attribute :history_save
|
92
|
+
|
93
|
+
# @return [Boolean]
|
94
|
+
attribute :history_load
|
95
|
+
|
96
|
+
# @return [String]
|
97
|
+
attribute :history_file
|
98
|
+
|
99
|
+
# @return [Array<String,Regexp>]
|
100
|
+
attribute :history_ignorelist
|
101
|
+
|
102
|
+
# @return [Array<String>] Ruby files to be required
|
103
|
+
attribute :requires
|
104
|
+
|
105
|
+
# @return [Integer] how many input/output lines to keep in memory
|
106
|
+
attribute :memory_size
|
107
|
+
|
108
|
+
# @return [Proc] The proc that runs system commands
|
109
|
+
attribute :system
|
110
|
+
|
111
|
+
# @return [Boolean]
|
112
|
+
attribute :auto_indent
|
113
|
+
|
114
|
+
# @return [Boolean]
|
115
|
+
attribute :correct_indent
|
116
|
+
|
117
|
+
# @return [Boolean] whether or not display a warning when a command name
|
118
|
+
# collides with a method/local in the current context.
|
119
|
+
attribute :collision_warning
|
120
|
+
|
121
|
+
# @return [Hash{Symbol=>Proc}]
|
122
|
+
attribute :extra_sticky_locals
|
123
|
+
|
124
|
+
# @return [#build_completion_proc] a completer to use
|
125
|
+
attribute :completer
|
126
|
+
|
127
|
+
# @return [Boolean] suppresses whereami output on `binding.pry`
|
128
|
+
attribute :quiet
|
129
|
+
|
130
|
+
# @return [Boolean] displays a warning about experience improvement on
|
131
|
+
# Windows
|
132
|
+
attribute :windows_console_warning
|
133
|
+
|
134
|
+
# @return [Proc]
|
135
|
+
attribute :command_completions
|
136
|
+
|
137
|
+
# @return [Proc]
|
138
|
+
attribute :file_completions
|
139
|
+
|
140
|
+
# @return [Hash]
|
141
|
+
attribute :ls
|
142
|
+
|
143
|
+
# @return [String] a line of code to execute in context before the session
|
144
|
+
# starts
|
145
|
+
attribute :exec_string
|
146
|
+
|
147
|
+
# @return [String]
|
148
|
+
attribute :output_prefix
|
149
|
+
|
150
|
+
# @return [String]
|
151
|
+
# @since v0.13.0
|
152
|
+
attribute :rc_file
|
153
|
+
|
154
|
+
def initialize
|
155
|
+
merge!(
|
156
|
+
input: MemoizedValue.new { lazy_readline },
|
157
|
+
output: $stdout.tap { |out| out.sync = true },
|
158
|
+
commands: Pry::Commands,
|
159
|
+
prompt_name: 'pry',
|
160
|
+
prompt: Pry::Prompt[:default],
|
161
|
+
prompt_safe_contexts: [String, Numeric, Symbol, nil, true, false],
|
162
|
+
print: Pry::ColorPrinter.method(:default),
|
163
|
+
quiet: false,
|
164
|
+
exception_handler: Pry::ExceptionHandler.method(:handle_exception),
|
165
|
+
|
166
|
+
unrescued_exceptions: [
|
167
|
+
::SystemExit, ::SignalException, Pry::TooSafeException
|
168
|
+
],
|
169
|
+
|
170
|
+
exception_whitelist: MemoizedValue.new do
|
171
|
+
output.puts(
|
172
|
+
'[warning] Pry.config.exception_whitelist is deprecated, ' \
|
173
|
+
'please use Pry.config.unrescued_exceptions instead.'
|
174
|
+
)
|
175
|
+
unrescued_exceptions
|
176
|
+
end,
|
177
|
+
|
178
|
+
hooks: Pry::Hooks.default,
|
179
|
+
pager: true,
|
180
|
+
system: Pry::SystemCommandHandler.method(:default),
|
181
|
+
color: Pry::Helpers::BaseHelpers.use_ansi_codes?,
|
182
|
+
default_window_size: 5,
|
183
|
+
editor: Pry::Editor.default,
|
184
|
+
rc_file: default_rc_file,
|
185
|
+
should_load_rc: true,
|
186
|
+
should_load_local_rc: true,
|
187
|
+
should_trap_interrupts: Pry::Helpers::Platform.jruby?,
|
188
|
+
disable_auto_reload: false,
|
189
|
+
command_prefix: '',
|
190
|
+
auto_indent: Pry::Helpers::BaseHelpers.use_ansi_codes?,
|
191
|
+
correct_indent: true,
|
192
|
+
collision_warning: false,
|
193
|
+
output_prefix: '=> ',
|
194
|
+
requires: [],
|
195
|
+
should_load_requires: true,
|
196
|
+
windows_console_warning: true,
|
197
|
+
control_d_handler: Pry::ControlDHandler.method(:default),
|
198
|
+
memory_size: 100,
|
199
|
+
extra_sticky_locals: {},
|
200
|
+
command_completions: proc { commands.keys },
|
201
|
+
file_completions: proc { Dir['.'] },
|
202
|
+
ls: OpenStruct.new(Pry::Command::Ls::DEFAULT_OPTIONS),
|
203
|
+
completer: Pry::InputCompleter,
|
204
|
+
history_save: true,
|
205
|
+
history_load: true,
|
206
|
+
history_file: Pry::History.default_file,
|
207
|
+
history_ignorelist: [],
|
208
|
+
history: MemoizedValue.new do
|
209
|
+
if defined?(input::HISTORY)
|
210
|
+
Pry::History.new(history: input::HISTORY)
|
211
|
+
else
|
212
|
+
Pry::History.new
|
213
|
+
end
|
214
|
+
end,
|
215
|
+
exec_string: ''
|
216
|
+
)
|
217
|
+
|
218
|
+
@custom_attrs = {}
|
219
|
+
end
|
220
|
+
|
221
|
+
def merge!(config_hash)
|
222
|
+
config_hash.each_pair { |attr, value| __send__("#{attr}=", value) }
|
223
|
+
self
|
224
|
+
end
|
225
|
+
|
226
|
+
def merge(config_hash)
|
227
|
+
dup.merge!(config_hash)
|
228
|
+
end
|
229
|
+
|
230
|
+
def []=(attr, value)
|
231
|
+
@custom_attrs[attr.to_s] = Config::Value.new(value)
|
232
|
+
end
|
233
|
+
|
234
|
+
def [](attr)
|
235
|
+
@custom_attrs[attr.to_s].call
|
236
|
+
end
|
237
|
+
|
238
|
+
# rubocop:disable Style/MethodMissingSuper
|
239
|
+
def method_missing(method_name, *args, &_block)
|
240
|
+
name = method_name.to_s
|
241
|
+
|
242
|
+
if name.end_with?('=')
|
243
|
+
self[name[0..-2]] = args.first
|
244
|
+
elsif @custom_attrs.key?(name)
|
245
|
+
self[name]
|
246
|
+
end
|
247
|
+
end
|
248
|
+
# rubocop:enable Style/MethodMissingSuper
|
249
|
+
|
250
|
+
def respond_to_missing?(method_name, include_all = false)
|
251
|
+
@custom_attrs.key?(method_name.to_s.tr('=', '')) || super
|
252
|
+
end
|
253
|
+
|
254
|
+
def initialize_dup(other)
|
255
|
+
super
|
256
|
+
@custom_attrs = @custom_attrs.dup
|
257
|
+
end
|
258
|
+
|
259
|
+
attr_reader :control_d_handler
|
260
|
+
def control_d_handler=(value)
|
261
|
+
proxy_proc =
|
262
|
+
if value.arity == 2
|
263
|
+
Pry::Warning.warn(
|
264
|
+
"control_d_handler's arity of 2 parameters was deprecated " \
|
265
|
+
'(eval_string, pry_instance). Now it gets passed just 1 ' \
|
266
|
+
'parameter (pry_instance)'
|
267
|
+
)
|
268
|
+
proc do |*args|
|
269
|
+
if args.size == 2
|
270
|
+
value.call(args.first, args[1])
|
271
|
+
else
|
272
|
+
value.call(args.first.eval_string, args.first)
|
273
|
+
end
|
274
|
+
end
|
275
|
+
else
|
276
|
+
proc do |*args|
|
277
|
+
if args.size == 2
|
278
|
+
value.call(args[1])
|
279
|
+
else
|
280
|
+
value.call(args.first)
|
281
|
+
end
|
282
|
+
end
|
283
|
+
end
|
284
|
+
@control_d_handler = proxy_proc
|
285
|
+
end
|
286
|
+
|
287
|
+
private
|
288
|
+
|
289
|
+
def lazy_readline
|
290
|
+
require 'readline'
|
291
|
+
::Readline
|
292
|
+
rescue LoadError
|
293
|
+
output.puts(
|
294
|
+
"Sorry, you can't use Pry without Readline or a compatible library. \n" \
|
295
|
+
"Possible solutions: \n" \
|
296
|
+
" * Rebuild Ruby with Readline support using `--with-readline` \n" \
|
297
|
+
" * Use the rb-readline gem, which is a pure-Ruby port of Readline \n" \
|
298
|
+
" * Use the pry-coolline gem, a pure-ruby alternative to Readline"
|
299
|
+
)
|
300
|
+
raise
|
301
|
+
end
|
10
302
|
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
else
|
21
|
-
self["hooks"] = hooks
|
303
|
+
def default_rc_file
|
304
|
+
[Pry::Env['PRYRC'],
|
305
|
+
# See XDG Base Directory Specification at
|
306
|
+
# https://specifications.freedesktop.org/basedir-spec/latest/
|
307
|
+
"#{Pry::Env['XDG_CONFIG_HOME']}/pry/pryrc",
|
308
|
+
File.expand_path('~/.pryrc'),
|
309
|
+
File.expand_path('~/.config/pry/pryrc')]
|
310
|
+
.compact
|
311
|
+
.find { |file| File.exist?(file) }
|
22
312
|
end
|
23
313
|
end
|
24
314
|
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class Pry
|
4
|
+
# @api private
|
5
|
+
# @since v0.13.0
|
6
|
+
module ControlDHandler
|
7
|
+
# Deal with the ^D key being pressed. Different behaviour in different
|
8
|
+
# cases:
|
9
|
+
# 1. In an expression behave like `!` command.
|
10
|
+
# 2. At top-level session behave like `exit` command.
|
11
|
+
# 3. In a nested session behave like `cd ..`.
|
12
|
+
def self.default(pry_instance)
|
13
|
+
if !pry_instance.eval_string.empty?
|
14
|
+
# Clear input buffer.
|
15
|
+
pry_instance.eval_string = ''
|
16
|
+
elsif pry_instance.binding_stack.one?
|
17
|
+
pry_instance.binding_stack.clear
|
18
|
+
throw(:breakout)
|
19
|
+
else
|
20
|
+
# Otherwise, saves current binding stack as old stack and pops last
|
21
|
+
# binding out of binding stack (the old stack still has that binding).
|
22
|
+
cd_state = Pry::CommandState.default.state_for('cd')
|
23
|
+
cd_state.old_stack = pry_instance.binding_stack.dup
|
24
|
+
pry_instance.binding_stack.pop
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
data/lib/pry/core_extensions.rb
CHANGED
@@ -1,10 +1,12 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
class Pry
|
2
4
|
# @return [Array] Code of the method used when implementing Pry's
|
3
5
|
# __binding__, along with line indication to be used with instance_eval (and
|
4
6
|
# friends).
|
5
7
|
#
|
6
8
|
# @see Object#__binding__
|
7
|
-
BINDING_METHOD_IMPL = [<<-METHOD, __FILE__, __LINE__ + 1]
|
9
|
+
BINDING_METHOD_IMPL = [<<-METHOD, __FILE__, __LINE__ + 1].freeze
|
8
10
|
# Get a binding with 'self' set to self, and no locals.
|
9
11
|
#
|
10
12
|
# The default definee is determined by the context in which the
|
@@ -38,8 +40,8 @@ class Object
|
|
38
40
|
# end
|
39
41
|
# my_method()
|
40
42
|
# @see Pry.start
|
41
|
-
def pry(object=nil, hash={})
|
42
|
-
if object.nil? || Hash === object
|
43
|
+
def pry(object = nil, hash = {})
|
44
|
+
if object.nil? || Hash === object # rubocop:disable Style/CaseEquality
|
43
45
|
Pry.start(self, object || {})
|
44
46
|
else
|
45
47
|
Pry.start(object, hash)
|
@@ -68,15 +70,26 @@ class Object
|
|
68
70
|
def __binding__
|
69
71
|
# If you ever feel like changing this method, be careful about variables
|
70
72
|
# that you use. They shouldn't be inserted into the binding that will
|
71
|
-
# eventually be
|
73
|
+
# eventually be returned.
|
72
74
|
|
73
75
|
# When you're cd'd into a class, methods you define should be added to it.
|
74
76
|
if is_a?(Module)
|
77
|
+
# A special case, for JRuby.
|
78
|
+
# Module.new.class_eval("binding") has different behaviour than CRuby,
|
79
|
+
# where this is not needed: class_eval("binding") vs class_eval{binding}.
|
80
|
+
# Using a block works around the difference of behaviour on JRuby.
|
81
|
+
# The scope is clear of local variables. Don't add any.
|
82
|
+
#
|
83
|
+
# This fixes the following two spec failures, at https://travis-ci.org/pry/pry/jobs/274470002
|
84
|
+
# 1) ./spec/pry_spec.rb:360:in `block in (root)'
|
85
|
+
# 2) ./spec/pry_spec.rb:366:in `block in (root)'
|
86
|
+
return class_eval { binding } if Pry::Helpers::Platform.jruby? && name.nil?
|
87
|
+
|
75
88
|
# class_eval sets both self and the default definee to this class.
|
76
|
-
return class_eval
|
89
|
+
return class_eval("binding", __FILE__, __LINE__)
|
77
90
|
end
|
78
91
|
|
79
|
-
unless
|
92
|
+
unless self.class.method_defined?(:__pry__)
|
80
93
|
# The easiest way to check whether an object has a working singleton class
|
81
94
|
# is to try and define a method on it. (just checking for the presence of
|
82
95
|
# the singleton class gives false positives for `true` and `false`).
|
@@ -113,7 +126,7 @@ class BasicObject
|
|
113
126
|
# BasicObjects don't have respond_to?, so we just define the method
|
114
127
|
# every time. As they also don't have `.freeze`, this call won't
|
115
128
|
# fail as it can for normal Objects.
|
116
|
-
(class << self; self; end).class_eval
|
129
|
+
(class << self; self; end).class_eval(<<-METHOD, __FILE__, __LINE__ + 1)
|
117
130
|
# Get a binding with 'self' set to self, and no locals.
|
118
131
|
#
|
119
132
|
# The default definee is determined by the context in which the
|
@@ -125,7 +138,7 @@ class BasicObject
|
|
125
138
|
def __pry__
|
126
139
|
::Kernel.binding
|
127
140
|
end
|
128
|
-
|
129
|
-
|
141
|
+
METHOD
|
142
|
+
__pry__
|
130
143
|
end
|
131
144
|
end
|
data/lib/pry/editor.rb
CHANGED
@@ -1,15 +1,34 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'shellwords'
|
4
|
+
|
1
5
|
class Pry
|
2
6
|
class Editor
|
3
|
-
|
7
|
+
def self.default
|
8
|
+
if (visual = Pry::Env['VISUAL'])
|
9
|
+
return visual
|
10
|
+
end
|
11
|
+
|
12
|
+
if (editor = Pry::Env['EDITOR'])
|
13
|
+
return editor
|
14
|
+
end
|
15
|
+
|
16
|
+
return 'notepad' if Helpers::Platform.windows?
|
17
|
+
|
18
|
+
%w[editor nano vi].find do |editor_exe|
|
19
|
+
Kernel.system("which #{editor_exe} > /dev/null 2>&1")
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
4
23
|
include Pry::Helpers::CommandHelpers
|
5
24
|
|
6
|
-
attr_reader :
|
25
|
+
attr_reader :pry_instance
|
7
26
|
|
8
|
-
def initialize(
|
9
|
-
@
|
27
|
+
def initialize(pry_instance)
|
28
|
+
@pry_instance = pry_instance
|
10
29
|
end
|
11
30
|
|
12
|
-
def edit_tempfile_with_content(initial_content, line=1)
|
31
|
+
def edit_tempfile_with_content(initial_content, line = 1)
|
13
32
|
temp_file do |f|
|
14
33
|
f.puts(initial_content)
|
15
34
|
f.flush
|
@@ -19,58 +38,60 @@ class Pry
|
|
19
38
|
end
|
20
39
|
end
|
21
40
|
|
22
|
-
def invoke_editor(file, line, blocking=true)
|
23
|
-
|
41
|
+
def invoke_editor(file, line, blocking = true)
|
42
|
+
unless pry_instance.config.editor
|
43
|
+
raise CommandError,
|
44
|
+
"Please set Pry.config.editor or export $VISUAL or $EDITOR"
|
45
|
+
end
|
24
46
|
|
25
47
|
editor_invocation = build_editor_invocation_string(file, line, blocking)
|
26
48
|
return nil unless editor_invocation
|
27
49
|
|
28
|
-
if jruby?
|
50
|
+
if Helpers::Platform.jruby?
|
29
51
|
open_editor_on_jruby(editor_invocation)
|
30
52
|
else
|
31
53
|
open_editor(editor_invocation)
|
32
54
|
end
|
33
55
|
end
|
34
56
|
|
35
|
-
private
|
36
|
-
|
37
57
|
# Generate the string that's used to start the editor. This includes
|
38
58
|
# all the flags we want as well as the file and line number we
|
39
59
|
# want to open at.
|
40
60
|
def build_editor_invocation_string(file, line, blocking)
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
_pry_.config.editor.call(*args)
|
61
|
+
if pry_instance.config.editor.respond_to?(:call)
|
62
|
+
args = [file, line, blocking][0...(pry_instance.config.editor.arity)]
|
63
|
+
pry_instance.config.editor.call(*args)
|
45
64
|
else
|
46
|
-
sanitized_file =
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
"#{_pry_.config.editor} #{blocking_flag_for_editor(blocking)} #{start_line_syntax_for_editor(sanitized_file, line)}"
|
65
|
+
sanitized_file = Helpers::Platform.windows? ? file : Shellwords.escape(file)
|
66
|
+
editor = pry_instance.config.editor
|
67
|
+
flag = blocking_flag_for_editor(blocking)
|
68
|
+
start_line = start_line_syntax_for_editor(sanitized_file, line)
|
69
|
+
"#{editor} #{flag} #{start_line}"
|
53
70
|
end
|
54
71
|
end
|
55
72
|
|
73
|
+
private
|
74
|
+
|
56
75
|
# Start the editor running, using the calculated invocation string
|
57
76
|
def open_editor(editor_invocation)
|
58
77
|
# Note we dont want to use Pry.config.system here as that
|
59
78
|
# may be invoked non-interactively (i.e via Open4), whereas we want to
|
60
79
|
# ensure the editor is always interactive
|
61
|
-
system(*Shellwords.split(editor_invocation))
|
80
|
+
system(*Shellwords.split(editor_invocation)) ||
|
81
|
+
raise(
|
82
|
+
CommandError,
|
83
|
+
"`#{editor_invocation}` gave exit status: #{$CHILD_STATUS.exitstatus}"
|
84
|
+
)
|
62
85
|
end
|
63
86
|
|
64
87
|
# We need JRuby specific code here cos just shelling out using
|
65
88
|
# system() appears to be pretty broken :/
|
66
89
|
def open_editor_on_jruby(editor_invocation)
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
system(editor_invocation)
|
73
|
-
end
|
90
|
+
require 'spoon'
|
91
|
+
pid = Spoon.spawnp(*Shellwords.split(editor_invocation))
|
92
|
+
Process.waitpid(pid)
|
93
|
+
rescue FFI::NotFoundError
|
94
|
+
system(editor_invocation)
|
74
95
|
end
|
75
96
|
|
76
97
|
# Some editors that run outside the terminal allow you to control whether or
|
@@ -84,7 +105,7 @@ class Pry
|
|
84
105
|
'--nofork' if blocking
|
85
106
|
when /^jedit/
|
86
107
|
'-wait' if blocking
|
87
|
-
when /^mate/, /^subl/, /^redcar/
|
108
|
+
when /^mate/, /^subl/, /^redcar/, /^code/
|
88
109
|
'-w' if blocking
|
89
110
|
end
|
90
111
|
end
|
@@ -100,6 +121,8 @@ class Pry
|
|
100
121
|
"+#{line_number} #{file_name}"
|
101
122
|
when /^mate/, /^geany/
|
102
123
|
"-l #{line_number} #{file_name}"
|
124
|
+
when /^code/
|
125
|
+
"-g #{file_name}:#{line_number}"
|
103
126
|
when /^subl/
|
104
127
|
"#{file_name}:#{line_number}"
|
105
128
|
when /^uedit32/
|
@@ -109,8 +132,8 @@ class Pry
|
|
109
132
|
when /^redcar/
|
110
133
|
"-l#{line_number} #{file_name}"
|
111
134
|
else
|
112
|
-
if windows?
|
113
|
-
|
135
|
+
if Helpers::Platform.windows?
|
136
|
+
file_name.to_s
|
114
137
|
else
|
115
138
|
"+#{line_number} #{file_name}"
|
116
139
|
end
|
@@ -128,8 +151,7 @@ class Pry
|
|
128
151
|
# # => textmate
|
129
152
|
#
|
130
153
|
def editor_name
|
131
|
-
File.basename(
|
154
|
+
File.basename(pry_instance.config.editor).split(" ").first
|
132
155
|
end
|
133
|
-
|
134
156
|
end
|
135
157
|
end
|
data/lib/pry/env.rb
ADDED
@@ -0,0 +1,18 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class Pry
|
4
|
+
# Env is a helper module to work with environment variables.
|
5
|
+
#
|
6
|
+
# @since v0.13.0
|
7
|
+
# @api private
|
8
|
+
module Env
|
9
|
+
def self.[](key)
|
10
|
+
return unless ENV.key?(key)
|
11
|
+
|
12
|
+
value = ENV[key]
|
13
|
+
return if value == ''
|
14
|
+
|
15
|
+
value
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
@@ -0,0 +1,43 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class Pry
|
4
|
+
# @api private
|
5
|
+
# @since v0.13.0
|
6
|
+
module ExceptionHandler
|
7
|
+
class << self
|
8
|
+
# Will only show the first line of the backtrace.
|
9
|
+
def handle_exception(output, exception, _pry_instance)
|
10
|
+
if exception.is_a?(UserError) && exception.is_a?(SyntaxError)
|
11
|
+
output.puts "SyntaxError: #{exception.message.sub(/.*syntax error, */m, '')}"
|
12
|
+
else
|
13
|
+
output.puts standard_error_text_for(exception)
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
private
|
18
|
+
|
19
|
+
def standard_error_text_for(exception)
|
20
|
+
text = exception_text(exception)
|
21
|
+
return text unless exception.respond_to?(:cause)
|
22
|
+
|
23
|
+
cause = exception.cause
|
24
|
+
while cause
|
25
|
+
text += cause_text(cause)
|
26
|
+
cause = cause.cause
|
27
|
+
end
|
28
|
+
|
29
|
+
text
|
30
|
+
end
|
31
|
+
|
32
|
+
def exception_text(exception)
|
33
|
+
"#{exception.class}: #{exception.message}\n" \
|
34
|
+
"from #{exception.backtrace.first}\n"
|
35
|
+
end
|
36
|
+
|
37
|
+
def cause_text(cause)
|
38
|
+
"Caused by #{cause.class}: #{cause}\n" \
|
39
|
+
"from #{cause.backtrace.first}\n"
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|