From e3587ed8498dcf7a3a8178030f7ae66cd0719c57 Mon Sep 17 00:00:00 2001 From: aycabta Date: Wed, 4 Dec 2019 22:32:12 +0900 Subject: Support disable-completion --- lib/reline/line_editor.rb | 30 +++++++++++++++++------------- 1 file changed, 17 insertions(+), 13 deletions(-) (limited to 'lib') diff --git a/lib/reline/line_editor.rb b/lib/reline/line_editor.rb index 072238f8a8..f029aa4e6e 100644 --- a/lib/reline/line_editor.rb +++ b/lib/reline/line_editor.rb @@ -776,20 +776,24 @@ class Reline::LineEditor @first_char = false completion_occurs = false if @config.editing_mode_is?(:emacs, :vi_insert) and key.char == "\C-i".ord - result = retrieve_completion_block - slice = result[1] - result = @completion_proc.(slice) if @completion_proc and slice - if result.is_a?(Array) - completion_occurs = true - complete(result) + unless @config.disable_completion + result = retrieve_completion_block + slice = result[1] + result = @completion_proc.(slice) if @completion_proc and slice + if result.is_a?(Array) + completion_occurs = true + complete(result) + end end - elsif @config.editing_mode_is?(:vi_insert) and ["\C-p".ord, "\C-n".ord].include?(key.char) - result = retrieve_completion_block - slice = result[1] - result = @completion_proc.(slice) if @completion_proc and slice - if result.is_a?(Array) - completion_occurs = true - move_completed_list(result, "\C-p".ord == key.char ? :up : :down) + elsif not @config.disable_completion and @config.editing_mode_is?(:vi_insert) and ["\C-p".ord, "\C-n".ord].include?(key.char) + unless @config.disable_completion + result = retrieve_completion_block + slice = result[1] + result = @completion_proc.(slice) if @completion_proc and slice + if result.is_a?(Array) + completion_occurs = true + move_completed_list(result, "\C-p".ord == key.char ? :up : :down) + end end elsif Symbol === key.char and respond_to?(key.char, true) process_key(key.char, key.char) -- cgit v1.2.3