diff options
author | kouji <kouji@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-12-12 16:13:11 +0000 |
---|---|---|
committer | kouji <kouji@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-12-12 16:13:11 +0000 |
commit | 73271378cf842c008117b22eed9097ef25c31081 (patch) | |
tree | d217ac137694e43a867e0d5fbc2af3b1bdf39970 | |
parent | deb225d2c632c60576a4abbb6dde0a818e531248 (diff) | |
download | ruby-73271378cf842c008117b22eed9097ef25c31081.tar.gz ruby-73271378cf842c008117b22eed9097ef25c31081.tar.xz ruby-73271378cf842c008117b22eed9097ef25c31081.zip |
* ext/readline/readline.c
(readline_s_get_completion_append_character): uses locale
encoding but not ASCII-8BIT.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@20680 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ext/readline/readline.c | 7 | ||||
-rw-r--r-- | test/readline/test_readline.rb | 18 |
2 files changed, 15 insertions, 10 deletions
diff --git a/ext/readline/readline.c b/ext/readline/readline.c index 6100633f2..87a1ff037 100644 --- a/ext/readline/readline.c +++ b/ext/readline/readline.c @@ -602,15 +602,14 @@ static VALUE readline_s_get_completion_append_character(VALUE self) { #ifdef HAVE_RL_COMPLETION_APPEND_CHARACTER - VALUE str; + char buf[1]; rb_secure(4); if (rl_completion_append_character == '\0') return Qnil; - str = rb_str_new(0, 1); - RSTRING_PTR(str)[0] = rl_completion_append_character; - return str; + buf[0] = (char) rl_completion_append_character; + return rb_locale_str_new(buf, 1); #else rb_notimplement(); return Qnil; /* not reached */ diff --git a/test/readline/test_readline.rb b/test/readline/test_readline.rb index 36aadd92d..cf809e20d 100644 --- a/test/readline/test_readline.rb +++ b/test/readline/test_readline.rb @@ -166,12 +166,18 @@ class TestReadline < Test::Unit::TestCase def test_completion_append_character begin - Readline.completion_append_character = "x" - assert_equal("x", Readline.completion_append_character) - Readline.completion_append_character = "xyz" - assert_equal("x", Readline.completion_append_character) - Readline.completion_append_character = nil - assert_equal(nil, Readline.completion_append_character) + enc = Encoding.default_internal || Encoding.find("locale") + data_expected = [ + ["x", "x"], + ["xyx", "x"], + [" ", " "], + ["\t", "\t"], + ] + data_expected.each do |(data, expected)| + Readline.completion_append_character = data + assert_equal(expected, Readline.completion_append_character) + assert_equal(enc, Readline.completion_append_character.encoding) + end Readline.completion_append_character = "" assert_equal(nil, Readline.completion_append_character) rescue NotImplementedError |