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

com.sun.faces.application.ApplicationResourceBundle Maven / Gradle / Ivy

Go to download

This is the master POM file for Sun's Implementation of the JSF 1.2 Specification.

There is a newer version: 1.2-20
Show newest version
/*
 * $Id: ApplicationResourceBundle.java,v 1.2 2007/04/27 22:00:53 ofung Exp $
 */

/*
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 * 
 * Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
 * 
 * The contents of this file are subject to the terms of either the GNU
 * General Public License Version 2 only ("GPL") or the Common Development
 * and Distribution License("CDDL") (collectively, the "License").  You
 * may not use this file except in compliance with the License. You can obtain
 * a copy of the License at https://glassfish.dev.java.net/public/CDDL+GPL.html
 * or glassfish/bootstrap/legal/LICENSE.txt.  See the License for the specific
 * language governing permissions and limitations under the License.
 * 
 * When distributing the software, include this License Header Notice in each
 * file and include the License file at glassfish/bootstrap/legal/LICENSE.txt.
 * Sun designates this particular file as subject to the "Classpath" exception
 * as provided by Sun in the GPL Version 2 section of the License file that
 * accompanied this code.  If applicable, add the following below the License
 * Header, with the fields enclosed by brackets [] replaced by your own
 * identifying information: "Portions Copyrighted [year]
 * [name of copyright owner]"
 * 
 * Contributor(s):
 * 
 * If you wish your version of this file to be governed by only the CDDL or
 * only the GPL Version 2, indicate your decision by adding "[Contributor]
 * elects to include this software in this distribution under the [CDDL or GPL
 * Version 2] license."  If you don't indicate a single choice of license, a
 * recipient has the option to distribute your version of this file under
 * either the CDDL, the GPL Version 2 or to extend the choice of license to
 * its licensees as provided above.  However, if you add GPL Version 2 code
 * and therefore, elected the GPL Version 2 license, then the option applies
 * only if the new code is made subject to such option by the copyright
 * holder.
 */

package com.sun.faces.application;

import com.sun.faces.util.Util;

import java.util.HashMap;
import java.util.Locale;
import java.util.Map;
import java.util.ResourceBundle;

/**
 * 

Contains an application level resource bundle * name and its associated descriptions, if any.

*/ public class ApplicationResourceBundle { public static final String DEFAULT_KEY = "DEFAULT"; private final String baseName; private final Map displayNames; private final Map descriptions; private volatile Map resources; // ------------------------------------------------------------ Constructors /** *

* Constructs a new ApplicationResourceBundle *

* @param baseName the base name of the ResourceBundle * @param displayNames any display names that were associated * with the resource bundle definition in the configuration resource * @param descriptions any descriptions that were associated * with the resource bundle definition in the configuration resource */ public ApplicationResourceBundle(String baseName, Map displayNames, Map descriptions) { if (baseName == null) { // PENDING i18n throw new IllegalArgumentException(); } this.baseName = baseName; this.displayNames = displayNames; this.descriptions = descriptions; this.resources = new HashMap(4, 1.0f); } // ---------------------------------------------------------- Public Methods /** * @return the base name of the ResourceBundle associated with * this ApplicationResourceBundle instance */ public String getBaseName() { return baseName; } /** * @param locale a Locale * @return return the ResourceBundle associated with the * specified
locale */ public ResourceBundle getResourceBundle(Locale locale) { if (locale == null) { locale = Locale.getDefault(); } ResourceBundle bundle = resources.get(locale); if (bundle == null) { ClassLoader loader = Util.getCurrentLoader(this); synchronized(this) { bundle = resources.get(locale); if (bundle == null) { bundle = ResourceBundle.getBundle(baseName, locale, loader); resources.put(locale, bundle); } } } return bundle; } /** * @param locale a Locale * @return a text of a display-name element associated with the * specified locale */ public String getDisplayName(Locale locale) { String displayName = null; if (displayNames != null) { displayName = queryMap(locale, displayNames); } return ((displayName != null) ? displayName : ""); } /** * @param locale a Locale * @return a text of a description element associated with the * specified locale */ public String getDescription(Locale locale) { String description = null; if (descriptions != null) { description = queryMap(locale, descriptions); } return ((description != null) ? description : ""); } // --------------------------------------------------------- Private Methods /** *

* Lookup and return the text for the specified Locale * from within the specified Map. *

* @param locale Locale if interest * @param map a map containing localized text keyed by Locale * @return localized text, if any */ private String queryMap(Locale locale, Map map) { if (locale == null) { return map.get(DEFAULT_KEY); } else { String key = locale.toString(); String description = map.get(key); if (description == null) { return map.get(DEFAULT_KEY); } } return null; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy