diff options
author | aycabta <aycabta@gmail.com> | 2019-05-25 02:13:14 +0900 |
---|---|---|
committer | aycabta <aycabta@gmail.com> | 2019-05-25 02:13:14 +0900 |
commit | ff43b2262702e828e2008ba65e68b331d263e3d0 (patch) | |
tree | c0e03d86c6abdae4c99f4d77eaba85864ea74608 /lib | |
parent | 637ee7ee3853387b4f34aa350471692f1778693d (diff) | |
download | ruby-ff43b2262702e828e2008ba65e68b331d263e3d0.tar.gz |
Enter key always means evaluate in Reline#readmultiline
Diffstat (limited to 'lib')
-rw-r--r-- | lib/reline/line_editor.rb | 19 |
1 files changed, 12 insertions, 7 deletions
diff --git a/lib/reline/line_editor.rb b/lib/reline/line_editor.rb index ea671d1b49..055b76a7b4 100644 --- a/lib/reline/line_editor.rb +++ b/lib/reline/line_editor.rb @@ -1096,16 +1096,21 @@ class Reline::LineEditor if @line_index < (@buffer_of_lines.size - 1) ed_next_history(key) # means cursor down else - finish if confirm_multiline_termination + # should check confirm_multiline_termination to finish? + finish end else - if @line_index == (@buffer_of_lines.size - 1) and confirm_multiline_termination - finish + if @line_index == (@buffer_of_lines.size - 1) + if confirm_multiline_termination + finish + else + key_newline(key) + end else - next_line = @line.byteslice(@byte_pointer, @line.bytesize - @byte_pointer) - cursor_line = @line.byteslice(0, @byte_pointer) - insert_new_line(cursor_line, next_line) - @cursor = 0 + # should check confirm_multiline_termination to finish? + @previous_line_index = @line_index + @line_index = @buffer_of_lines.size - 1 + finish end end else |