class IRB::ReadlineInputMethod
Public Class Methods
Source
# File lib/irb/input-method.rb, line 177 def initialize_readline require "readline" rescue LoadError else include ::Readline end
Source
# File lib/irb/input-method.rb, line 188 def initialize self.class.initialize_readline if Readline.respond_to?(:encoding_system_needs) IRB.__send__(:set_encoding, Readline.encoding_system_needs.name, override: false) end super @eof = false @completor = RegexpCompletor.new if Readline.respond_to?("basic_word_break_characters=") Readline.basic_word_break_characters = BASIC_WORD_BREAK_CHARACTERS end Readline.completion_append_character = nil Readline.completion_proc = ->(target) { bind = IRB.conf[:MAIN_CONTEXT].workspace.binding @completor.completion_candidates('', target, '', bind: bind) } end
Creates a new input method object using Readline
Calls superclass method
IRB::StdioInputMethod::new
Public Instance Methods
Source
# File lib/irb/input-method.rb, line 209 def completion_info 'RegexpCompletor' end
Source
# File lib/irb/input-method.rb, line 232 def eof? @eof end
Whether the end of this input method has been reached, returns true
if there is no more data to read.
See IO#eof? for more information.
Source
# File lib/irb/input-method.rb, line 216 def gets Readline.input = @stdin Readline.output = @stdout if l = readline(@prompt, false) HISTORY.push(l) if !l.empty? @line[@line_no += 1] = l + "\n" else @eof = true l end end
Reads the next line from this input method.
See IO#gets for more information.
Source
# File lib/irb/input-method.rb, line 241 def inspect readline_impl = (defined?(Reline) && Readline == Reline) ? 'Reline' : 'ext/readline' str = "ReadlineInputMethod with #{readline_impl} #{Readline::VERSION}" inputrc_path = File.expand_path(ENV['INPUTRC'] || '~/.inputrc') str += " and #{inputrc_path}" if File.exist?(inputrc_path) str end
For debug message