Class: IRB::RelineInputMethod
Relationships & Source Files | |
Extension / Inclusion / Inheritance Descendants | |
Subclasses:
|
|
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
self,
InputMethod
|
|
Instance Chain:
self,
Reline,
InputMethod
|
|
Inherits: |
IRB::InputMethod
|
Defined in: | lib/irb/input-method.rb |
Constant Summary
-
SHOW_DOC_DIALOG =
# File 'lib/irb/input-method.rb', line 321->() { dialog.trap_key = nil alt_d = [ [Reline::Key.new(nil, 0xE4, true)], # Normal Alt+d. [27, 100], # Normal Alt+d when convert-meta isn't used. [195, 164], # The "ä" that appears when Alt+d is pressed on xterm. [226, 136, 130] # The "∂" that appears when Alt+d in pressed on iTerm2. ] if just_cursor_moving and completion_journey_data.nil? return nil end cursor_pos_to_render, result, pointer, autocomplete_dialog = context.pop(4) return nil if result.nil? or pointer.nil? or pointer < 0 name = result[pointer] name = IRB::InputCompletor.retrieve_completion_data(name, doc_namespace: true) = {} [:extra_doc_dirs] = IRB.conf[:EXTRA_DOC_DIRS] unless IRB.conf[:EXTRA_DOC_DIRS].empty? driver = RDoc::RI::Driver.new( ) if key.match?(dialog.name) begin driver.display_names([name]) rescue RDoc::RI::Driver::NotFoundError end end begin name = driver. (name) rescue RDoc::RI::Driver::NotFoundError return nil rescue return nil # unknown error end doc = nil used_for_class = false if not name =~ /#|\./ found, klasses, includes, extends = driver.classes_and_includes_and_extends_for(name) if not found.empty? doc = driver.class_document(name, found, klasses, includes, extends) used_for_class = true end end unless used_for_class doc = RDoc::Markup::Document.new begin driver.add_method(doc, name) rescue RDoc::RI::Driver::NotFoundError doc = nil rescue return nil # unknown error end end return nil if doc.nil? width = 40 right_x = cursor_pos_to_render.x + autocomplete_dialog.width if right_x + width > screen_width right_width = screen_width - (right_x + 1) left_x = autocomplete_dialog.column - width left_x = 0 if left_x < 0 left_width = width > autocomplete_dialog.column ? autocomplete_dialog.column : width if right_width.positive? and left_width.positive? if right_width >= left_width width = right_width x = right_x else width = left_width x = left_x end elsif right_width.positive? and left_width <= 0 width = right_width x = right_x elsif right_width <= 0 and left_width.positive? width = left_width x = left_x else # Both are negative width. return nil end else x = right_x end formatter = RDoc::Markup::ToAnsi.new formatter.width = width dialog.trap_key = alt_d = 'Press Alt+d to read the full document' contents = [ ] + doc.accept(formatter).split("\n") y = cursor_pos_to_render.y DialogRenderInfo.new(pos: Reline::CursorPos.new(x, y), contents: contents, width: width, bg_color: '49') }
Class Method Summary
-
.new ⇒ RelineInputMethod
constructor
Creates a new input method object using Reline.
InputMethod
- Inherited
.new | Creates a new input method object. |
Instance Attribute Summary
-
#eof? ⇒ Boolean
readonly
Whether the end of this input method has been reached, returns
true
if there is no more data to read. -
#readable_after_eof? ⇒ Boolean
readonly
Whether this input method is still readable when there is no more data to read.
InputMethod
- Inherited
#file_name | The file name of this input method, usually given during initialization. |
#prompt | The irb prompt associated with this input method. |
#readable_after_eof? | Whether this input method is still readable when there is no more data to read. |
Instance Method Summary
- #auto_indent(&block)
- #check_termination(&block)
- #dynamic_prompt(&block)
-
#encoding
The external encoding for standard input.
-
#gets
Reads the next line from this input method.
-
#inspect
For debug message.
-
#line(line_no)
Returns the current line number for
#io
.
InputMethod
- Inherited
Constructor Details
.new ⇒ RelineInputMethod
Creates a new input method object using Reline
# File 'lib/irb/input-method.rb', line 268
def initialize IRB.__send__(:set_encoding, Reline.encoding_system_needs.name, override: false) super @line_no = 0 @line = [] @eof = false @stdin = ::IO.open(STDIN.to_i, :external_encoding => IRB.conf[:LC_MESSAGES].encoding, :internal_encoding => "-") @stdout = ::IO.open(STDOUT.to_i, 'w', :external_encoding => IRB.conf[:LC_MESSAGES].encoding, :internal_encoding => "-") if Reline.respond_to?("basic_word_break_characters=") Reline.basic_word_break_characters = IRB::InputCompletor::BASIC_WORD_BREAK_CHARACTERS end Reline.completion_append_character = nil Reline.completer_quote_characters = '' Reline.completion_proc = IRB::InputCompletor::CompletionProc Reline.output_modifier_proc = if IRB.conf[:USE_COLORIZE] proc do |output, complete: | next unless IRB::Color.colorable? lvars = IRB.CurrentContext&.local_variables || [] IRB::Color.colorize_code(output, complete: complete, local_variables: lvars) end else proc do |output| Reline::Unicode.escape_for_print(output) end end Reline.dig_perfect_match_proc = IRB::InputCompletor::PerfectMatchedProc Reline.autocompletion = IRB.conf[:USE_AUTOCOMPLETE] if IRB.conf[:USE_AUTOCOMPLETE] begin require 'rdoc' Reline.add_dialog_proc(:show_doc, SHOW_DOC_DIALOG, Reline::DEFAULT_DIALOG_CONTEXT) rescue LoadError end end end
Instance Attribute Details
#eof? ⇒ Boolean
(readonly)
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 435
def eof? @eof end
#readable_after_eof? ⇒ Boolean
(readonly)
Whether this input method is still readable when there is no more data to read.
See IO#eof
for more information.
# File 'lib/irb/input-method.rb', line 443
def readable_after_eof? true end
Instance Method Details
#auto_indent(&block)
[ GitHub ]# File 'lib/irb/input-method.rb', line 317
def auto_indent(&block) @auto_indent_proc = block end
#check_termination(&block)
[ GitHub ]# File 'lib/irb/input-method.rb', line 309
def check_termination(&block) @check_termination_proc = block end
#dynamic_prompt(&block)
[ GitHub ]# File 'lib/irb/input-method.rb', line 313
def dynamic_prompt(&block) @prompt_proc = block end
#encoding
The external encoding for standard input.
# File 'lib/irb/input-method.rb', line 457
def encoding @stdin.external_encoding end
#gets
Reads the next line from this input method.
See IO#gets
for more information.
# File 'lib/irb/input-method.rb', line 417
def gets Reline.input = @stdin Reline.output = @stdout Reline.prompt_proc = @prompt_proc Reline.auto_indent_proc = @auto_indent_proc if @auto_indent_proc if l = readmultiline(@prompt, false, &@check_termination_proc) 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 462
def inspect config = Reline::Config.new str = "RelineInputMethod with Reline #{Reline::VERSION}" if config.respond_to?(:inputrc_path) inputrc_path = File. (config.inputrc_path) else inputrc_path = File. (ENV['INPUTRC'] || '~/.inputrc') end str += " and #{inputrc_path}" if File.exist?(inputrc_path) str end
#line(line_no)
Returns the current line number for #io
.
#line
counts the number of times #gets is called.
See IO#lineno
for more information.
# File 'lib/irb/input-method.rb', line 452
def line(line_no) @line[line_no] end