ruby-changes:56376
From: Nobuyoshi <ko1@a...>
Date: Sat, 6 Jul 2019 12:35:06 +0900 (JST)
Subject: [ruby-changes:56376] Nobuyoshi Nakada: 688cef2169 (master): Refactored width calculations
https://git.ruby-lang.org/ruby.git/commit/?id=688cef2169 From 688cef2169a438c1402a8870887a6406f29a824b Mon Sep 17 00:00:00 2001 From: Nobuyoshi Nakada <nobu@r...> Date: Sat, 6 Jul 2019 12:31:11 +0900 Subject: Refactored width calculations diff --git a/lib/reline/line_editor.rb b/lib/reline/line_editor.rb index 6bcfb4b..f4b72cd 100644 --- a/lib/reline/line_editor.rb +++ b/lib/reline/line_editor.rb @@ -53,6 +53,7 @@ class Reline::LineEditor https://github.com/ruby/ruby/blob/trunk/lib/reline/line_editor.rb#L53 OSC_REGEXP = /\e\]\d+(?:;[^;]+)*\a/ NON_PRINTING_START = "\1" NON_PRINTING_END = "\2" + WIDTH_SCANNER = /\G(?:#{NON_PRINTING_START}|#{NON_PRINTING_END}|#{CSI_REGEXP}|#{OSC_REGEXP}|\X)/ def initialize(config) @config = config @@ -145,35 +146,23 @@ class Reline::LineEditor https://github.com/ruby/ruby/blob/trunk/lib/reline/line_editor.rb#L146 width = 0 rest = "#{prompt}#{str}".encode(Encoding::UTF_8) in_zero_width = false - loop do - break if rest.empty? - if rest.start_with?(NON_PRINTING_START) - rest.delete_prefix!(NON_PRINTING_START) + rest.scan(WIDTH_SCANNER) do |gc| + case gc + when NON_PRINTING_START in_zero_width = true - elsif rest.start_with?(NON_PRINTING_END) - rest.delete_prefix!(NON_PRINTING_END) + when NON_PRINTING_END in_zero_width = false - elsif rest.start_with?(CSI_REGEXP) - lines.last << $& - rest = $' - elsif rest.start_with?(OSC_REGEXP) - lines.last << $& - rest = $' + when CSI_REGEXP, OSC_REGEXP + lines.last << gc else - gcs = rest.grapheme_clusters - gc = gcs.first - rest = gcs[1..-1].join - if in_zero_width - mbchar_width = 0 - else + unless in_zero_width mbchar_width = Reline::Unicode.get_mbchar_width(gc) - end - width += mbchar_width - if width > max_width - width = mbchar_width - lines << nil - lines << String.new(encoding: @encoding) - height += 1 + if (width += mbchar_width) > max_width + width = mbchar_width + lines << nil + lines << String.new(encoding: @encoding) + height += 1 + end end lines.last << gc end @@ -955,28 +944,17 @@ class Reline::LineEditor https://github.com/ruby/ruby/blob/trunk/lib/reline/line_editor.rb#L944 width = 0 rest = str.encode(Encoding::UTF_8) in_zero_width = false - loop do - break if rest.empty? - if rest.start_with?(NON_PRINTING_START) - rest.delete_prefix!(NON_PRINTING_START) + rest.scan(WIDTH_SCANNER) do |gc| + case gc + when NON_PRINTING_START in_zero_width = true - elsif rest.start_with?(NON_PRINTING_END) - rest.delete_prefix!(NON_PRINTING_END) + when NON_PRINTING_END in_zero_width = false - elsif rest.start_with?(CSI_REGEXP) - rest = $' - elsif rest.start_with?(OSC_REGEXP) - rest = $' + when CSI_REGEXP, OSC_REGEXP else - gcs = rest.grapheme_clusters - gc = gcs.first - rest = gcs[1..-1].join - if in_zero_width - mbchar_width = 0 - else - mbchar_width = Reline::Unicode.get_mbchar_width(gc) + unless in_zero_width + width += Reline::Unicode.get_mbchar_width(gc) end - width += mbchar_width end end width -- cgit v0.10.2 -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/