All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.myfaces.trinidadinternal.share.nls.LocaleContextImpl Maven / Gradle / Ivy

/*
 *  Licensed to the Apache Software Foundation (ASF) under one
 *  or more contributor license agreements.  See the NOTICE file
 *  distributed with this work for additional information
 *  regarding copyright ownership.  The ASF licenses this file
 *  to you under the Apache License, Version 2.0 (the
 *  "License"); you may not use this file except in compliance
 *  with the License.  You may obtain a copy of the License at
 * 
 *  http://www.apache.org/licenses/LICENSE-2.0
 * 
 *  Unless required by applicable law or agreed to in writing,
 *  software distributed under the License is distributed on an
 *  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 *  KIND, either express or implied.  See the License for the
 *  specific language governing permissions and limitations
 *  under the License.
 */
package org.apache.myfaces.trinidadinternal.share.nls;

import java.util.HashMap;
import java.util.Locale;
import java.util.MissingResourceException;
import java.util.ResourceBundle;
import java.util.TimeZone;

import org.apache.myfaces.trinidad.context.LocaleContext;
import org.apache.myfaces.trinidad.util.ClassLoaderUtils;

import org.apache.myfaces.trinidadinternal.util.nls.LocaleUtils;
import org.apache.myfaces.trinidad.logging.TrinidadLogger;

/**
 * Context for locale-specific operations and properties.  All of the properties
 * should initially default to those of the base Locale, while allowing
 * the locale-specific properties to be overridden.
 * 

* It is expected that additional properties will be added to this class * over time in order to support overriding the date and number formats. *

* Clients should never subclass this class. *

* @version $Name: $ ($Revision: adfrt/faces/adf-faces-impl/src/main/java/oracle/adfinternal/view/faces/share/nls/LocaleContext.java#0 $) $Date: 10-nov-2005.19:00:03 $ */ public class LocaleContextImpl extends LocaleContext { /** * Creates a LocaleContext based off of the specified Locale. */ public LocaleContextImpl( Locale locale ) { this(locale, locale); } /** * Creates a LocaleContext based off of the specified Locale and using * a different Locale for translations. Applications that only provide * translations for a subset of the Locales provided by subcomponents * can use the translation Locale to force subcomponents to only * use translations in a language supported by the application. *

* @param formattingLocale Locale providing default formatting * behavior for the LocaleContext. * If not specified, the defualt Locale is used. * @param translationLocale Locale to use for translations. If not * specified, the formattingLocale is used. */ public LocaleContextImpl( Locale formattingLocale, Locale translationLocale ) { if (!getClass().getName().startsWith("org.apache.myfaces.trinidadinternal.share.nls.")) throw new IllegalStateException(_LOG.getMessage( "USER_DEFINED_SUBCLASSES_NOT_SUPOORTED")); if (formattingLocale == null) { formattingLocale = Locale.getDefault(); } _formattingLocale = formattingLocale; // default the translation locale to the baseLocale if (translationLocale == null) translationLocale = formattingLocale; _transLocale = translationLocale; setTimeZone(null); } /** * Returns the locale that should be used for translations. */ @Override public Locale getTranslationLocale() { return _transLocale; } /** * Returns the locale that should be used for formatting. */ @Override public Locale getFormattingLocale() { return _formattingLocale; } /** * Returns the Locale in IANA String format. */ @Override public String getFormattingIANALocaleString() { if (_formattingIanaLocale == null) { String localeString = _formattingLocale.toString(); _formattingIanaLocale = localeString.replace('_', '-'); } return _formattingIanaLocale; } /** * Returns the translation Locale in IANA String format. */ @Override public String getTranslationIANALocaleString() { if (_transIanaLocale == null) { String transLocaleString = getTranslationLocale().toString(); _transIanaLocale = transLocaleString.replace('_', '-'); } return _transIanaLocale; } @Override public boolean isRightToLeft() { return (getReadingDirection() == LocaleUtils.DIRECTION_RIGHTTOLEFT); } /** * Returns the reading direction that should be used for rendering. * @return a reading direction from * org.apache.myfaces.trinidadinternal.util.nls.LocaleUtils. * This method will never return * LocaleUtils.DIRECTION_DEFAULT. *

* @see #setReadingDirection * @see org.apache.myfaces.trinidadinternal.util.nls.LocaleUtils */ public int getReadingDirection() { if (_readingDirection != LocaleUtils.DIRECTION_DEFAULT) { return _readingDirection; } else { return LocaleUtils.getReadingDirectionForLocale(getTranslationLocale()); } } /** * Sets the new reading direction to be one of the reading directions * defined in org.apache.myfaces.trinidadinternal.util.nls.LocaleUtils. * * @deprecated use MutableLocaleContext.setReadingDirection() instead * @see org.apache.myfaces.trinidadinternal.share.nls.MutableLocaleContext */ @Deprecated public void setReadingDirection( int newReadingDirection ) { if ((newReadingDirection != LocaleUtils.DIRECTION_DEFAULT) && (newReadingDirection != LocaleUtils.DIRECTION_LEFTTORIGHT) && (newReadingDirection != LocaleUtils.DIRECTION_RIGHTTOLEFT)) { throw new IllegalArgumentException(_LOG.getMessage( "UNKNOWN_READING_DIRECTION", newReadingDirection)); } _readingDirection = newReadingDirection; } /** * Returns the TimeZone that the user is running in. */ @Override public TimeZone getTimeZone() { return _timeZone; } /** * Sets the TimeZone that the user is running in. Setting this value * to null will set the TimeZone to the default TimeZone. * * @deprecated use MutableLocaleContext.setTimeZone() instead * @see org.apache.myfaces.trinidadinternal.share.nls.MutableLocaleContext */ @Deprecated public void setTimeZone( TimeZone newTimeZone ) { if (newTimeZone == null) { newTimeZone = TimeZone.getDefault(); } _timeZone = newTimeZone; } /** * Override of Object.toString(). */ @Override public String toString() { StringBuffer buffer = new StringBuffer(super.toString()); buffer.append(" translationLocale="); buffer.append(getTranslationLocale()); buffer.append(", formattingLocale="); buffer.append(getFormattingLocale()); buffer.append(", direction="); buffer.append(getReadingDirection()); buffer.append(", timeZone="); buffer.append(getTimeZone()); buffer.append(", dateFormatContext="); buffer.append(getDateFormatContext()); buffer.append(", decimalFormatContext="); buffer.append(getDecimalFormatContext()); return buffer.toString(); } /** * Returns the resource bundle with the specified name, for this * translation locale. *

* As the LocaleContext maintains a cache of found ResourceBundles, * this is much faster than using * ResourceBundle.getBundle *

* @see java.util.ResourceBundle#getBundle */ @Override public ResourceBundle getBundle( String baseBundleName ) throws MissingResourceException { if (_bundles == null) { _bundles = new HashMap(13); } ResourceBundle bundle = _bundles.get(baseBundleName); if (bundle == null) { ClassLoader loader = ClassLoaderUtils.getContextClassLoader(); Locale translationLocale = getTranslationLocale(); if (loader == null) { bundle = ResourceBundle.getBundle(baseBundleName, translationLocale); } else { bundle = ResourceBundle.getBundle(baseBundleName, translationLocale, loader); } // cache the bundle _bundles.put(baseBundleName, bundle); } return bundle; } /** * Returns the year offset for parsing years with only two digits. */ @Override public int getTwoDigitYearStart() { return getDateFormatContext().getTwoDigitYearStart(); } /** * Returns the character used to separate number groups. * If zero (NUL), the default separator for the Locale * will be used. */ @Override public char getGroupingSeparator() { return getDecimalFormatContext().getGroupingSeparator(); } /** * Returns the character used as a decimal separator. * If zero (NUL), the default separator for the Locale * will be used. */ @Override public char getDecimalSeparator() { return getDecimalFormatContext().getDecimalSeparator(); } /** * Returns the DateFormatContext containing all date format parameters, * falling back on defaults when getDateFormatContextImpl * returns null; */ public final DateFormatContext getDateFormatContext() { DateFormatContext dfc = getDateFormatContextImpl(); if (dfc == null) dfc = _sDefaultDateFormatContext; return dfc; } /** * Returns the DecimalFormatContext containing all number format parameters, * falling back on defaults when getDecimalFormatContextImpl * returns null; */ public final DecimalFormatContext getDecimalFormatContext() { DecimalFormatContext dfc = getDecimalFormatContextImpl(); if (dfc == null) dfc = _sDefaultDecimalFormatContext; return dfc; } /** * Override of Object.hashCode(). */ @Override public int hashCode() { return getFormattingLocale().hashCode(); } /** * Override of Object.equals(). */ @Override public boolean equals(Object obj) { if (obj == this) return true; if (!(obj instanceof LocaleContextImpl)) return false; LocaleContextImpl that = (LocaleContextImpl)obj; return (this.getTranslationLocale().equals(that.getTranslationLocale()) && this.getFormattingLocale().equals(that.getFormattingLocale()) && this.getTimeZone().equals(that.getTimeZone()) && (this.getReadingDirection() == that.getReadingDirection()) && this.getDateFormatContext().equals(that.getDateFormatContext()) && this.getDecimalFormatContext().equals(that.getDecimalFormatContext())); } /** * Returns the DateFormatContext containing all date format parameters. * If this method returns null, getDateFormatContext will * use the default value instead. */ protected DateFormatContext getDateFormatContextImpl() { // use defaults return null; } /** * Returns the DecimalFormatContext containing all number format parameters. * If this method returns null, getDecimalFormatContext will * use the default value instead. */ protected DecimalFormatContext getDecimalFormatContextImpl() { // use defaults return null; } static private class DefaultDecimal extends DecimalFormatContext { @Override public char getGroupingSeparator() { return (char) 0; } @Override public char getDecimalSeparator() { return (char) 0; } } static private class DefaultDate extends DateFormatContext { @Override public int getTwoDigitYearStart() { return 1950; } } private static final DateFormatContext _sDefaultDateFormatContext = new DefaultDate(); private static final DecimalFormatContext _sDefaultDecimalFormatContext = new DefaultDecimal(); private HashMap _bundles; private Locale _formattingLocale; private Locale _transLocale; private transient String _formattingIanaLocale; private transient String _transIanaLocale; private TimeZone _timeZone; private int _readingDirection = LocaleUtils.DIRECTION_DEFAULT; private static final TrinidadLogger _LOG = TrinidadLogger.createTrinidadLogger( LocaleContextImpl.class); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy