1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00

Add Reline.test_mode to use with special I/O

This commit is contained in:
aycabta 2019-05-18 03:12:53 +09:00
parent b165bedcbd
commit 16917cc3cb
3 changed files with 32 additions and 11 deletions

View file

@ -180,12 +180,19 @@ module Reline
@@line_editor&.delete_text(start, length) @@line_editor&.delete_text(start, length)
end end
private_class_method def self.test_mode
remove_const('IOGate') if const_defined?('IOGate')
const_set('IOGate', Reline::GeneralIO)
end
def self.input=(val) def self.input=(val)
raise TypeError unless val.respond_to?(:getc) or val.nil? raise TypeError unless val.respond_to?(:getc) or val.nil?
if val.respond_to?(:getc) if val.respond_to?(:getc)
Reline::GeneralIO.input = val if defined?(Reline::ANSI) and IOGate == Reline::ANSI
remove_const('IOGate') if const_defined?('IOGate') Reline::ANSI.input = val
const_set('IOGate', Reline::GeneralIO) elsif IOGate == Reline::GeneralIO
Reline::GeneralIO.input = val
end
end end
end end
@ -193,6 +200,9 @@ module Reline
def self.output=(val) def self.output=(val)
raise TypeError unless val.respond_to?(:write) or val.nil? raise TypeError unless val.respond_to?(:write) or val.nil?
@@output = val @@output = val
if defined?(Reline::ANSI) and IOGate == Reline::ANSI
Reline::ANSI.output = val
end
end end
def self.vi_editing_mode def self.vi_editing_mode

View file

@ -1,23 +1,33 @@
class Reline::ANSI class Reline::ANSI
@@input = STDIN
def self.input=(val)
@@input = val
end
@@output = STDOUT
def self.output=(val)
@@output = val
end
def self.getc def self.getc
c = nil c = nil
loop do loop do
result = select([STDIN], [], [], 0.1) result = select([@@input], [], [], 0.1)
next if result.nil? next if result.nil?
c = STDIN.read(1) c = @@input.read(1)
break break
end end
c&.ord c&.ord
end end
def self.get_screen_size def self.get_screen_size
STDIN.winsize @@input.winsize
rescue Errno::ENOTTY rescue Errno::ENOTTY
[24, 80] [24, 80]
end end
def self.set_screen_size(rows, columns) def self.set_screen_size(rows, columns)
STDIN.winsize = [rows, columns] @@input.winsize = [rows, columns]
self self
rescue Errno::ENOTTY rescue Errno::ENOTTY
self self
@ -26,9 +36,9 @@ class Reline::ANSI
def self.cursor_pos def self.cursor_pos
begin begin
res = '' res = ''
STDIN.raw do |stdin| @@input.raw do |stdin|
STDOUT << "\e[6n" @@output << "\e[6n"
STDOUT.flush @@output.flush
while (c = stdin.getc) != 'R' while (c = stdin.getc) != 'R'
res << c if c res << c if c
end end
@ -37,7 +47,7 @@ class Reline::ANSI
column = m[:column].to_i - 1 column = m[:column].to_i - 1
row = m[:row].to_i - 1 row = m[:row].to_i - 1
rescue Errno::ENOTTY rescue Errno::ENOTTY
buf = STDOUT.pread(STDOUT.pos, 0) buf = @@output.pread(@@output.pos, 0)
row = buf.count("\n") row = buf.count("\n")
column = buf.rindex("\n") ? (buf.size - buf.rindex("\n")) - 1 : 0 column = buf.rindex("\n") ? (buf.size - buf.rindex("\n")) - 1 : 0
end end

View file

@ -11,6 +11,7 @@ def use_ext_readline # Use ext/readline as Readline
end end
def use_lib_reline # Use lib/reline as Readline def use_lib_reline # Use lib/reline as Readline
Reline.send(:test_mode)
Object.send(:remove_const, :Readline) if Object.const_defined?(:Readline) Object.send(:remove_const, :Readline) if Object.const_defined?(:Readline)
Object.const_set(:Readline, Reline) Object.const_set(:Readline, Reline)
end end