summaryrefslogtreecommitdiff
path: root/lib/reline
diff options
context:
space:
mode:
authoraycabta <aycabta@gmail.com>2019-12-10 07:01:26 +0900
committeraycabta <aycabta@gmail.com>2019-12-10 07:07:43 +0900
commit6a22b2a091eda81a473eb1b0cc69fe0792560e27 (patch)
treeaf969234b7f36b066a916b083cb74fef8008b070 /lib/reline
parent562fd754b55aaaf794fa8eb5461eb0ee87725464 (diff)
Support completion with case-insensitive fashion
Reline performs completion in a case-insensitive fashon if Readline.completion_case_fold or completion-ignore-case of .inputrc are set "on".
Diffstat (limited to 'lib/reline')
-rw-r--r--lib/reline/line_editor.rb20
1 files changed, 16 insertions, 4 deletions
diff --git a/lib/reline/line_editor.rb b/lib/reline/line_editor.rb
index e352f8881c..2986bdd154 100644
--- a/lib/reline/line_editor.rb
+++ b/lib/reline/line_editor.rb
@@ -552,7 +552,11 @@ class Reline::LineEditor
if i and not Encoding.compatible?(target.encoding, i.encoding)
raise Encoding::CompatibilityError
end
- i&.start_with?(target)
+ if @config.completion_ignore_case
+ i&.downcase.start_with?(target.downcase)
+ else
+ i&.start_with?(target)
+ end
}
if is_menu
menu(target, list)
@@ -569,10 +573,18 @@ class Reline::LineEditor
size = [memo_mbchars.size, item_mbchars.size].min
result = ''
size.times do |i|
- if memo_mbchars[i] == item_mbchars[i]
- result << memo_mbchars[i]
+ if @config.completion_ignore_case
+ if memo_mbchars[i].casecmp?(item_mbchars[i])
+ result << memo_mbchars[i]
+ else
+ break
+ end
else
- break
+ if memo_mbchars[i] == item_mbchars[i]
+ result << memo_mbchars[i]
+ else
+ break
+ end
end
end
result