class IRB::ReadlineInputMethod
Public Class Methods
initialize_readline
()
# File lib/irb/input-method.rb, line 175 def initialize_readline require "readline" rescue LoadError else include ::Readline end
new
()
Creates a new input method object using Readline
Calls superclass method
IRB::StdioInputMethod::new
# File lib/irb/input-method.rb, line 186 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
Public Instance Methods
completion_info
()
# File lib/irb/input-method.rb, line 207 def completion_info 'RegexpCompletor' end
eof?
()
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.
# File lib/irb/input-method.rb, line 230 def eof? @eof end
gets
()
Reads the next line from this input method.
See IO#gets
for more information.
# File lib/irb/input-method.rb, line 214 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
inspect
()
For debug message
# File lib/irb/input-method.rb, line 239 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
prompting?
()
# File lib/irb/input-method.rb, line 234 def prompting? true end