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:
parent
b165bedcbd
commit
16917cc3cb
3 changed files with 32 additions and 11 deletions
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Add table
Reference in a new issue