summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Kenny Root <kroot@google.com> 2011-06-16 02:30:37 -0700
committer Android (Google) Code Review <android-gerrit@google.com> 2011-06-16 02:30:37 -0700
commit9266847e6b666c1f43a08fb18a4f8dd78d9ce66c (patch)
treec3e3e5cf0599ad1865e18ab4e38c6c299c2cf8a8
parentdf60dc327f165ae145755d3b721f1230c4a17106 (diff)
parent49e3b372ab288992a4705dfe7f37fbd732d06aed (diff)
Merge "Fix crash determining direction of invalid locale"
-rw-r--r--core/java/android/util/LocaleUtil.java5
-rw-r--r--core/tests/coretests/src/android/util/LocaleUtilTest.java5
2 files changed, 8 insertions, 2 deletions
diff --git a/core/java/android/util/LocaleUtil.java b/core/java/android/util/LocaleUtil.java
index 4511d9405112..e767a853b606 100644
--- a/core/java/android/util/LocaleUtil.java
+++ b/core/java/android/util/LocaleUtil.java
@@ -71,8 +71,9 @@ public class LocaleUtil {
if (localeWithSubtags == null) return getLayoutDirectionFromFirstChar(locale);
// Need to check if we can extract the script subtag. For example, "Latn" in "en_Latn_US"
- if (localeWithSubtags.charAt(2) != UNDERSCORE_CHAR ||
- localeWithSubtags.charAt(7) != UNDERSCORE_CHAR) {
+ if (localeWithSubtags.length() <= 7
+ || localeWithSubtags.charAt(2) != UNDERSCORE_CHAR
+ || localeWithSubtags.charAt(7) != UNDERSCORE_CHAR) {
return getLayoutDirectionFromFirstChar(locale);
}
// Extract the script subtag
diff --git a/core/tests/coretests/src/android/util/LocaleUtilTest.java b/core/tests/coretests/src/android/util/LocaleUtilTest.java
index a3b494868552..5aa99c1beb14 100644
--- a/core/tests/coretests/src/android/util/LocaleUtilTest.java
+++ b/core/tests/coretests/src/android/util/LocaleUtilTest.java
@@ -193,5 +193,10 @@ public class LocaleUtilTest extends AndroidTestCase {
locale = new Locale("uz_Arab", "AF");
assertEquals(LocaleUtil.TEXT_LAYOUT_DIRECTION_RTL_DO_NOT_USE,
LocaleUtil.getLayoutDirectionFromLocale(locale));
+
+ // Locale without a real language
+ locale = new Locale("zz");
+ assertEquals(LocaleUtil.TEXT_LAYOUT_DIRECTION_LTR_DO_NOT_USE,
+ LocaleUtil.getLayoutDirectionFromLocale(locale));
}
}