summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoraycabta <aycabta@gmail.com>2019-05-25 02:13:14 +0900
committeraycabta <aycabta@gmail.com>2019-05-25 02:13:14 +0900
commitff43b2262702e828e2008ba65e68b331d263e3d0 (patch)
treec0e03d86c6abdae4c99f4d77eaba85864ea74608
parent637ee7ee3853387b4f34aa350471692f1778693d (diff)
Enter key always means evaluate in Reline#readmultiline
-rw-r--r--lib/reline/line_editor.rb19
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