diff options
author | aycabta <aycabta@gmail.com> | 2019-05-27 10:09:21 +0900 |
---|---|---|
committer | aycabta <aycabta@gmail.com> | 2019-05-27 10:09:21 +0900 |
commit | 1d301acbe8e9b0df7872d6719d6646ade25630d6 (patch) | |
tree | 35c730726b0bd7cd68b8037609a5a56d44138171 /lib | |
parent | 9c136f3dea0c6052fefb377bf2c445daec1ca0b6 (diff) |
Fix rendering bug of ^D
Diffstat (limited to 'lib')
-rw-r--r-- | lib/reline.rb | 4 | ||||
-rw-r--r-- | lib/reline/line_editor.rb | 44 |
2 files changed, 35 insertions, 13 deletions
diff --git a/lib/reline.rb b/lib/reline.rb index aef750813e..0b6eddf498 100644 --- a/lib/reline.rb +++ b/lib/reline.rb @@ -254,6 +254,10 @@ module Reline [preposing, block, postposing] end + def eof? + @@line_editor.eof? + end + def readmultiline(prompt = '', add_hist = false, &confirm_multiline_termination) unless confirm_multiline_termination raise ArgumentError.new('#readmultiline needs block to confirm multiline termination') diff --git a/lib/reline/line_editor.rb b/lib/reline/line_editor.rb index e257ab335e..a1cb3d0fd7 100644 --- a/lib/reline/line_editor.rb +++ b/lib/reline/line_editor.rb @@ -104,6 +104,10 @@ class Reline::LineEditor Signal.trap('SIGINT', @old_trap) end + def eof? + @eof + end + def reset_variables(prompt = '', encoding = Encoding.default_external) @prompt = prompt @encoding = encoding @@ -125,6 +129,7 @@ class Reline::LineEditor @first_prompt = true @searching_prompt = nil @first_char = true + @eof = false reset_line end @@ -389,17 +394,21 @@ class Reline::LineEditor @rerender_all = false end line = modify_lines(whole_lines)[@line_index] - if !@is_multiline - render_partial(prompt, prompt_width, line) - scroll_down(1) - Reline::IOGate.move_cursor_column(0) - Reline::IOGate.erase_after_cursor - elsif !finished? - render_partial(prompt, prompt_width, line) + if @is_multiline + if finished? + scroll_down(1) + Reline::IOGate.move_cursor_column(0) + Reline::IOGate.erase_after_cursor + else + render_partial(prompt, prompt_width, line) + end else - scroll_down(1) unless whole_lines.last.empty? - Reline::IOGate.move_cursor_column(0) - Reline::IOGate.erase_after_cursor + render_partial(prompt, prompt_width, line) + if finished? + scroll_down(1) + Reline::IOGate.move_cursor_column(0) + Reline::IOGate.erase_after_cursor + end end end @@ -1194,8 +1203,11 @@ class Reline::LineEditor private def em_delete_or_list(key) if @line.empty? @line = nil - scroll_down(@highest_in_all - @first_line_started_from) + if @buffer_of_lines.size > 1 + scroll_down(@highest_in_all - @first_line_started_from) + end Reline::IOGate.move_cursor_column(0) + @eof = true finish elsif @byte_pointer < @line.bytesize splitted_last = @line.byteslice(@byte_pointer, @line.bytesize) @@ -1488,8 +1500,11 @@ class Reline::LineEditor private def vi_end_of_transmission(key) if @line.empty? @line = nil - scroll_down(@highest_in_all - @first_line_started_from) + if @buffer_of_lines.size > 1 + scroll_down(@highest_in_all - @first_line_started_from) + end Reline::IOGate.move_cursor_column(0) + @eof = true finish end end @@ -1497,8 +1512,11 @@ class Reline::LineEditor private def vi_list_or_eof(key) if @line.empty? @line = nil - scroll_down(@highest_in_all - @first_line_started_from) + if @buffer_of_lines.size > 1 + scroll_down(@highest_in_all - @first_line_started_from) + end Reline::IOGate.move_cursor_column(0) + @eof = true finish else # TODO: list |