Skip to content

Commit

Permalink
Fix transliteration to default replacement char
Browse files Browse the repository at this point in the history
Commit f6a4294 introduced a bug where non-ASCII chars not present in
the transliteration map would be removed from the output, instead of
being replaced by the default replacement char, violating the
behavior stated in the documentation:

    I18n.transliterate("日本語")
    # => ""         (should be "???")

This fixes the issue while preserving the optimization introduced by
that commit.
  • Loading branch information
romuloceccon committed Feb 21, 2017
1 parent 529d61c commit 6b60a5b
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 1 deletion.
3 changes: 2 additions & 1 deletion lib/i18n/backend/transliterator.rb
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,8 @@ def initialize(rule = nil)
add rule if rule
end

def transliterate(string, replacement = DEFAULT_REPLACEMENT_CHAR)
def transliterate(string, replacement = nil)
replacement ||= DEFAULT_REPLACEMENT_CHAR
string.gsub(/[^\x00-\x7f]/u) do |char|
approximations[char] || replacement
end
Expand Down
4 changes: 4 additions & 0 deletions test/i18n_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -351,6 +351,10 @@ def call(exception, locale, key, options); key; end
end
end

test "transliterate non-ASCII chars not in map with default replacement char" do
assert_equal "???", I18n.transliterate("日本語")
end

test "I18n.locale_available? returns true when the passed locale is available" do
I18n.available_locales = [:en, :de]
assert_equal true, I18n.locale_available?(:de)
Expand Down

0 comments on commit 6b60a5b

Please sign in to comment.