summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authoraycabta <aycabta@gmail.com>2020-07-20 20:52:07 +0900
committeraycabta <aycabta@gmail.com>2020-08-18 19:08:40 +0900
commit80a7358cfcafa9748c232be851e5f70bede32acb (patch)
tree86908b6827c8d925c20874791d2f57a4fa3bbee7 /lib
parent44b24ab4c1bd1833aab37cba83801b2023b8e0a9 (diff)
[ruby/reline] Keep original characters in inputrc
https://github.com/ruby/reline/commit/96583c6336
Diffstat (limited to 'lib')
-rw-r--r--lib/reline/config.rb16
1 files changed, 12 insertions, 4 deletions
diff --git a/lib/reline/config.rb b/lib/reline/config.rb
index 9b8ddc0536..1cd607902a 100644
--- a/lib/reline/config.rb
+++ b/lib/reline/config.rb
@@ -167,7 +167,7 @@ class Reline::Config
case line
when /^set +([^ ]+) +([^ ]+)/i
- var, value = $1.downcase, $2.downcase
+ var, value = $1.downcase, $2
bind_variable(var, value)
next
when /\s*("#{KEYSEQ_PATTERN}+")\s*:\s*(.*)\s*$/o
@@ -270,17 +270,25 @@ class Reline::Config
@show_mode_in_prompt = false
end
when 'vi-cmd-mode-string'
- @vi_cmd_mode_icon = value
+ @vi_cmd_mode_icon = retrieve_string(value)
when 'vi-ins-mode-string'
- @vi_ins_mode_icon = value
+ @vi_ins_mode_icon = retrieve_string(value)
when 'emacs-mode-string'
- @emacs_mode_string = value
+ @emacs_mode_string = retrieve_string(value)
when *VARIABLE_NAMES then
variable_name = :"@#{name.tr(?-, ?_)}"
instance_variable_set(variable_name, value.nil? || value == '1' || value == 'on')
end
end
+ def retrieve_string(str)
+ if str =~ /\A"(.*)"\z/
+ parse_keyseq($1).map(&:chr).join
+ else
+ parse_keyseq(str).map(&:chr).join
+ end
+ end
+
def bind_key(key, func_name)
if key =~ /\A"(.*)"\z/
keyseq = parse_keyseq($1)