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

org.apache.myfaces.trinidadinternal.renderkit.RenderKitBase Maven / Gradle / Ivy

There is a newer version: 2.2.1
Show newest version
/*
 *  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.renderkit;

import java.io.InputStream;
import java.io.IOException;

import java.net.URL;

import java.util.Enumeration;
import java.util.Map;
import java.util.Properties;

import java.util.concurrent.ConcurrentHashMap;

import javax.faces.render.Renderer;
import javax.faces.render.RenderKit;


import org.apache.myfaces.trinidad.logging.TrinidadLogger;


/**
 * Base implementation of RenderKit.
 * 

* @version $Name: $ ($Revision: adfrt/faces/adf-faces-impl/src/main/java/oracle/adfinternal/view/faces/renderkit/RenderKitBase.java#0 $) $Date: 10-nov-2005.19:00:26 $ */ abstract public class RenderKitBase extends RenderKit { public RenderKitBase() { _renderers = new ConcurrentHashMap> (64, 0.75f, 1); // See if we have a render kit map, and if so, // load it String renderKitMap = getRenderKitMap(); if (renderKitMap != null) { _loadRenderKitMap(renderKitMap); } } /** *

Add a new {@link Renderer} instance, associated with the * specified rendererType, to the set of * {@link Renderer}s registered with this {@link RenderKit}. * * @param rendererType Renderer type of the new {@link Renderer} * @param renderer The new {@link Renderer} instance * * @exception IllegalArgumentException if a {@link Renderer} with the * specified rendererType has already been registered * @exception NullPointerException if rendererType or * renderer is null */ @Override public void addRenderer( String family, String rendererType, Renderer renderer) { /* =-=AEW No: it is legal to override a renderer. if ( _get(family, rendererType) != null ) throw new IllegalArgumentException(_LOG.getMessage( "DUPLICATE_RENDERER_TYPE", new Object[]{rendererType, family})); */ _put(family, rendererType, renderer); } /** * Extension allowing for on-demand class loading. */ public void addRenderer(String family, String rendererType, String rendererClassName) { /* =-=AEW No: it is legal to override a renderer. if ( _get(family, rendererType) != null ) throw new IllegalArgumentException(_LOG.getMessage( "DUPLICATE_RENDERER_TYPE", new Object[]{rendererType, family})); */ _put(family, rendererType, new ClassRendererInstantiator(rendererClassName)); } protected String getRenderKitMap() { return null; } /** *

Create (if necessary) and return a {@link Renderer} instance * with the specified renderer type. Subsequent calls to this method * with the same rendererType, from the same web application, * must return the same instance.

* * @param rendererType Renderer type to be returned * * @exception IllegalArgumentException if the requested renderer type * is not supported by this {@link RenderKit} * @exception NullPointerException if rendererType * is null */ @Override public Renderer getRenderer(String family, String rendererType) { Renderer renderer = findRenderer(family, rendererType); if (renderer == null) { if (_LOG.isWarning()) _LOG.warning("RENDERER_NOT_FOUND", new String[]{rendererType, family}); } return renderer; } /** * Finds a renderer - and returns null if one cannot be found. * getRenderer() will log a warning when one cannot be found. */ public Renderer findRenderer(String family, String rendererType) { Object o = _get(family, rendererType); Renderer renderer = null; if (o == null) { if (_aggregated != null) { // Use findRenderer() to avoid "not found" warning messages if (_aggregated instanceof RenderKitBase) renderer = ((RenderKitBase) _aggregated).findRenderer( family, rendererType); else renderer = _aggregated.getRenderer(family, rendererType); } } else if (o instanceof Renderer) { renderer = (Renderer) o; } else if (o instanceof RendererInstantiator) { renderer = ((RendererInstantiator) o).instantiate(); _put(family, rendererType, renderer); } return renderer; } protected void attachAggregatedRenderKit(RenderKit aggregated) { _aggregated = aggregated; } /** * @todo use ArrayMap for "sub-maps", since they'll almost * always be small? */ synchronized private void _put( String family, String rendererType, Object o) { Map subMap = _renderers.get(family); if (subMap == null) { subMap = new ConcurrentHashMap(8, 0.75f, 1); _renderers.put(family, subMap); } subMap.put(rendererType, o); } private Object _get( String family, String rendererType) { Map subMap = _renderers.get(family); if (subMap == null) return null; return subMap.get(rendererType); } /** * Load a renderkit map from a file. renderkit maps * will typically be generated by the faces plugin, * but are properties files of the form: * {component-family}|{renderer-type}={class-name}. */ private void _loadRenderKitMap(String fileName) { ClassLoader loader = Thread.currentThread().getContextClassLoader(); if (loader == null) loader = getClass().getClassLoader(); try { for (Enumeration e = loader.getResources(fileName) ; e.hasMoreElements() ;) { URL resource = (URL)e.nextElement(); if (resource != null) { try { Properties properties = new Properties(); _LOG.fine("Loading renderkit map from {0}", resource); InputStream is = resource.openStream(); try { properties.load(is); } finally { is.close(); } for (Map.Entry entry : properties.entrySet()) { String key = (String) entry.getKey(); int barIndex = key.indexOf('|'); if (barIndex < 0) { _LOG.warning("Invalid renderkit map entry: {0}", key); continue; } String componentFamily = key.substring(0, barIndex); String rendererType = key.substring(barIndex + 1); String className = (String) entry.getValue(); addRenderer(componentFamily, rendererType, className); } } catch (IOException ioe) { _LOG.severe("CANNOT_LOAD_URL", resource); _LOG.severe(ioe); } } else { _LOG.severe("CANNOT_LOAD_URL", resource); } } } catch(IOException ioe) { _LOG.severe("CANNOT_LOAD_RESOURCES", fileName); _LOG.severe(ioe); } } private RenderKit _aggregated; private Map> _renderers; static private final TrinidadLogger _LOG = TrinidadLogger.createTrinidadLogger(RenderKitBase.class); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy