123456789_123456789_123456789_123456789_123456789_

Module: IRB::IrbLoader

Relationships & Source Files
Extension / Inclusion / Inheritance Descendants
Included In:
Defined in: lib/irb/ext/loader.rb

Overview

Provides a few commands for loading files within an irb session.

See ExtendCommandBundle for more information.

Constant Summary

Instance Method Summary

Instance Method Details

#absolute_path?(path)

See additional method definition at line 35.

[ GitHub ]

  
# File 'lib/irb/ext/loader.rb', line 52

def absolute_path?(path)
  File.absolute_path?(path)
end

#irb_load(fn, priv = nil)

Loads the given file similarly to Kernel.load

Raises:

  • (LoadError)
[ GitHub ]

  
# File 'lib/irb/ext/loader.rb', line 27

def irb_load(fn, priv = nil)
  path = search_file_from_ruby_path(fn)
  raise LoadError, "No such file to load -- #{fn}" unless path

  load_file(path, priv)
end

#load_file(path, priv = nil)

Loads the given file in the current session’s context and evaluates it.

See Irb#suspend_input_method for more information.

[ GitHub ]

  
# File 'lib/irb/ext/loader.rb', line 98

def load_file(path, priv = nil)
  irb.suspend_name(path, File.basename(path)) do

    if priv
      ws = WorkSpace.new(Module.new)
    else
      ws = WorkSpace.new
    end
    irb.suspend_workspace(ws) do
      FileInputMethod.open(path) do |io|
        irb.suspend_input_method(io) do
          |back_io|
          irb.signal_status(:IN_LOAD) do
            if back_io.kind_of?(FileInputMethod)
              irb.eval_input
            else
              begin
                irb.eval_input
              rescue LoadAbort
                print "load abort!!\n"
              end
            end
          end
        end
      end
    end
  end
end

#old

This method is for internal use only.
[ GitHub ]

  
# File 'lib/irb/ext/loader.rb', line 127

def old # :nodoc:
  back_io = @io
  back_path = @irb_path
  back_name = @irb_name
  back_scanner = @irb.scanner
  begin
    @io = FileInputMethod.new(path)
    @irb_name = File.basename(path)
    @irb_path = path
    @irb.signal_status(:IN_LOAD) do
      if back_io.kind_of?(FileInputMethod)
        @irb.eval_input
      else
        begin
          @irb.eval_input
        rescue LoadAbort
          print "load abort!!\n"
        end
      end
    end
  ensure
    @io = back_io
    @irb_name = back_name
    @irb_path = back_path
    @irb.scanner = back_scanner
  end
end

#ruby_load

[ GitHub ]

  
# File 'lib/irb/ext/loader.rb', line 23

alias ruby_load load

#ruby_require

[ GitHub ]

  
# File 'lib/irb/ext/loader.rb', line 24

alias ruby_require require

#search_file_from_ruby_path(fn)

This method is for internal use only.
[ GitHub ]

  
# File 'lib/irb/ext/loader.rb', line 57

def search_file_from_ruby_path(fn) # :nodoc:
  if absolute_path?(fn)
    return fn if File.exist?(fn)
    return nil
  end

  for path in $:
    if File.exist?(f = File.join(path, fn))
      return f
    end
  end
  return nil
end

#source_file(path)

Loads a given file in the current session and displays the source lines

See Irb#suspend_input_method for more information.

[ GitHub ]

  
# File 'lib/irb/ext/loader.rb', line 74

def source_file(path)
  irb.suspend_name(path, File.basename(path)) do
    FileInputMethod.open(path) do |io|
      irb.suspend_input_method(io) do
        |back_io|
        irb.signal_status(:IN_LOAD) do
          if back_io.kind_of?(FileInputMethod)
            irb.eval_input
          else
            begin
              irb.eval_input
            rescue LoadAbort
              print "load abort!!\n"
            end
          end
        end
      end
    end
  end
end