From 48c70517e3bb914c4157e27fb0d70492f4f76cbe Mon Sep 17 00:00:00 2001 From: "xji@chromium.org" Date: Wed, 16 Sep 2009 17:21:13 +0000 Subject: =?UTF-8?q?=C3=AF=C2=BB=C2=BFThis=20CL=20fixes=20issue=2010860=20-?= =?UTF-8?q?=20RTL:=20Hebrew=20file=20names=20should=20have=20forced=20LTR?= =?UTF-8?q?=20directionality=20in=20download=20shelf.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit File names in download shelf are forced to be LTR in DownloadItemView and through ElideFileName(). BUG=http://crbug.com/10860 TEST=1. Open chrome with Hebrew UI. 2. Right click a link and chose Save As... (4th item from the top for non-Hebrew speakers) 3. In the save as dialog name the file קובץ.html 4. In the download shelf the filename should display as קובץ.html (not html.קובץ) Review URL: http://codereview.chromium.org/131001 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@26359 0039d316-1c4b-4281-b951-d872f2087c98 --- app/gfx/text_elider.cc | 24 +++++++++++++++++------- app/gfx/text_elider.h | 5 ++++- app/gfx/text_elider_unittest.cc | 6 +++++- app/l10n_util.cc | 6 ++++++ app/l10n_util.h | 12 +++++++++--- app/l10n_util_unittest.cc | 27 +++++++++++++++++++++++++++ 6 files changed, 68 insertions(+), 12 deletions(-) (limited to 'app') diff --git a/app/gfx/text_elider.cc b/app/gfx/text_elider.cc index 7f56fac..a1db1c6 100644 --- a/app/gfx/text_elider.cc +++ b/app/gfx/text_elider.cc @@ -4,6 +4,7 @@ #include "app/gfx/font.h" #include "app/gfx/text_elider.h" +#include "app/l10n_util.h" #include "base/file_path.h" #include "base/string_util.h" #include "base/sys_string_conversions.h" @@ -257,8 +258,10 @@ std::wstring ElideFilename(const FilePath& filename, const gfx::Font& font, int available_pixel_width) { int full_width = font.GetStringWidth(filename.ToWStringHack()); - if (full_width <= available_pixel_width) - return filename.ToWStringHack(); + if (full_width <= available_pixel_width) { + std::wstring elided_name = filename.ToWStringHack(); + return l10n_util::GetDisplayStringInLTRDirectionality(&elided_name); + } #if defined(OS_WIN) std::wstring extension = filename.Extension(); @@ -268,18 +271,25 @@ std::wstring ElideFilename(const FilePath& filename, std::wstring rootname = filename.BaseName().RemoveExtension().ToWStringHack(); - if (rootname.empty() || extension.empty()) - return ElideText(filename.ToWStringHack(), font, available_pixel_width); + if (rootname.empty() || extension.empty()) { + std::wstring elided_name = ElideText(filename.ToWStringHack(), font, + available_pixel_width); + return l10n_util::GetDisplayStringInLTRDirectionality(&elided_name); + } int ext_width = font.GetStringWidth(extension); int root_width = font.GetStringWidth(rootname); // We may have trimmed the path. - if (root_width + ext_width <= available_pixel_width) - return rootname + extension; + if (root_width + ext_width <= available_pixel_width) { + std::wstring elided_name = rootname + extension; + return l10n_util::GetDisplayStringInLTRDirectionality(&elided_name); + } int available_root_width = available_pixel_width - ext_width; - return ElideText(rootname, font, available_root_width) + extension; + std::wstring elided_name = ElideText(rootname, font, available_root_width); + elided_name += extension; + return l10n_util::GetDisplayStringInLTRDirectionality(&elided_name); } // This function adds an ellipsis at the end of the text if the text diff --git a/app/gfx/text_elider.h b/app/gfx/text_elider.h index 4c9c1fa..aa33c29 100644 --- a/app/gfx/text_elider.h +++ b/app/gfx/text_elider.h @@ -42,7 +42,10 @@ std::wstring ElideText(const std::wstring& text, // Elide a filename to fit a given pixel width, with an emphasis on not hiding // the extension unless we have to. If filename contains a path, the path will -// be removed if filename doesn't fit into available_pixel_width. +// be removed if filename doesn't fit into available_pixel_width. The elided +// filename is forced to have LTR directionality, which means that in RTL UI +// the elided filename is wrapped with LRE (Left-To-Right Embedding) mark and +// PDF (Pop Directional Formatting) mark. std::wstring ElideFilename(const FilePath& filename, const gfx::Font& font, int available_pixel_width); diff --git a/app/gfx/text_elider_unittest.cc b/app/gfx/text_elider_unittest.cc index abb7c23..fb6e7523 100644 --- a/app/gfx/text_elider_unittest.cc +++ b/app/gfx/text_elider_unittest.cc @@ -4,6 +4,7 @@ #include "app/gfx/font.h" #include "app/gfx/text_elider.h" +#include "app/l10n_util.h" #include "base/file_path.h" #include "base/string_util.h" #include "googleurl/src/gurl.h" @@ -176,7 +177,10 @@ TEST(TextEliderTest, TestFilenameEliding) { static const gfx::Font font; for (size_t i = 0; i < arraysize(testcases); ++i) { FilePath filepath(testcases[i].input); - EXPECT_EQ(testcases[i].output, ElideFilename(filepath, + std::wstring expected = testcases[i].output; + if (l10n_util::GetTextDirection() == l10n_util::RIGHT_TO_LEFT) + l10n_util::WrapStringWithLTRFormatting(&expected); + EXPECT_EQ(expected, ElideFilename(filepath, font, font.GetStringWidth(testcases[i].output))); } diff --git a/app/l10n_util.cc b/app/l10n_util.cc index 2dd3cf2..f23de27 100644 --- a/app/l10n_util.cc +++ b/app/l10n_util.cc @@ -830,6 +830,12 @@ void WrapPathWithLTRFormatting(const FilePath& path, rtl_safe_path->push_back(kPopDirectionalFormatting); } +std::wstring GetDisplayStringInLTRDirectionality(std::wstring* text) { + if (GetTextDirection() == RIGHT_TO_LEFT) + WrapStringWithLTRFormatting(text); + return *text; +} + int DefaultCanvasTextAlignment() { if (GetTextDirection() == LEFT_TO_RIGHT) { return gfx::Canvas::TEXT_ALIGN_LEFT; diff --git a/app/l10n_util.h b/app/l10n_util.h index 85fa36b..5e50d6e 100644 --- a/app/l10n_util.h +++ b/app/l10n_util.h @@ -248,12 +248,18 @@ void WrapStringWithLTRFormatting(std::wstring* text); // strings are rendered properly in an LTR context. void WrapStringWithRTLFormatting(std::wstring* text); -// Wraps individual file path components to get them to display correctly in an -// RTL UI. All filepaths should be passed through this function before display -// in UI for RTL locales. +// Wraps file path to get it to display correctly in RTL UI. All filepaths +// should be passed through this function before display in UI for RTL locales. void WrapPathWithLTRFormatting(const FilePath& path, string16* rtl_safe_path); +// Given the string in |text|, this function returns the adjusted string having +// LTR directionality for display purpose. Which means that in RTL locale the +// string is wrapped with LRE (Left-To-Right Embedding) and PDF (Pop +// Directional Formatting) marks and returned. In LTR locale, the string itself +// is returned. +std::wstring GetDisplayStringInLTRDirectionality(std::wstring* text); + // Returns the default text alignment to be used when drawing text on a // gfx::Canvas based on the directionality of the system locale language. This // function is used by gfx::Canvas::DrawStringInt when the text alignment is diff --git a/app/l10n_util_unittest.cc b/app/l10n_util_unittest.cc index 18a568c..c9409fe 100644 --- a/app/l10n_util_unittest.cc +++ b/app/l10n_util_unittest.cc @@ -412,6 +412,33 @@ TEST_F(L10nUtilTest, WrapPathWithLTRFormatting) { } } +typedef struct { + std::wstring raw_filename; + std::wstring display_string; +} StringAndLTRString; + +TEST_F(L10nUtilTest, GetDisplayStringInLTRDirectionality) { + const StringAndLTRString test_data[] = { + { L"test", L"\x202atest\x202c" }, + { L"test.html", L"\x202atest.html\x202c" }, + { L"\x05d0\x05d1\x05d2", L"\x202a\x05d0\x05d1\x05d2\x202c" }, + { L"\x05d0\x05d1\x05d2.txt", L"\x202a\x05d0\x05d1\x05d2.txt\x202c" }, + { L"\x05d0"L"abc", L"\x202a\x05d0"L"abc\x202c" }, + { L"\x05d0"L"abc.txt", L"\x202a\x05d0"L"abc.txt\x202c" }, + { L"abc\x05d0\x05d1", L"\x202a"L"abc\x05d0\x05d1\x202c" }, + { L"abc\x05d0\x05d1.jpg", L"\x202a"L"abc\x05d0\x05d1.jpg\x202c" }, + }; + for (unsigned int i = 0; i < arraysize(test_data); ++i) { + std::wstring input = test_data[i].raw_filename; + std::wstring expected = + l10n_util::GetDisplayStringInLTRDirectionality(&input); + if (l10n_util::GetTextDirection() == l10n_util::RIGHT_TO_LEFT) + EXPECT_EQ(test_data[i].display_string, expected); + else + EXPECT_EQ(input, expected); + } +} + TEST_F(L10nUtilTest, GetTextDirection) { EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, GetTextDirection("ar")); EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, GetTextDirection("ar_EG")); -- cgit v1.1