diff options
author | aycabta <aycabta@gmail.com> | 2020-07-20 20:52:07 +0900 |
---|---|---|
committer | aycabta <aycabta@gmail.com> | 2020-08-18 19:08:40 +0900 |
commit | 80a7358cfcafa9748c232be851e5f70bede32acb (patch) | |
tree | 86908b6827c8d925c20874791d2f57a4fa3bbee7 /lib/reline | |
parent | 44b24ab4c1bd1833aab37cba83801b2023b8e0a9 (diff) |
[ruby/reline] Keep original characters in inputrc
https://github.com/ruby/reline/commit/96583c6336
Diffstat (limited to 'lib/reline')
-rw-r--r-- | lib/reline/config.rb | 16 |
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) |