pry 0.6.8-java
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.
- data/.gemtest +0 -0
- data/CHANGELOG +88 -0
- data/LICENSE +25 -0
- data/README.markdown +321 -0
- data/Rakefile +103 -0
- data/bin/pry +83 -0
- data/examples/example_basic.rb +17 -0
- data/examples/example_command_override.rb +35 -0
- data/examples/example_commands.rb +39 -0
- data/examples/example_hooks.rb +12 -0
- data/examples/example_image_edit.rb +71 -0
- data/examples/example_input.rb +10 -0
- data/examples/example_input2.rb +32 -0
- data/examples/example_output.rb +14 -0
- data/examples/example_print.rb +9 -0
- data/examples/example_prompt.rb +12 -0
- data/lib/pry.rb +32 -0
- data/lib/pry/command_base.rb +150 -0
- data/lib/pry/commands.rb +616 -0
- data/lib/pry/completion.rb +202 -0
- data/lib/pry/core_extensions.rb +55 -0
- data/lib/pry/hooks.rb +19 -0
- data/lib/pry/print.rb +19 -0
- data/lib/pry/prompts.rb +26 -0
- data/lib/pry/pry_class.rb +219 -0
- data/lib/pry/pry_instance.rb +316 -0
- data/lib/pry/version.rb +3 -0
- data/test/test.rb +725 -0
- data/test/test_helper.rb +46 -0
- data/test/testrc +2 -0
- metadata +152 -0
    
        data/bin/pry
    ADDED
    
    | @@ -0,0 +1,83 @@ | |
| 1 | 
            +
            #!/usr/bin/env ruby
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            # (C) John Mair (banisterfiend)
         | 
| 4 | 
            +
            # MIT license
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            begin
         | 
| 7 | 
            +
              require 'pry'
         | 
| 8 | 
            +
            rescue LoadError
         | 
| 9 | 
            +
              require 'rubygems'
         | 
| 10 | 
            +
              require 'pry'
         | 
| 11 | 
            +
            end
         | 
| 12 | 
            +
            require 'optparse'
         | 
| 13 | 
            +
             | 
| 14 | 
            +
            # defaults
         | 
| 15 | 
            +
            options = {
         | 
| 16 | 
            +
              :context_string => "TOPLEVEL_BINDING",
         | 
| 17 | 
            +
              :loadrc => true
         | 
| 18 | 
            +
            }
         | 
| 19 | 
            +
             | 
| 20 | 
            +
            OptionParser.new do |opts|
         | 
| 21 | 
            +
              opts.banner = %{Usage: pry [OPTIONS] 
         | 
| 22 | 
            +
            Start a Pry session.
         | 
| 23 | 
            +
            See: `https://github.com/banister` for more information.
         | 
| 24 | 
            +
            --
         | 
| 25 | 
            +
            }
         | 
| 26 | 
            +
              opts.on("-r", "--require FILE", "`require` a Ruby script at startup.") do |file|
         | 
| 27 | 
            +
                require file
         | 
| 28 | 
            +
              end
         | 
| 29 | 
            +
             | 
| 30 | 
            +
              opts.on("-e", "--exec CODE", "A line of Ruby code to execute in context before the session starts.") do |code|
         | 
| 31 | 
            +
                options[:code] = code
         | 
| 32 | 
            +
              end
         | 
| 33 | 
            +
             | 
| 34 | 
            +
              opts.on("-f", "Suppress loading of ~/.pryrc") do 
         | 
| 35 | 
            +
                options[:loadrc] = false
         | 
| 36 | 
            +
              end
         | 
| 37 | 
            +
             | 
| 38 | 
            +
              opts.on("--no-color", "Start session without syntax highlighting.") do 
         | 
| 39 | 
            +
                Pry.color = false
         | 
| 40 | 
            +
              end
         | 
| 41 | 
            +
             | 
| 42 | 
            +
              opts.on("--simple-prompt", "Simple prompt mode.") do 
         | 
| 43 | 
            +
                Pry.prompt = Pry::SIMPLE_PROMPT
         | 
| 44 | 
            +
              end
         | 
| 45 | 
            +
             | 
| 46 | 
            +
              opts.on("-I LOADPATH", "Specify $LOAD_PATH directory.") do  |load_path|
         | 
| 47 | 
            +
                $LOAD_PATH << load_path
         | 
| 48 | 
            +
              end
         | 
| 49 | 
            +
             | 
| 50 | 
            +
              opts.on("-v", "--version", "Display the Pry version.") do
         | 
| 51 | 
            +
                puts "Pry version #{Pry::VERSION} on Ruby #{RUBY_VERSION}"
         | 
| 52 | 
            +
                exit
         | 
| 53 | 
            +
              end
         | 
| 54 | 
            +
             | 
| 55 | 
            +
              opts.on("-c", "--context CONTEXT",
         | 
| 56 | 
            +
                      "Start the session in the specified context. Equivalent to `context.pry` in a session.") do |context|
         | 
| 57 | 
            +
             | 
| 58 | 
            +
                # save the context name
         | 
| 59 | 
            +
                options[:context_string] = context
         | 
| 60 | 
            +
              end
         | 
| 61 | 
            +
             | 
| 62 | 
            +
              opts.on_tail("-h", "--help", "This message.") do 
         | 
| 63 | 
            +
                puts opts
         | 
| 64 | 
            +
                exit
         | 
| 65 | 
            +
              end
         | 
| 66 | 
            +
            end.parse!
         | 
| 67 | 
            +
             | 
| 68 | 
            +
            # invoked via cli
         | 
| 69 | 
            +
            Pry.cli = true
         | 
| 70 | 
            +
             | 
| 71 | 
            +
            # load ~/.pryrc, if not suppressed with -f option
         | 
| 72 | 
            +
            Pry.should_load_rc = false if !options[:loadrc]
         | 
| 73 | 
            +
             | 
| 74 | 
            +
            # create the actual context
         | 
| 75 | 
            +
            context = Pry.binding_for(eval(options[:context_string]))
         | 
| 76 | 
            +
             | 
| 77 | 
            +
            # run code passed with `-e`, if there is any.
         | 
| 78 | 
            +
            if options[:code]
         | 
| 79 | 
            +
              Pry.new(:input => StringIO.new(options[:code]), :print => proc {}).rep(context)
         | 
| 80 | 
            +
            end
         | 
| 81 | 
            +
             | 
| 82 | 
            +
            # start the session
         | 
| 83 | 
            +
            context.pry
         | 
| @@ -0,0 +1,17 @@ | |
| 1 | 
            +
            direc = File.dirname(__FILE__)
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            require 'rubygems'
         | 
| 4 | 
            +
            require "#{direc}/../lib/pry"
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            # define a local.
         | 
| 7 | 
            +
            a = "a local variable"
         | 
| 8 | 
            +
             | 
| 9 | 
            +
            # defing a top-level method.
         | 
| 10 | 
            +
            def hello
         | 
| 11 | 
            +
              puts "hello world!"
         | 
| 12 | 
            +
            end
         | 
| 13 | 
            +
             | 
| 14 | 
            +
            # Start pry session at top-level.
         | 
| 15 | 
            +
            # The local variable `a` and the `hello` method will
         | 
| 16 | 
            +
            # be accessible.
         | 
| 17 | 
            +
            pry
         | 
| @@ -0,0 +1,35 @@ | |
| 1 | 
            +
            direc = File.dirname(__FILE__)
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            require 'rubygems'
         | 
| 4 | 
            +
            require "#{direc}/../lib/pry"
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            # Inherit standard command set, but tweak them by importing some and
         | 
| 7 | 
            +
            # overriding others.
         | 
| 8 | 
            +
            # Illustrates use of `command`, `run`, and `import_from` commands.
         | 
| 9 | 
            +
            class MyCommands < Pry::CommandBase
         | 
| 10 | 
            +
             | 
| 11 | 
            +
              # Override ls command
         | 
| 12 | 
            +
              command "ls", "An unhelpful ls" do
         | 
| 13 | 
            +
                output.puts "No, i refuse to display any useful information."
         | 
| 14 | 
            +
              end
         | 
| 15 | 
            +
             | 
| 16 | 
            +
              # bring in just the status command from Pry::Commands
         | 
| 17 | 
            +
              import_from Pry::Commands, "status"
         | 
| 18 | 
            +
             | 
| 19 | 
            +
              # analogy to Ruby's native alias_method idiom for decorating a method
         | 
| 20 | 
            +
              alias_command "old_status", "status", ""
         | 
| 21 | 
            +
              
         | 
| 22 | 
            +
              # Invoke one command from within another using `run`
         | 
| 23 | 
            +
              command "status", "Modified status."  do |x|
         | 
| 24 | 
            +
                output.puts "About to show status, are you ready?"
         | 
| 25 | 
            +
                run "old_status", x
         | 
| 26 | 
            +
                output.puts "Finished showing status."
         | 
| 27 | 
            +
              end
         | 
| 28 | 
            +
             | 
| 29 | 
            +
              # bring in a few other commands
         | 
| 30 | 
            +
              import_from Pry::Commands, "quit", "show-method"
         | 
| 31 | 
            +
            end
         | 
| 32 | 
            +
             | 
| 33 | 
            +
            # Start a Pry session using the commands defined in MyCommands
         | 
| 34 | 
            +
            # Type 'help' in Pry to get a list of the commands and their descriptions
         | 
| 35 | 
            +
            Pry.start(TOPLEVEL_BINDING, :commands => MyCommands)
         | 
| @@ -0,0 +1,39 @@ | |
| 1 | 
            +
            direc = File.dirname(__FILE__)
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            require 'rubygems'
         | 
| 4 | 
            +
            require "#{direc}/../lib/pry"
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            class MathCommands < Pry::CommandBase
         | 
| 7 | 
            +
              command "greet", "Greet a person, e.g: greet john" do |name|
         | 
| 8 | 
            +
                output.puts "Good afternoon #{name.capitalize}! Do you like Math?"
         | 
| 9 | 
            +
              end
         | 
| 10 | 
            +
             | 
| 11 | 
            +
              command "add", "Add a list of numbers together, e.g: add 1 2 3 4" do |*args|
         | 
| 12 | 
            +
                output.puts "Total: #{args.map(&:to_f).inject(&:+)}"
         | 
| 13 | 
            +
              end
         | 
| 14 | 
            +
             | 
| 15 | 
            +
              command "multiply", "Multiply a list of numbers together, e.g: multiply 1 2 3 4" do |*args|
         | 
| 16 | 
            +
                output.puts "Total: #{args.map(&:to_f).inject(&:*)}"
         | 
| 17 | 
            +
              end
         | 
| 18 | 
            +
             | 
| 19 | 
            +
              # Explicitly giving a description of "" to prevent command being
         | 
| 20 | 
            +
              # displayed in 'help'
         | 
| 21 | 
            +
              command "exit", "" do
         | 
| 22 | 
            +
                throw :breakout, 0
         | 
| 23 | 
            +
              end
         | 
| 24 | 
            +
             | 
| 25 | 
            +
              # Bring in the "!" method from Pry::Commands
         | 
| 26 | 
            +
              import_from Pry::Commands, "!"
         | 
| 27 | 
            +
            end
         | 
| 28 | 
            +
             | 
| 29 | 
            +
            # Since we provide math commands, let's have mathematical
         | 
| 30 | 
            +
            # before_session and after_session hooks, and a mathematical prompt
         | 
| 31 | 
            +
            math_prompt = [proc { "math> " }, proc { "math* " }]
         | 
| 32 | 
            +
            math_hooks = {
         | 
| 33 | 
            +
              :before_session => proc { |output, *| output.puts "Welcome! Let's do some math! Type 'help' for a list of commands." },
         | 
| 34 | 
            +
              :after_session => proc { |output, *| output.puts "Goodbye!" }
         | 
| 35 | 
            +
            }
         | 
| 36 | 
            +
             | 
| 37 | 
            +
            # Start a Pry session using the commands defined in MyCommands
         | 
| 38 | 
            +
            # Type 'help' in Pry to get a list of the commands and their descriptions
         | 
| 39 | 
            +
            Pry.start(TOPLEVEL_BINDING, :commands => MathCommands, :prompt => math_prompt, :hooks => math_hooks)
         | 
| @@ -0,0 +1,12 @@ | |
| 1 | 
            +
            direc = File.dirname(__FILE__)
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            require 'rubygems'
         | 
| 4 | 
            +
            require "#{direc}/../lib/pry"
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            my_hooks = {
         | 
| 7 | 
            +
              :before_session => proc { |out, target| out.puts "Opening #{target.eval('self')}." },
         | 
| 8 | 
            +
              :after_session => proc { |out, target| out.puts "Closing #{target.eval('self')}." }
         | 
| 9 | 
            +
            }
         | 
| 10 | 
            +
                       
         | 
| 11 | 
            +
            # Start a Pry session using the hooks hash defined in my_hooks
         | 
| 12 | 
            +
            Pry.start(TOPLEVEL_BINDING, :hooks => my_hooks)
         | 
| @@ -0,0 +1,71 @@ | |
| 1 | 
            +
            # Note: this requires you to have Gosu and TexPlay installed.
         | 
| 2 | 
            +
            # `gem install gosu`
         | 
| 3 | 
            +
            # `gem install texplay`
         | 
| 4 | 
            +
            # 
         | 
| 5 | 
            +
            # Extra instructions for installing Gosu on Linux can be found here:
         | 
| 6 | 
            +
            # http://code.google.com/p/gosu/wiki/GettingStartedOnLinux
         | 
| 7 | 
            +
            #
         | 
| 8 | 
            +
            # Instructions for using TexPlay can be found here:
         | 
| 9 | 
            +
            # http://banisterfiend.wordpress.com/2008/08/23/texplay-an-image-manipulation-tool-for-ruby-and-gosu/
         | 
| 10 | 
            +
            #
         | 
| 11 | 
            +
            # Have fun! :)
         | 
| 12 | 
            +
             | 
| 13 | 
            +
            direc = File.dirname(__FILE__)
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            require 'rubygems'
         | 
| 16 | 
            +
            require "texplay"
         | 
| 17 | 
            +
            require "#{direc}/../lib/pry"
         | 
| 18 | 
            +
             | 
| 19 | 
            +
            WIDTH = 640
         | 
| 20 | 
            +
            HEIGHT = 480
         | 
| 21 | 
            +
             | 
| 22 | 
            +
            IMAGE_PROMPT = [ proc { "(image edit)> " }, proc { "(image edit)* " } ]
         | 
| 23 | 
            +
             | 
| 24 | 
            +
            class ImageCommands < Pry::CommandBase
         | 
| 25 | 
            +
              command "drawing_methods", "Show a list of TexPlay methods" do
         | 
| 26 | 
            +
                output.puts "#{Pry.view(TexPlay.public_instance_methods)}"
         | 
| 27 | 
            +
              end
         | 
| 28 | 
            +
             | 
| 29 | 
            +
              command "exit", "Exit the program." do
         | 
| 30 | 
            +
                output.puts "Thanks for dropping by!"
         | 
| 31 | 
            +
                exit
         | 
| 32 | 
            +
              end
         | 
| 33 | 
            +
             | 
| 34 | 
            +
              import_from Pry::Commands, "ls", "!"
         | 
| 35 | 
            +
            end
         | 
| 36 | 
            +
             | 
| 37 | 
            +
            class WinClass < Gosu::Window
         | 
| 38 | 
            +
             | 
| 39 | 
            +
              def initialize
         | 
| 40 | 
            +
                super(WIDTH, HEIGHT, false)
         | 
| 41 | 
            +
                @img = TexPlay.create_image(self, 200, 200).clear :color => :black
         | 
| 42 | 
            +
                @img.rect 0, 0, @img.width - 1, @img.height - 1
         | 
| 43 | 
            +
             | 
| 44 | 
            +
                @binding = Pry.binding_for(@img)
         | 
| 45 | 
            +
                
         | 
| 46 | 
            +
                @pry_instance = Pry.new(:commands => ImageCommands, :prompt => IMAGE_PROMPT)
         | 
| 47 | 
            +
              end
         | 
| 48 | 
            +
             | 
| 49 | 
            +
              def draw
         | 
| 50 | 
            +
                @img.draw_rot(WIDTH / 2, HEIGHT / 2, 1, 0, 0.5, 0.5) 
         | 
| 51 | 
            +
              end
         | 
| 52 | 
            +
             | 
| 53 | 
            +
              def update
         | 
| 54 | 
            +
                exit if button_down?(Gosu::KbEscape)
         | 
| 55 | 
            +
             | 
| 56 | 
            +
                # We do not want a REPL session as the loop prevents the image
         | 
| 57 | 
            +
                # being updated; instead we do a REP session, and let the image
         | 
| 58 | 
            +
                # update each time the user presses enter. We maintain the same
         | 
| 59 | 
            +
                # binding object to keep locals between calls to `Pry#rep()`
         | 
| 60 | 
            +
                @pry_instance.rep(@binding)
         | 
| 61 | 
            +
              end
         | 
| 62 | 
            +
            end
         | 
| 63 | 
            +
             | 
| 64 | 
            +
            puts "Welcome to ImageEdit; type `help` for a list of commands and `drawing_methods` for a list of drawing methods available."
         | 
| 65 | 
            +
            puts "--"
         | 
| 66 | 
            +
            puts "Example: Try typing 'circle width/2, height/2, 95, :color => :blue, :fill => true'"
         | 
| 67 | 
            +
            puts "If you want to save your image, type: save(\"img.png\")"
         | 
| 68 | 
            +
             | 
| 69 | 
            +
            w = WinClass.new
         | 
| 70 | 
            +
            w.show
         | 
| 71 | 
            +
             | 
| @@ -0,0 +1,10 @@ | |
| 1 | 
            +
            direc = File.dirname(__FILE__)
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            require 'rubygems'
         | 
| 4 | 
            +
            require "#{direc}/../lib/pry"
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            # Create a StringIO that contains the input data
         | 
| 7 | 
            +
            str_input = StringIO.new("puts 'hello world!'\nputs \"I am in \#{self}\"\nexit")
         | 
| 8 | 
            +
             | 
| 9 | 
            +
            # Start a Pry session on the Fixnum 5 using the input data in str_input
         | 
| 10 | 
            +
            Pry.start(5, :input => str_input)
         | 
| @@ -0,0 +1,32 @@ | |
| 1 | 
            +
            direc = File.dirname(__FILE__)
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            require 'rubygems'
         | 
| 4 | 
            +
            require "#{direc}/../lib/pry"
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            # Create a StringIO that contains the input data for all the Pry objects
         | 
| 7 | 
            +
            cmds = <<-CMDS
         | 
| 8 | 
            +
            cd 1
         | 
| 9 | 
            +
            status
         | 
| 10 | 
            +
            puts 'hello from 1!!'
         | 
| 11 | 
            +
            cd 2
         | 
| 12 | 
            +
            nesting
         | 
| 13 | 
            +
            puts 'hello from 2!!'
         | 
| 14 | 
            +
            _pry_.parent.input = Readline
         | 
| 15 | 
            +
            back
         | 
| 16 | 
            +
            exit-all
         | 
| 17 | 
            +
            CMDS
         | 
| 18 | 
            +
             | 
| 19 | 
            +
            # create our StringIO object
         | 
| 20 | 
            +
            str_input = StringIO.new(cmds)
         | 
| 21 | 
            +
             | 
| 22 | 
            +
            # set global input to str_input, this means that all pry sessions
         | 
| 23 | 
            +
            # adopt this object as their input object.
         | 
| 24 | 
            +
            Pry.input = str_input
         | 
| 25 | 
            +
             | 
| 26 | 
            +
            # Start the session reading from str_input.
         | 
| 27 | 
            +
            # Note that because `Pry.input` is set to `str_input` all nested pry
         | 
| 28 | 
            +
            # sessions will read from `str_input` too. All pry sessions are there
         | 
| 29 | 
            +
            # for non-interactive, except for `pry(1)` which starts off
         | 
| 30 | 
            +
            # non-interactive but is set to be interactive by pry(2) (using
         | 
| 31 | 
            +
            # _pry_.parent.input = Readline)
         | 
| 32 | 
            +
            0.pry
         | 
| @@ -0,0 +1,14 @@ | |
| 1 | 
            +
            direc = File.dirname(__FILE__)
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            require 'rubygems'
         | 
| 4 | 
            +
            require "#{direc}/../lib/pry"
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            # Create a StringIO to contain the output data
         | 
| 7 | 
            +
            str_output = StringIO.new
         | 
| 8 | 
            +
             | 
| 9 | 
            +
            # Start a Pry session on the Fixnum 5 using str_output to store the
         | 
| 10 | 
            +
            # output (not writing to $stdout)
         | 
| 11 | 
            +
            Pry.start(5, :output => str_output)
         | 
| 12 | 
            +
             | 
| 13 | 
            +
            # Display all the output accumulated during the session
         | 
| 14 | 
            +
            puts str_output.string
         | 
| @@ -0,0 +1,9 @@ | |
| 1 | 
            +
            direc = File.dirname(__FILE__)
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            require 'rubygems'
         | 
| 4 | 
            +
            require "#{direc}/../lib/pry"
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            my_print = proc { |out, value| out.puts "Output is: #{value.inspect}" }
         | 
| 7 | 
            +
                       
         | 
| 8 | 
            +
            # Start a Pry session using the print object defined in my_print
         | 
| 9 | 
            +
            Pry.start(TOPLEVEL_BINDING, :print => my_print)
         | 
| @@ -0,0 +1,12 @@ | |
| 1 | 
            +
            direc = File.dirname(__FILE__)
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            require 'rubygems'
         | 
| 4 | 
            +
            require "#{direc}/../lib/pry"
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            # Remember, first prompt in array is the main prompt, second is the wait
         | 
| 7 | 
            +
            # prompt (used for multiline input when more input is required)
         | 
| 8 | 
            +
            my_prompt = [ proc { |obj, *| "inside #{obj}> " },
         | 
| 9 | 
            +
                       proc { |obj, *| "inside #{obj}* "} ]
         | 
| 10 | 
            +
                       
         | 
| 11 | 
            +
            # Start a Pry session using the prompt defined in my_prompt
         | 
| 12 | 
            +
            Pry.start(TOPLEVEL_BINDING, :prompt => my_prompt)
         | 
    
        data/lib/pry.rb
    ADDED
    
    | @@ -0,0 +1,32 @@ | |
| 1 | 
            +
            # (C) John Mair (banisterfiend) 2011
         | 
| 2 | 
            +
            # MIT License
         | 
| 3 | 
            +
             | 
| 4 | 
            +
            direc = File.dirname(__FILE__)
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            $LOAD_PATH << File.expand_path(direc)
         | 
| 7 | 
            +
             | 
| 8 | 
            +
            require "method_source"
         | 
| 9 | 
            +
            require 'shellwords'
         | 
| 10 | 
            +
            require "readline"
         | 
| 11 | 
            +
            require "stringio"
         | 
| 12 | 
            +
            require "coderay"
         | 
| 13 | 
            +
             | 
| 14 | 
            +
            if RUBY_PLATFORM =~ /mswin/ || RUBY_PLATFORM =~ /mingw/
         | 
| 15 | 
            +
              begin
         | 
| 16 | 
            +
                require 'win32console'
         | 
| 17 | 
            +
              rescue LoadError
         | 
| 18 | 
            +
                $stderr.puts "Need to `gem install win32console`" 
         | 
| 19 | 
            +
                exit 1
         | 
| 20 | 
            +
              end
         | 
| 21 | 
            +
            end
         | 
| 22 | 
            +
             | 
| 23 | 
            +
            require "pry/version"
         | 
| 24 | 
            +
            require "pry/hooks"
         | 
| 25 | 
            +
            require "pry/print"
         | 
| 26 | 
            +
            require "pry/command_base"
         | 
| 27 | 
            +
            require "pry/commands"
         | 
| 28 | 
            +
            require "pry/prompts"
         | 
| 29 | 
            +
            require "pry/completion"
         | 
| 30 | 
            +
            require "pry/core_extensions"
         | 
| 31 | 
            +
            require "pry/pry_class"
         | 
| 32 | 
            +
            require "pry/pry_instance"
         | 
| @@ -0,0 +1,150 @@ | |
| 1 | 
            +
            class Pry
         | 
| 2 | 
            +
             | 
| 3 | 
            +
              # Basic command functionality. All user-defined commands must
         | 
| 4 | 
            +
              # inherit from this class. It provides the `command` method.
         | 
| 5 | 
            +
              class CommandBase
         | 
| 6 | 
            +
                class << self
         | 
| 7 | 
            +
                  attr_accessor :commands
         | 
| 8 | 
            +
                  attr_accessor :opts, :output, :target
         | 
| 9 | 
            +
             | 
| 10 | 
            +
                  # private because we want to force function style invocation. We require
         | 
| 11 | 
            +
                  # that the location where the block is defined has the `opts`
         | 
| 12 | 
            +
                  # method in scope.
         | 
| 13 | 
            +
                  private
         | 
| 14 | 
            +
                  
         | 
| 15 | 
            +
                  # Defines a new Pry command.
         | 
| 16 | 
            +
                  # @param [String, Array] names The name of the command (or array of
         | 
| 17 | 
            +
                  #   command name aliases).
         | 
| 18 | 
            +
                  # @param [String] description A description of the command.
         | 
| 19 | 
            +
                  # @param [Hash] options The optional configuration parameters.
         | 
| 20 | 
            +
                  # @option options [Boolean] :keep_retval Whether or not to use return value
         | 
| 21 | 
            +
                  #   of the block for return of `command` or just to return `nil`
         | 
| 22 | 
            +
                  #   (the default).
         | 
| 23 | 
            +
                  # @yield The action to perform. The parameters in the block
         | 
| 24 | 
            +
                  #   determines the parameters the command will receive. All
         | 
| 25 | 
            +
                  #   parameters passed into the block will be strings. Successive
         | 
| 26 | 
            +
                  #   command parameters are separated by whitespace at the Pry prompt.
         | 
| 27 | 
            +
                  # @example
         | 
| 28 | 
            +
                  #   class MyCommands < Pry::CommandBase
         | 
| 29 | 
            +
                  #     command "greet", "Greet somebody" do |name|
         | 
| 30 | 
            +
                  #       puts "Good afternoon #{name.capitalize}!"
         | 
| 31 | 
            +
                  #     end
         | 
| 32 | 
            +
                  #   end
         | 
| 33 | 
            +
                  #
         | 
| 34 | 
            +
                  #   # From pry:
         | 
| 35 | 
            +
                  #   # pry(main)> _pry_.commands = MyCommands
         | 
| 36 | 
            +
                  #   # pry(main)> greet john
         | 
| 37 | 
            +
                  #   # Good afternoon John!
         | 
| 38 | 
            +
                  #   # pry(main)> help greet
         | 
| 39 | 
            +
                  #   # Greet somebody
         | 
| 40 | 
            +
                  def command(names, description="No description.", options={}, &block)
         | 
| 41 | 
            +
                    options = {
         | 
| 42 | 
            +
                      :keep_retval => false
         | 
| 43 | 
            +
                    }.merge!(options)
         | 
| 44 | 
            +
                    
         | 
| 45 | 
            +
                    @commands ||= {}
         | 
| 46 | 
            +
             | 
| 47 | 
            +
                    Array(names).each do |name|
         | 
| 48 | 
            +
                      commands[name] = {
         | 
| 49 | 
            +
                        :description => description,
         | 
| 50 | 
            +
                        :action => block,
         | 
| 51 | 
            +
                        :keep_retval => options[:keep_retval]
         | 
| 52 | 
            +
                      }
         | 
| 53 | 
            +
                    end
         | 
| 54 | 
            +
                  end
         | 
| 55 | 
            +
             | 
| 56 | 
            +
                  # Delete a command or an array of commands.
         | 
| 57 | 
            +
                  # Useful when inheriting from another command set and pruning
         | 
| 58 | 
            +
                  # those commands down to the ones you want.
         | 
| 59 | 
            +
                  # @param [Array<String>] names The command name or array
         | 
| 60 | 
            +
                  #   of command names you want to delete
         | 
| 61 | 
            +
                  # @example Deleteing inherited commands
         | 
| 62 | 
            +
                  #   class MyCommands < Pry::Commands
         | 
| 63 | 
            +
                  #     delete "show_method", "show_imethod", "show_doc", "show_idoc"
         | 
| 64 | 
            +
                  #   end
         | 
| 65 | 
            +
                  #   Pry.commands = MyCommands
         | 
| 66 | 
            +
                  def delete(*names)
         | 
| 67 | 
            +
                    names.each { |name| commands.delete(name) }
         | 
| 68 | 
            +
                  end
         | 
| 69 | 
            +
             | 
| 70 | 
            +
                  # Execute a command (this enables commands to call other commands).
         | 
| 71 | 
            +
                  # @param [String] name The command to execute
         | 
| 72 | 
            +
                  # @param [Array] args The parameters to pass to the command.
         | 
| 73 | 
            +
                  # @example Wrap one command with another
         | 
| 74 | 
            +
                  #   class MyCommands < Pry::Commands
         | 
| 75 | 
            +
                  #     command "ls2" do
         | 
| 76 | 
            +
                  #       output.puts "before ls"
         | 
| 77 | 
            +
                  #       run "ls"
         | 
| 78 | 
            +
                  #       output.puts "after ls"
         | 
| 79 | 
            +
                  #     end
         | 
| 80 | 
            +
                  #   end
         | 
| 81 | 
            +
                  def run(name, *args)
         | 
| 82 | 
            +
                    action = opts[:commands][name][:action]
         | 
| 83 | 
            +
                    instance_exec(*args, &action)
         | 
| 84 | 
            +
                  end
         | 
| 85 | 
            +
             | 
| 86 | 
            +
                  # Import commands from another command object.
         | 
| 87 | 
            +
                  # @param [Pry::CommandBase] klass The class to import from (must
         | 
| 88 | 
            +
                  #   be a subclass of `Pry::CommandBase`)
         | 
| 89 | 
            +
                  # @param [Array<String>] names The commands to import.
         | 
| 90 | 
            +
                  # @example
         | 
| 91 | 
            +
                  #   class MyCommands < Pry::CommandBase
         | 
| 92 | 
            +
                  #     import_from Pry::Commands, "ls", "show_method", "cd"
         | 
| 93 | 
            +
                  #   end
         | 
| 94 | 
            +
                  def import_from(klass, *names)
         | 
| 95 | 
            +
                    imported_hash = Hash[klass.commands.select { |k, v| names.include?(k) }]
         | 
| 96 | 
            +
                    commands.merge!(imported_hash)
         | 
| 97 | 
            +
                  end
         | 
| 98 | 
            +
             | 
| 99 | 
            +
                  # Create an alias for a command.
         | 
| 100 | 
            +
                  # @param [String] new_command The alias name.
         | 
| 101 | 
            +
                  # @param [String] orig_command The original command name.
         | 
| 102 | 
            +
                  # @param [String] desc The optional description.
         | 
| 103 | 
            +
                  # @example
         | 
| 104 | 
            +
                  #   class MyCommands < Pry::CommandBase
         | 
| 105 | 
            +
                  #     alias_command "help_alias", "help"
         | 
| 106 | 
            +
                  #   end
         | 
| 107 | 
            +
                  def alias_command(new_command_name, orig_command_name, desc=nil)
         | 
| 108 | 
            +
                    commands[new_command_name] = commands[orig_command_name].dup
         | 
| 109 | 
            +
                    commands[new_command_name][:description] = desc if desc
         | 
| 110 | 
            +
                  end
         | 
| 111 | 
            +
             | 
| 112 | 
            +
                  # Set the description for a command (replacing the old
         | 
| 113 | 
            +
                  # description.)
         | 
| 114 | 
            +
                  # @param [String] name The command name.
         | 
| 115 | 
            +
                  # @param [String] description The command description.
         | 
| 116 | 
            +
                  # @example
         | 
| 117 | 
            +
                  #   class MyCommands < Pry::CommandBase
         | 
| 118 | 
            +
                  #     desc "help", "help description"
         | 
| 119 | 
            +
                  #   end
         | 
| 120 | 
            +
                  def desc(name, description)
         | 
| 121 | 
            +
                    commands[name][:description] = description
         | 
| 122 | 
            +
                  end
         | 
| 123 | 
            +
                end
         | 
| 124 | 
            +
                
         | 
| 125 | 
            +
                command "help", "This menu." do |cmd|
         | 
| 126 | 
            +
                  command_info = opts[:commands]
         | 
| 127 | 
            +
                  param = cmd
         | 
| 128 | 
            +
             | 
| 129 | 
            +
                  if !param
         | 
| 130 | 
            +
                    output.puts "Command list:"
         | 
| 131 | 
            +
                    output.puts "--"
         | 
| 132 | 
            +
                    command_info.each do |k, data|
         | 
| 133 | 
            +
                      output.puts "#{k}".ljust(18) + data[:description] if !data[:description].empty?
         | 
| 134 | 
            +
                    end
         | 
| 135 | 
            +
                  else
         | 
| 136 | 
            +
                    if command_info[param]
         | 
| 137 | 
            +
                      output.puts command_info[param][:description]
         | 
| 138 | 
            +
                    else
         | 
| 139 | 
            +
                      output.puts "No info for command: #{param}"
         | 
| 140 | 
            +
                    end
         | 
| 141 | 
            +
                  end
         | 
| 142 | 
            +
                end
         | 
| 143 | 
            +
             | 
| 144 | 
            +
                # Ensures that commands can be inherited
         | 
| 145 | 
            +
                def self.inherited(klass)
         | 
| 146 | 
            +
                  klass.commands = commands.dup
         | 
| 147 | 
            +
                end
         | 
| 148 | 
            +
                
         | 
| 149 | 
            +
              end
         | 
| 150 | 
            +
            end
         |