ruby-changes:59210
From: aycabta <ko1@a...>
Date: Thu, 12 Dec 2019 08:41:14 +0900 (JST)
Subject: [ruby-changes:59210] 7d991a0571 (master): Suppress to crash IRB if completed list has nil
https://git.ruby-lang.org/ruby.git/commit/?id=7d991a0571 From 7d991a0571ab33f44c00fdc227f076d1eaf5fb2b Mon Sep 17 00:00:00 2001 From: aycabta <aycabta@g...> Date: Thu, 12 Dec 2019 08:40:44 +0900 Subject: Suppress to crash IRB if completed list has nil diff --git a/lib/reline/line_editor.rb b/lib/reline/line_editor.rb index 928b043..5d23c82 100644 --- a/lib/reline/line_editor.rb +++ b/lib/reline/line_editor.rb @@ -553,7 +553,7 @@ class Reline::LineEditor https://github.com/ruby/ruby/blob/trunk/lib/reline/line_editor.rb#L553 raise Encoding::CompatibilityError, "#{target.encoding.name} is not comaptible with #{i.encoding.name}" end if @config.completion_ignore_case - i&.downcase.start_with?(target.downcase) + i&.downcase&.start_with?(target.downcase) else i&.start_with?(target) end diff --git a/test/reline/test_key_actor_emacs.rb b/test/reline/test_key_actor_emacs.rb index cd5b926..4e3184b 100644 --- a/test/reline/test_key_actor_emacs.rb +++ b/test/reline/test_key_actor_emacs.rb @@ -1363,6 +1363,51 @@ class Reline::KeyActor::Emacs::Test < Reline::TestCase https://github.com/ruby/ruby/blob/trunk/test/reline/test_key_actor_emacs.rb#L1363 assert_line('abcde foo_o_ ABCDE') end + def test_completion_with_nil_value + @line_editor.completion_proc = proc { |word| + %w{ + foo_foo + foo_bar + Foo_baz + qux + }.map { |i| + i.encode(@encoding) + }.prepend(nil) + } + @config.completion_ignore_case = true + input_keys('fo') + assert_byte_pointer_size('fo') + assert_cursor(2) + assert_cursor_max(2) + assert_line('fo') + assert_equal(nil, @line_editor.instance_variable_get(:@menu_info)) + input_keys("\C-i", false) + assert_byte_pointer_size('foo_') + assert_cursor(4) + assert_cursor_max(4) + assert_line('foo_') + assert_equal(nil, @line_editor.instance_variable_get(:@menu_info)) + input_keys("\C-i", false) + assert_byte_pointer_size('foo_') + assert_cursor(4) + assert_cursor_max(4) + assert_line('foo_') + assert_equal(%w{foo_foo foo_bar Foo_baz}, @line_editor.instance_variable_get(:@menu_info).list) + input_keys('a') + input_keys("\C-i", false) + assert_byte_pointer_size('foo_a') + assert_cursor(5) + assert_cursor_max(5) + assert_line('foo_a') + input_keys("\C-h", false) + input_keys('b') + input_keys("\C-i", false) + assert_byte_pointer_size('foo_ba') + assert_cursor(6) + assert_cursor_max(6) + assert_line('foo_ba') + end + def test_em_kill_region input_keys('abc def{bbb}ccc ddd ') assert_byte_pointer_size('abc def{bbb}ccc ddd ') -- cgit v0.10.2 -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/