| 
 | Java™ Platform Standard Ed. 6 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectjava.util.spi.LocaleServiceProvider
public abstract class LocaleServiceProvider
This is the super class of all the locale sensitive service provider interfaces (SPIs).
 Locale sensitive  service provider interfaces are interfaces that 
 correspond to locale sensitive classes in the java.text
 and java.util packages. The interfaces enable the 
 construction of locale sensitive objects and the retrieval of 
 localized names for these packages. Locale sensitive factory methods 
 and methods for name retrieval in the java.text and 
 java.util packages use implementations of the provider 
 interfaces to offer support for locales beyond the set of locales 
 supported by the Java runtime environment itself.
 
If a particular concrete provider class is named in more than one configuration file, or is named in the same configuration file more than once, then the duplicates will be ignored. The configuration file naming a particular provider need not be in the same jar file or other distribution unit as the provider itself. The provider must be accessible from the same class loader that was initially queried to locate the configuration file; this is not necessarily the class loader that loaded the file.
 For example, an implementation of the
 DateFormatProvider class should 
 take the form of a jar file which contains the file: 
 
META-INF/services/java.text.spi.DateFormatProviderAnd the file
java.text.spi.DateFormatProvider should have 
 a line such as: 
 
 com.foo.DateFormatProviderImpl
 
 which is the fully qualified class name of the class implementing 
 DateFormatProvider.
 
 Locale sensitive factory methods and methods for name retrieval in the 
 java.text and java.util packages invoke 
 service provider methods when needed to support the requested locale. 
 The methods first check whether the Java runtime environment itself 
 supports the requested locale, and use its support if available. 
 Otherwise, they call the getAvailableLocales() methods of 
 installed providers for the appropriate interface to find one that 
 supports the requested locale. If such a provider is found, its other 
 methods are called to obtain the requested object or name. If neither 
 the Java runtime environment itself nor an installed provider supports 
 the requested locale, a fallback locale is constructed by replacing the 
 first of the variant, country, or language strings of the locale that's 
 not an empty string with an empty string, and the lookup process is 
 restarted. In the case that the variant contains one or more '_'s, the 
 fallback locale is constructed by replacing the variant with a new variant 
 which eliminates the last '_' and the part following it.  Even if a 
 fallback occurs, methods that return requested objects or name are 
 invoked with the original locale before the fallback.The Java runtime 
 environment must support the root locale for all locale sensitive services 
 in order to guarantee that this process terminates.
 
 Providers of names (but not providers of other objects) are allowed to 
 return null for some name requests even for locales that they claim to 
 support by including them in their return value for 
 getAvailableLocales. Similarly, the Java runtime 
 environment itself may not have all names for all locales that it 
 supports. This is because the sets of objects for which names are 
 requested can be large and vary over time, so that it's not always 
 feasible to cover them completely. If the Java runtime environment or a 
 provider returns null instead of a name, the lookup will proceed as 
 described above as if the locale was not supported.
| Constructor Summary | |
|---|---|
| protected  | LocaleServiceProvider()Sole constructor. | 
| Method Summary | |
|---|---|
| abstract  Locale[] | getAvailableLocales()Returns an array of all locales for which this locale service provider can provide localized objects or names. | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Constructor Detail | 
|---|
protected LocaleServiceProvider()
| Method Detail | 
|---|
public abstract Locale[] getAvailableLocales()
| 
 | Java™ Platform Standard Ed. 6 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
Copyright © 1993, 2010, Oracle and/or its affiliates. All rights reserved.