mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-27 23:04:50 +02:00
8154520: java.time: appendLocalizedOffset() should return the localized "GMT" string
Changes to produce/consume the locale-specific equivalent corresponding to the english string "GMT". Reviewed-by: naoto, rriggs
This commit is contained in:
parent
2cd3eb0d40
commit
1f325a0f20
3 changed files with 123 additions and 10 deletions
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2012, 2018, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2012, 2019, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
@ -85,7 +85,6 @@ import java.time.LocalTime;
|
||||||
import java.time.ZoneId;
|
import java.time.ZoneId;
|
||||||
import java.time.ZoneOffset;
|
import java.time.ZoneOffset;
|
||||||
import java.time.chrono.ChronoLocalDate;
|
import java.time.chrono.ChronoLocalDate;
|
||||||
import java.time.chrono.ChronoLocalDateTime;
|
|
||||||
import java.time.chrono.Chronology;
|
import java.time.chrono.Chronology;
|
||||||
import java.time.chrono.Era;
|
import java.time.chrono.Era;
|
||||||
import java.time.chrono.IsoChronology;
|
import java.time.chrono.IsoChronology;
|
||||||
|
@ -122,7 +121,6 @@ import java.util.concurrent.ConcurrentMap;
|
||||||
import sun.text.spi.JavaTimeDateTimePatternProvider;
|
import sun.text.spi.JavaTimeDateTimePatternProvider;
|
||||||
import sun.util.locale.provider.CalendarDataUtility;
|
import sun.util.locale.provider.CalendarDataUtility;
|
||||||
import sun.util.locale.provider.LocaleProviderAdapter;
|
import sun.util.locale.provider.LocaleProviderAdapter;
|
||||||
import sun.util.locale.provider.LocaleResources;
|
|
||||||
import sun.util.locale.provider.TimeZoneNameUtility;
|
import sun.util.locale.provider.TimeZoneNameUtility;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -3871,7 +3869,11 @@ public final class DateTimeFormatterBuilder {
|
||||||
if (offsetSecs == null) {
|
if (offsetSecs == null) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
String gmtText = "GMT"; // TODO: get localized version of 'GMT'
|
String key = "timezone.gmtZeroFormat";
|
||||||
|
String gmtText = DateTimeTextProvider.getLocalizedResource(key, context.getLocale());
|
||||||
|
if (gmtText == null) {
|
||||||
|
gmtText = "GMT"; // Default to "GMT"
|
||||||
|
}
|
||||||
buf.append(gmtText);
|
buf.append(gmtText);
|
||||||
int totalSecs = Math.toIntExact(offsetSecs);
|
int totalSecs = Math.toIntExact(offsetSecs);
|
||||||
if (totalSecs != 0) {
|
if (totalSecs != 0) {
|
||||||
|
@ -3917,7 +3919,11 @@ public final class DateTimeFormatterBuilder {
|
||||||
public int parse(DateTimeParseContext context, CharSequence text, int position) {
|
public int parse(DateTimeParseContext context, CharSequence text, int position) {
|
||||||
int pos = position;
|
int pos = position;
|
||||||
int end = text.length();
|
int end = text.length();
|
||||||
String gmtText = "GMT"; // TODO: get localized version of 'GMT'
|
String key = "timezone.gmtZeroFormat";
|
||||||
|
String gmtText = DateTimeTextProvider.getLocalizedResource(key, context.getLocale());
|
||||||
|
if (gmtText == null) {
|
||||||
|
gmtText = "GMT"; // Default to "GMT"
|
||||||
|
}
|
||||||
if (!context.subSequenceEquals(text, pos, gmtText, 0, gmtText.length())) {
|
if (!context.subSequenceEquals(text, pos, gmtText, 0, gmtText.length())) {
|
||||||
return ~position;
|
return ~position;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2012, 2019, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
@ -69,6 +69,7 @@ import java.time.ZonedDateTime;
|
||||||
import java.time.format.DateTimeFormatter;
|
import java.time.format.DateTimeFormatter;
|
||||||
import java.time.format.DateTimeFormatterBuilder;
|
import java.time.format.DateTimeFormatterBuilder;
|
||||||
import java.time.format.TextStyle;
|
import java.time.format.TextStyle;
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
import org.testng.annotations.BeforeMethod;
|
import org.testng.annotations.BeforeMethod;
|
||||||
import org.testng.annotations.DataProvider;
|
import org.testng.annotations.DataProvider;
|
||||||
|
@ -557,20 +558,20 @@ public class TCKOffsetPrinterParser {
|
||||||
ZonedDateTime zdt = ldt.atZone(offset);
|
ZonedDateTime zdt = ldt.atZone(offset);
|
||||||
|
|
||||||
DateTimeFormatter f = new DateTimeFormatterBuilder().appendLocalizedOffset(style)
|
DateTimeFormatter f = new DateTimeFormatterBuilder().appendLocalizedOffset(style)
|
||||||
.toFormatter();
|
.toFormatter(Locale.US);
|
||||||
assertEquals(f.format(odt), expected);
|
assertEquals(f.format(odt), expected);
|
||||||
assertEquals(f.format(zdt), expected);
|
assertEquals(f.format(zdt), expected);
|
||||||
assertEquals(f.parse(expected, ZoneOffset::from), offset);
|
assertEquals(f.parse(expected, ZoneOffset::from), offset);
|
||||||
|
|
||||||
if (style == TextStyle.FULL) {
|
if (style == TextStyle.FULL) {
|
||||||
f = new DateTimeFormatterBuilder().appendPattern("ZZZZ")
|
f = new DateTimeFormatterBuilder().appendPattern("ZZZZ")
|
||||||
.toFormatter();
|
.toFormatter(Locale.US);
|
||||||
assertEquals(f.format(odt), expected);
|
assertEquals(f.format(odt), expected);
|
||||||
assertEquals(f.format(zdt), expected);
|
assertEquals(f.format(zdt), expected);
|
||||||
assertEquals(f.parse(expected, ZoneOffset::from), offset);
|
assertEquals(f.parse(expected, ZoneOffset::from), offset);
|
||||||
|
|
||||||
f = new DateTimeFormatterBuilder().appendPattern("OOOO")
|
f = new DateTimeFormatterBuilder().appendPattern("OOOO")
|
||||||
.toFormatter();
|
.toFormatter(Locale.US);
|
||||||
assertEquals(f.format(odt), expected);
|
assertEquals(f.format(odt), expected);
|
||||||
assertEquals(f.format(zdt), expected);
|
assertEquals(f.format(zdt), expected);
|
||||||
assertEquals(f.parse(expected, ZoneOffset::from), offset);
|
assertEquals(f.parse(expected, ZoneOffset::from), offset);
|
||||||
|
@ -578,7 +579,7 @@ public class TCKOffsetPrinterParser {
|
||||||
|
|
||||||
if (style == TextStyle.SHORT) {
|
if (style == TextStyle.SHORT) {
|
||||||
f = new DateTimeFormatterBuilder().appendPattern("O")
|
f = new DateTimeFormatterBuilder().appendPattern("O")
|
||||||
.toFormatter();
|
.toFormatter(Locale.US);
|
||||||
assertEquals(f.format(odt), expected);
|
assertEquals(f.format(odt), expected);
|
||||||
assertEquals(f.format(zdt), expected);
|
assertEquals(f.format(zdt), expected);
|
||||||
assertEquals(f.parse(expected, ZoneOffset::from), offset);
|
assertEquals(f.parse(expected, ZoneOffset::from), offset);
|
||||||
|
|
|
@ -0,0 +1,106 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019, 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 8154520
|
||||||
|
* @summary This test verifies that the localized text for "GMT" from CLDR is
|
||||||
|
* applied/recognized during printing/parsing timestamps. For example, the
|
||||||
|
* localized text for "GMT" on some particular locale may be "UTC", and the
|
||||||
|
* resulting formatted string should have UTC+<offset> (instead of GMT+<offset>).
|
||||||
|
* Since the test relies on CLDR data, the "expected" text in the test data may
|
||||||
|
* require to be modified in accordance with changes to CLDR, if any.
|
||||||
|
* @modules jdk.localedata
|
||||||
|
*/
|
||||||
|
|
||||||
|
package test.java.time.format;
|
||||||
|
|
||||||
|
import static org.testng.Assert.assertEquals;
|
||||||
|
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
import java.time.OffsetDateTime;
|
||||||
|
import java.time.ZoneOffset;
|
||||||
|
import java.time.ZonedDateTime;
|
||||||
|
import java.time.format.DateTimeFormatter;
|
||||||
|
import java.time.format.DateTimeFormatterBuilder;
|
||||||
|
import java.time.format.TextStyle;
|
||||||
|
import java.util.Locale;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
import org.testng.annotations.DataProvider;
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test DateTimeFormatterBuilder.appendOffset().
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public class TestLocalizedOffsetPrinterParser {
|
||||||
|
|
||||||
|
private static final LocalDateTime DT_2012_06_30_12_30_40 = LocalDateTime.of(2012, 6, 30, 12, 30, 40);
|
||||||
|
|
||||||
|
private static final Locale LOCALE_GA = new Locale("ga");
|
||||||
|
|
||||||
|
@DataProvider(name="print_localized_custom_locale")
|
||||||
|
Object[][] data_print_localized_custom_locale() {
|
||||||
|
return new Object[][] {
|
||||||
|
{TextStyle.FULL, DT_2012_06_30_12_30_40, ZoneOffset.UTC, LOCALE_GA, "MAG"},
|
||||||
|
{TextStyle.SHORT, DT_2012_06_30_12_30_40, ZoneOffset.ofHours(1), LOCALE_GA, "MAG+1"},
|
||||||
|
{TextStyle.FULL, DT_2012_06_30_12_30_40, ZoneOffset.ofHours(-1), LOCALE_GA, "MAG-01:00"}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(dataProvider="print_localized_custom_locale")
|
||||||
|
public void test_print_localized_custom_locale(TextStyle style, LocalDateTime ldt, ZoneOffset offset, Locale locale, String expected) {
|
||||||
|
|
||||||
|
Objects.requireNonNull(locale, "Locale must not be null");
|
||||||
|
|
||||||
|
OffsetDateTime odt = OffsetDateTime.of(ldt, offset);
|
||||||
|
ZonedDateTime zdt = ldt.atZone(offset);
|
||||||
|
|
||||||
|
DateTimeFormatter f = new DateTimeFormatterBuilder().appendLocalizedOffset(style).toFormatter(locale);
|
||||||
|
assertEquals(f.format(odt), expected);
|
||||||
|
assertEquals(f.format(zdt), expected);
|
||||||
|
assertEquals(f.parse(expected, ZoneOffset::from), offset);
|
||||||
|
|
||||||
|
if (style == TextStyle.FULL) {
|
||||||
|
f = new DateTimeFormatterBuilder().appendPattern("ZZZZ").toFormatter(locale);
|
||||||
|
assertEquals(f.format(odt), expected);
|
||||||
|
assertEquals(f.format(zdt), expected);
|
||||||
|
assertEquals(f.parse(expected, ZoneOffset::from), offset);
|
||||||
|
|
||||||
|
f = new DateTimeFormatterBuilder().appendPattern("OOOO").toFormatter(locale);
|
||||||
|
assertEquals(f.format(odt), expected);
|
||||||
|
assertEquals(f.format(zdt), expected);
|
||||||
|
assertEquals(f.parse(expected, ZoneOffset::from), offset);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (style == TextStyle.SHORT) {
|
||||||
|
f = new DateTimeFormatterBuilder().appendPattern("O").toFormatter(locale);
|
||||||
|
assertEquals(f.format(odt), expected);
|
||||||
|
assertEquals(f.format(zdt), expected);
|
||||||
|
assertEquals(f.parse(expected, ZoneOffset::from), offset);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue