8342582: user.region for formatting number no longer works for 21.0.5
Reviewed-by: jlu, rriggs
This commit is contained in:
parent
426da4bbad
commit
e64f0798be
@ -1126,28 +1126,11 @@ public final class Locale implements Cloneable, Serializable {
|
||||
}
|
||||
|
||||
private static Locale initDefault() {
|
||||
String language, region, script, country, variant;
|
||||
language = StaticProperty.USER_LANGUAGE;
|
||||
// for compatibility, check for old user.region property
|
||||
region = StaticProperty.USER_REGION;
|
||||
if (!region.isEmpty()) {
|
||||
// region can be of form country, country_variant, or _variant
|
||||
int i = region.indexOf('_');
|
||||
if (i >= 0) {
|
||||
country = region.substring(0, i);
|
||||
variant = region.substring(i + 1);
|
||||
} else {
|
||||
country = region;
|
||||
variant = "";
|
||||
}
|
||||
script = "";
|
||||
} else {
|
||||
script = StaticProperty.USER_SCRIPT;
|
||||
country = StaticProperty.USER_COUNTRY;
|
||||
variant = StaticProperty.USER_VARIANT;
|
||||
}
|
||||
|
||||
return getInstance(language, script, country, variant,
|
||||
return getInstance(
|
||||
StaticProperty.USER_LANGUAGE,
|
||||
StaticProperty.USER_SCRIPT,
|
||||
StaticProperty.USER_COUNTRY,
|
||||
StaticProperty.USER_VARIANT,
|
||||
getDefaultExtensions(StaticProperty.USER_EXTENSIONS)
|
||||
.orElse(null));
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2018, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2018, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
@ -98,19 +98,33 @@ public final class StaticProperty {
|
||||
USER_LANGUAGE = getProperty(props, "user.language", "en");
|
||||
USER_LANGUAGE_DISPLAY = getProperty(props, "user.language.display", USER_LANGUAGE);
|
||||
USER_LANGUAGE_FORMAT = getProperty(props, "user.language.format", USER_LANGUAGE);
|
||||
USER_SCRIPT = getProperty(props, "user.script", "");
|
||||
// for compatibility, check for old user.region property
|
||||
USER_REGION = getProperty(props, "user.region", "");
|
||||
if (!USER_REGION.isEmpty()) {
|
||||
// region can be of form country, country_variant, or _variant
|
||||
int i = USER_REGION.indexOf('_');
|
||||
if (i >= 0) {
|
||||
USER_COUNTRY = USER_REGION.substring(0, i);
|
||||
USER_VARIANT = USER_REGION.substring(i + 1);
|
||||
} else {
|
||||
USER_COUNTRY = USER_REGION;
|
||||
USER_VARIANT = "";
|
||||
}
|
||||
USER_SCRIPT = "";
|
||||
} else {
|
||||
USER_SCRIPT = getProperty(props, "user.script", "");
|
||||
USER_COUNTRY = getProperty(props, "user.country", "");
|
||||
USER_VARIANT = getProperty(props, "user.variant", "");
|
||||
}
|
||||
USER_SCRIPT_DISPLAY = getProperty(props, "user.script.display", USER_SCRIPT);
|
||||
USER_SCRIPT_FORMAT = getProperty(props, "user.script.format", USER_SCRIPT);
|
||||
USER_COUNTRY = getProperty(props, "user.country", "");
|
||||
USER_COUNTRY_DISPLAY = getProperty(props, "user.country.display", USER_COUNTRY);
|
||||
USER_COUNTRY_FORMAT = getProperty(props, "user.country.format", USER_COUNTRY);
|
||||
USER_VARIANT = getProperty(props, "user.variant", "");
|
||||
USER_VARIANT_DISPLAY = getProperty(props, "user.variant.display", USER_VARIANT);
|
||||
USER_VARIANT_FORMAT = getProperty(props, "user.variant.format", USER_VARIANT);
|
||||
USER_EXTENSIONS = getProperty(props, "user.extensions", "");
|
||||
USER_EXTENSIONS_DISPLAY = getProperty(props, "user.extensions.display", USER_EXTENSIONS);
|
||||
USER_EXTENSIONS_FORMAT = getProperty(props, "user.extensions.format", USER_EXTENSIONS);
|
||||
USER_REGION = getProperty(props, "user.region", "");
|
||||
}
|
||||
|
||||
private static String getProperty(Properties props, String key) {
|
||||
|
74
test/jdk/java/util/Locale/UserRegionTest.java
Normal file
74
test/jdk/java/util/Locale/UserRegionTest.java
Normal file
@ -0,0 +1,74 @@
|
||||
/*
|
||||
* Copyright (c) 2024, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
/*
|
||||
* @test
|
||||
* @bug 8342582
|
||||
* @summary Test if "user.region" system property successfully overrides
|
||||
* other locale related system properties at startup
|
||||
* @modules jdk.localedata
|
||||
* @run junit/othervm
|
||||
* -Duser.region=DE
|
||||
* -Duser.language=en
|
||||
* -Duser.script=Latn
|
||||
* -Duser.country=US
|
||||
* -Duser.variant=FOO UserRegionTest
|
||||
* @run junit/othervm
|
||||
* -Duser.region=DE_POSIX
|
||||
* -Duser.language=en
|
||||
* -Duser.script=Latn
|
||||
* -Duser.country=US
|
||||
* -Duser.variant=FOO UserRegionTest
|
||||
* @run junit/othervm
|
||||
* -Duser.region=_POSIX
|
||||
* -Duser.language=en
|
||||
* -Duser.script=Latn
|
||||
* -Duser.country=US
|
||||
* -Duser.variant=FOO UserRegionTest
|
||||
*/
|
||||
|
||||
import java.util.Locale;
|
||||
|
||||
import org.junit.jupiter.api.Test;
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
|
||||
public class UserRegionTest {
|
||||
@Test
|
||||
public void testDefaultLocale() {
|
||||
var region = System.getProperty("user.region").split("_");
|
||||
var expected = Locale.of(System.getProperty("user.language"),
|
||||
region[0], region.length > 1 ? region[1] : "");
|
||||
assertEquals(expected, Locale.getDefault());
|
||||
assertEquals(expected, Locale.getDefault(Locale.Category.FORMAT));
|
||||
assertEquals(expected, Locale.getDefault(Locale.Category.DISPLAY));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testNumberFormat() {
|
||||
if (System.getProperty("user.region").startsWith("DE")) {
|
||||
assertEquals("0,50000", String.format("%.5f", 0.5f));
|
||||
} else {
|
||||
assertEquals("0.50000", String.format("%.5f", 0.5f));
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user