1
0
Fork 0
mirror of https://github.com/pry/pry.git synced 2022-11-09 12:35:05 -05:00

Pry::Editor, Pry::Command::Whereami: more refactorings

This commit is contained in:
John Mair 2013-01-02 16:25:18 +01:00
parent 4d384737a7
commit e647957507
2 changed files with 53 additions and 26 deletions

View file

@ -30,14 +30,22 @@ class Pry
output.puts "#{text.bold('Exception:')} #{_pry_.last_exception.class}: #{_pry_.last_exception}\n--" output.puts "#{text.bold('Exception:')} #{_pry_.last_exception.class}: #{_pry_.last_exception}\n--"
if opts.verbose? if opts.verbose?
output.puts Pry::Code.new(_pry_.last_exception.backtrace, 0, :text).with_line_numbers.to_s output.puts with_line_numbers(backtrace)
else else
output.puts Pry::Code.new(_pry_.last_exception.backtrace.first(size_of_backtrace), 0, :text).with_line_numbers.to_s output.puts with_line_numbers(backtrace.first(size_of_backtrace))
end end
end end
private private
def with_line_numbers(bt)
Pry::Code.new(bt, 0, :text).with_line_numbers.to_s
end
def backtrace
_pry_.last_exception.backtrace
end
def size_of_backtrace def size_of_backtrace
[captures[0].size, 0.5].max * 10 [captures[0].size, 0.5].max * 10
end end

View file

@ -9,52 +9,71 @@ class Pry
f.puts(initial_content) f.puts(initial_content)
f.flush f.flush
f.close(false) f.close(false)
invoke_editor(f.path, line, false) invoke_editor(f.path, line, true)
File.read(f.path) File.read(f.path)
end end
end end
def invoke_editor(file, line, reloading) def invoke_editor(file, line, blocking=true)
raise CommandError, "Please set Pry.config.editor or export $VISUAL or $EDITOR" unless Pry.config.editor raise CommandError, "Please set Pry.config.editor or export $VISUAL or $EDITOR" unless Pry.config.editor
if Pry.config.editor.respond_to?(:call)
args = [file, line, reloading][0...(Pry.config.editor.arity)] editor_invocation = build_editor_invocation_string(file, line, blocking)
editor_invocation = Pry.config.editor.call(*args)
else
editor_invocation = "#{Pry.config.editor} #{blocking_flag_for_editor(reloading)} #{start_line_syntax_for_editor(file, line)}"
end
return nil unless editor_invocation return nil unless editor_invocation
if jruby? if jruby?
begin open_editor_on_jruby(editor_invocation)
require 'spoon'
pid = Spoon.spawnp(*editor_invocation.split)
Process.waitpid(pid)
rescue FFI::NotFoundError
system(editor_invocation)
end
else else
# Note we dont want to use Pry.config.system here as that open_editor(editor_invocation)
# may be invoked non-interactively (i.e via Open4), whereas we want to
# ensure the editor is always interactive
system(editor_invocation) or raise CommandError, "`#{editor_invocation}` gave exit status: #{$?.exitstatus}"
end end
end end
private private
# Generate the string that's used to start the editor. This includes
# all the flags we want as well as the file and line number we
# want to open at.
def build_editor_invocation_string(file, line, blocking)
if Pry.config.editor.respond_to?(:call)
args = [file, line, blocking][0...(Pry.config.editor.arity)]
Pry.config.editor.call(*args)
else
"#{Pry.config.editor} #{blocking_flag_for_editor(blocking)} #{start_line_syntax_for_editor(file, line)}"
end
end
# Start the editor running, using the calculated invocation string
def open_editor(editor_invocation)
# Note we dont want to use Pry.config.system here as that
# may be invoked non-interactively (i.e via Open4), whereas we want to
# ensure the editor is always interactive
system(editor_invocation) or raise CommandError, "`#{editor_invocation}` gave exit status: #{$?.exitstatus}"
end
# We need JRuby specific code here cos just shelling out using
# system() appears to be pretty broken :/
def open_editor_on_jruby(editor_invocation)
begin
require 'spoon'
pid = Spoon.spawnp(*editor_invocation.split)
Process.waitpid(pid)
rescue FFI::NotFoundError
system(editor_invocation)
end
end
# Some editors that run outside the terminal allow you to control whether or # Some editors that run outside the terminal allow you to control whether or
# not to block the process from which they were launched (in this case, Pry). # not to block the process from which they were launched (in this case, Pry).
# For those editors, return the flag that produces the desired behavior. # For those editors, return the flag that produces the desired behavior.
def blocking_flag_for_editor(block) def blocking_flag_for_editor(blocking)
case editor_name case editor_name
when /^emacsclient/ when /^emacsclient/
'--no-wait' unless block '--no-wait' unless blocking
when /^[gm]vim/ when /^[gm]vim/
'--nofork' if block '--nofork' if blocking
when /^jedit/ when /^jedit/
'-wait' if block '-wait' if blocking
when /^mate/, /^subl/ when /^mate/, /^subl/
'-w' if block '-w' if blocking
end end
end end