mirror of
https://github.com/unicode-org/icu.git
synced 2025-04-06 14:05:32 +00:00
ICU-21344 Fix wrong passing of script in Locale.
Also add same unit test in Java which have no problem.
This commit is contained in:
parent
766088ddb3
commit
9ab5487eb8
3 changed files with 11 additions and 1 deletions
|
@ -35,6 +35,7 @@
|
|||
|
||||
#include "unicode/bytestream.h"
|
||||
#include "unicode/locid.h"
|
||||
#include "unicode/localebuilder.h"
|
||||
#include "unicode/strenum.h"
|
||||
#include "unicode/stringpiece.h"
|
||||
#include "unicode/uloc.h"
|
||||
|
@ -1336,7 +1337,10 @@ AliasReplacer::replaceTerritory(UVector& toBeFreed, UErrorCode& status)
|
|||
// Cannot use nullptr for language because that will construct
|
||||
// the default locale, in that case, use "und" to get the correct
|
||||
// locale.
|
||||
Locale l(language == nullptr ? "und" : language, nullptr, script);
|
||||
Locale l = LocaleBuilder()
|
||||
.setLanguage(language == nullptr ? "und" : language)
|
||||
.setScript(script)
|
||||
.build(status);
|
||||
l.addLikelySubtags(status);
|
||||
const char* likelyRegion = l.getCountry();
|
||||
CharString* item = nullptr;
|
||||
|
|
|
@ -4894,6 +4894,9 @@ void LocaleTest::TestCanonicalize(void)
|
|||
{ "ja-Latn-hepburn-heploc", "ja-Latn-alalc97"},
|
||||
|
||||
{ "aaa-Fooo-SU", "aaa-Fooo-RU"},
|
||||
|
||||
// ICU-21344
|
||||
{ "ku-Arab-NT", "ku-Arab-IQ"},
|
||||
};
|
||||
int32_t i;
|
||||
for (i=0; i < UPRV_LENGTHOF(testCases); i++) {
|
||||
|
|
|
@ -5212,6 +5212,9 @@ public class ULocaleTest extends TestFmwk {
|
|||
Assert.assertEquals("ja-Latn-alalc97", canonicalTag("ja-Latn-hepburn-heploc"));
|
||||
|
||||
Assert.assertEquals("aaa-Fooo-RU", canonicalTag("aaa-Fooo-SU"));
|
||||
|
||||
// ICU-21344
|
||||
Assert.assertEquals("ku-Arab-IQ", canonicalTag("ku-Arab-NT"));
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
Loading…
Add table
Reference in a new issue