mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-26 22:34:27 +02:00
8282319: java.util.Locale method to stream available Locales
Reviewed-by: stsypanov, naoto, lancea, rriggs
This commit is contained in:
parent
881517586d
commit
7e47d51e10
3 changed files with 115 additions and 3 deletions
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1996, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1996, 2023, 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
|
||||||
|
@ -48,6 +48,7 @@ import java.io.Serializable;
|
||||||
import java.text.MessageFormat;
|
import java.text.MessageFormat;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import java.util.spi.LocaleNameProvider;
|
import java.util.spi.LocaleNameProvider;
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
import jdk.internal.vm.annotation.Stable;
|
import jdk.internal.vm.annotation.Stable;
|
||||||
|
|
||||||
|
@ -1210,6 +1211,24 @@ public final class Locale implements Cloneable, Serializable {
|
||||||
return LocaleServiceProviderPool.getAllAvailableLocales();
|
return LocaleServiceProviderPool.getAllAvailableLocales();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a stream of all installed locales.
|
||||||
|
* The returned stream represents the union of locales supported
|
||||||
|
* by the Java runtime environment and by installed
|
||||||
|
* {@link java.util.spi.LocaleServiceProvider LocaleServiceProvider}
|
||||||
|
* implementations. At a minimum, the returned stream must contain a
|
||||||
|
* {@code Locale} instance equal to {@link Locale#ROOT Locale.ROOT} and
|
||||||
|
* a {@code Locale} instance equal to {@link Locale#US Locale.US}.
|
||||||
|
*
|
||||||
|
* @implNote Unlike {@code getAvailableLocales()}, this method does
|
||||||
|
* not create a defensive copy of the Locale array.
|
||||||
|
* @return A stream of installed locales.
|
||||||
|
* @since 21
|
||||||
|
*/
|
||||||
|
public static Stream<Locale> availableLocales() {
|
||||||
|
return LocaleServiceProviderPool.streamAllAvailableLocales();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a list of all 2-letter country codes defined in ISO 3166.
|
* Returns a list of all 2-letter country codes defined in ISO 3166.
|
||||||
* Can be used to obtain Locales.
|
* Can be used to obtain Locales.
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2005, 2023, 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
|
||||||
|
@ -38,6 +38,7 @@ import java.util.Set;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import java.util.concurrent.ConcurrentMap;
|
import java.util.concurrent.ConcurrentMap;
|
||||||
import java.util.spi.LocaleServiceProvider;
|
import java.util.spi.LocaleServiceProvider;
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An instance of this class holds a set of the third party implementations of a particular
|
* An instance of this class holds a set of the third party implementations of a particular
|
||||||
|
@ -138,7 +139,6 @@ public final class LocaleServiceProviderPool {
|
||||||
LocaleServiceProviderPool.getPool(c);
|
LocaleServiceProviderPool.getPool(c);
|
||||||
all.addAll(pool.getAvailableLocaleSet());
|
all.addAll(pool.getAvailableLocaleSet());
|
||||||
}
|
}
|
||||||
|
|
||||||
allAvailableLocales = all.toArray(new Locale[0]);
|
allAvailableLocales = all.toArray(new Locale[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -147,6 +147,17 @@ public final class LocaleServiceProviderPool {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a stream of the available locales for all the provider classes.
|
||||||
|
* This stream is constructed from all the locales
|
||||||
|
* that are provided by each provider, including the JRE.
|
||||||
|
*
|
||||||
|
* @return a stream of the available locales for all provider classes
|
||||||
|
*/
|
||||||
|
public static Stream<Locale> streamAllAvailableLocales() {
|
||||||
|
return Arrays.stream(AllAvailableLocales.allAvailableLocales);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns an array of available locales for all the provider classes.
|
* Returns an array of available locales for all the provider classes.
|
||||||
* This array is a merged array of all the locales that are provided by each
|
* This array is a merged array of all the locales that are provided by each
|
||||||
|
|
82
test/jdk/java/util/Locale/StreamAvailableLocales.java
Normal file
82
test/jdk/java/util/Locale/StreamAvailableLocales.java
Normal file
|
@ -0,0 +1,82 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2023, 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
|
||||||
|
* @summary Test the implementation
|
||||||
|
* of Locale.availableLocales()
|
||||||
|
* @bug 8282319
|
||||||
|
* @run junit StreamAvailableLocales
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Locale;
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.jupiter.params.ParameterizedTest;
|
||||||
|
import org.junit.jupiter.params.provider.MethodSource;
|
||||||
|
import org.junit.jupiter.params.provider.Arguments;
|
||||||
|
|
||||||
|
public class StreamAvailableLocales {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test to validate that the methods: Locale.getAvailableLocales()
|
||||||
|
* and Locale.availableLocales() contain the same underlying elements
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testStreamEqualsArray() {
|
||||||
|
Locale[] arrayLocales = Locale.getAvailableLocales();
|
||||||
|
Stream<Locale> streamedLocales = Locale.availableLocales();
|
||||||
|
Locale[] convertedLocales = streamedLocales.toArray(Locale[]::new);
|
||||||
|
if (Arrays.equals(arrayLocales, convertedLocales)) {
|
||||||
|
System.out.println("$$$ Passed: The underlying elements" +
|
||||||
|
" of getAvailableLocales() and availableLocales() are the same!");
|
||||||
|
} else {
|
||||||
|
throw new RuntimeException("$$$ Error: The underlying elements" +
|
||||||
|
" of getAvailableLocales() and availableLocales()" +
|
||||||
|
" are not the same.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test to validate that the stream has the required
|
||||||
|
* Locale.ROOT and Locale.US.
|
||||||
|
*/
|
||||||
|
@ParameterizedTest
|
||||||
|
@MethodSource("requiredLocaleProvider")
|
||||||
|
public void testStreamRequirements(Locale requiredLocale, String localeName) {
|
||||||
|
if (Locale.availableLocales().anyMatch(loc -> (loc.equals(requiredLocale)))) {
|
||||||
|
System.out.printf("$$$ Passed: Stream has %s!%n", localeName);
|
||||||
|
} else {
|
||||||
|
throw new RuntimeException(String.format("$$$ Error:" +
|
||||||
|
" Stream is missing %s!", localeName));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Data provider for testStreamRequirements
|
||||||
|
private static Stream<Arguments> requiredLocaleProvider() {
|
||||||
|
return Stream.of(
|
||||||
|
Arguments.of(Locale.ROOT, "Root locale"),
|
||||||
|
Arguments.of(Locale.US, "US locale")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue