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

org.apache.myfaces.trinidadinternal.ui.composite.CompositeRenderingContext 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.ui.composite;

import java.util.Map;
import java.util.MissingResourceException;
import javax.faces.context.FacesContext;
import javax.faces.context.ResponseWriter;

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


import org.apache.myfaces.trinidadinternal.agent.TrinidadAgent;
import org.apache.myfaces.trinidadinternal.share.config.Configuration;
import org.apache.myfaces.trinidad.context.LocaleContext;
import org.apache.myfaces.trinidadinternal.share.url.FormEncoder;
import org.apache.myfaces.trinidadinternal.share.url.URLEncoder;

import org.apache.myfaces.trinidadinternal.image.ImageContext;

import org.apache.myfaces.trinidad.context.PartialPageContext;

import org.apache.myfaces.trinidadinternal.style.StyleContext;

import org.apache.myfaces.trinidadinternal.ui.LogicalNodeRenderingContext;
import org.apache.myfaces.trinidadinternal.ui.RendererManager;
import org.apache.myfaces.trinidadinternal.ui.UIXRenderingContext;
import org.apache.myfaces.trinidadinternal.ui.UINode;
import org.apache.myfaces.trinidadinternal.ui.expl.UIVariableResolver;
import org.apache.myfaces.trinidadinternal.ui.data.DataObject;
import org.apache.myfaces.trinidadinternal.ui.laf.LookAndFeel;
import org.apache.myfaces.trinidad.skin.Icon;

/**
 * @version $Name:  $ ($Revision: adfrt/faces/adf-faces-impl/src/main/java/oracle/adfinternal/view/faces/ui/composite/CompositeRenderingContext.java#0 $) $Date: 10-nov-2005.18:56:50 $
 * @deprecated This class comes from the old Java 1.2 UIX codebase and should not be used anymore.
 */
@Deprecated
class CompositeRenderingContext extends LogicalNodeRenderingContext
{
  /**
   * Get a CompositeRenderingContext that delegates to the
   * parentContext
   * 

* @see #recycleContext */ static synchronized CompositeRenderingContext __getCompositeRenderingContext( UIXRenderingContext parentContext ) { CompositeRenderingContext currContext = _sContexts; if (currContext == null) { currContext = new CompositeRenderingContext(); } else { // the list has one fewer Runnable _sCurrCompositeCount--; _sContexts = currContext._nextContext; // unlink from list currContext._nextContext = null; } // initialize currContext.initialize(parentContext); return currContext; } /** * Recycles the CompositeRenderingContext for reuse. *

* @see #getCompositeRenderingContext */ static synchronized void __recycleContext( CompositeRenderingContext context ) { if (context == null) throw new IllegalArgumentException(); // return the context to the list if there is room if (_sCurrCompositeCount < _MAX_COMPOSITE_COUNT) { // the list has another Context _sCurrCompositeCount++; // // link returned context to head of available list // context._nextContext = _sContexts; _sContexts = context; } // reset the contents of the context context.reset(); } /** * Creates a CompositeRenderingContext. */ protected CompositeRenderingContext() { super(); } protected void initialize( UIXRenderingContext parentContext ) { if (parentContext == null) throw new NullPointerException(); _parentContext = parentContext; _nonCompositeContext = _getNonCompositeContext(parentContext); // Reset the data scope to the default (private) __setGlobalCurrentDataObject(false); setCurrentDataObject(parentContext.getCurrentDataObject()); } @Override protected void reset() { super.reset(); // release references _parentContext = null; _nonCompositeContext = null; _skinResourceKeyMap = null; } @Override public FacesContext getFacesContext() { return _nonCompositeContext.getFacesContext(); } /** * Returns the LookAndFeel that should be used when rendering. */ public LookAndFeel getLookAndFeel() { return _nonCompositeContext.getLookAndFeel(); } /** * Returns the Skin that should be used when rendering. */ public Skin getSkin() { return _nonCompositeContext.getSkin(); } /** * Returns the RendererManager that should be used * for finding renderers. */ public RendererManager getRendererManager() { return _nonCompositeContext.getRendererManager(); } /** * Returns the ResponseWriter that should be used * for rendering text. */ public ResponseWriter getResponseWriter() { return _nonCompositeContext.getResponseWriter(); } public void setResponseWriter(ResponseWriter writer) { _nonCompositeContext.setResponseWriter(writer); } /** * Returns an Agent object that can be used to identify * what device will display the rendering. */ public TrinidadAgent getAgent() { return _nonCompositeContext.getAgent(); } /** * Returns the LocaleContext that should be used for rendering. */ public LocaleContext getLocaleContext() { return _nonCompositeContext.getLocaleContext(); } /** * Store a Map that maps a skin's resource keys from one key to another. * For example, if the renderer uses a new HideShowBean, it will need * to map the HideShowBean's keys to its keys. It can store the map * here, so that context.getTranslatedValue(key) can use this map to get * the correct translated value key. * @param mapping */ public void setSkinResourceKeyMap(Map mapping) { _skinResourceKeyMap = mapping; } /** * Get the _skinResourceKeyMap Map. * @param mapping */ public Map getSkinResourceKeyMap() { return _skinResourceKeyMap; } /** * Returns the number of rendered nodes in the path form the current * node being rendered to the root of the tree of nodes being rendered. */ public int getRenderedAncestorNodeCount() { return _nonCompositeContext.getRenderedAncestorNodeCount(); } /** * Returns an ancestor of the node currently being processed. The * zero-based index from least to most distant - * getRenderedAncestor(0) will always return the current * rendering node. Returns null if the index is greater than or equal to * the number of ancestors. */ public UINode getRenderedAncestorNode( int index ) { return _nonCompositeContext.getRenderedAncestorNode(index); } @Override public void pushRenderedChild( UIXRenderingContext currentContext, UINode renderedChild ) { // push the child onto the stack of rendered children getParentContext().pushRenderedChild(currentContext, renderedChild); // handle initialization of dataobjects super.pushRenderedChild(currentContext, renderedChild); } @Override public void popRenderedChild(UIXRenderingContext currentContext) { // handle cleaning up any of the dataproviders super.popRenderedChild(currentContext); // pop the child off of the stack of rendered children getParentContext().popRenderedChild(currentContext); } /** * Returns the DataObject for the given namespace and name pair. */ @Override public DataObject getDataObject( UIXRenderingContext context, String namespaceURI, String name ) { // give our dataproviders first crack at the dataobject DataObject data = super.getDataObject(context, namespaceURI, name); if (data == null) { data = getParentContext().getDataObject(context, namespaceURI, name); } return data; } /** * Returns a DataObject for the current node (such as a row * of a table). */ @Override public DataObject getCurrentDataObject() { if (_globalCurrentDataObject) return getParentContext().getCurrentDataObject(); return super.getCurrentDataObject(); } /** * Sets the new currentDataObject, returning the current * currentDataObject. *

* @see #getCurrentDataObject */ @Override public DataObject setCurrentDataObject( DataObject newDataObject ) { if (_globalCurrentDataObject) return getParentContext().setCurrentDataObject(newDataObject); return super.setCurrentDataObject(newDataObject); } /** * gets the variableResolver to use with the current render cycle */ public final UIVariableResolver getVariableResolver() { return getParentContext().getVariableResolver(); } /** * Gets a property stored on the context. */ public Object getProperty( String namespace, Object key ) { return _nonCompositeContext.getProperty(namespace, key); } /** * Stores a property on the context. Since RendererContexts * are not persistent, state stored on a RendererContext will * not be present in subsequent rendering passes. */ public void setProperty( String namespace, Object key, Object value ) { _nonCompositeContext.setProperty(namespace, key, value); } /** * Sets a property on the stack frame of the currently rendering UINode. *

* This method is for use by rendering code that needs to save some * state while it is rendering. *

* @param key Key used to identify this property on the stack frame. * @param value Value to store. null is an acceptable value. *

* @see #getLocalProperty */ public void setLocalProperty( Object key, Object value ) { _nonCompositeContext.setLocalProperty(key, value); } /** * Retrieves the specifed property from the stack frame of a * rendering UINode. If the property is not present, * defaultValue is returned. *

* This method is for use by rendering code that needs to save some * state while it is rendering. *

* @param ancestorIndex index into the rendered ancestor stack. If 0, * uses the currently rendering node * @param key Key used to identify the property on the stack frame to * retrieve. * @param defaultValue Value to return if the property doesn't exist * in the stack frame. *

* @see #setLocalProperty */ public Object getLocalProperty( int ancestorIndex, Object key, Object defaultValue ) { return _nonCompositeContext.getLocalProperty(ancestorIndex, key, defaultValue); } /** * Returns a translated value from the skin's resource bundle. * Logs a severe message if there is a MissingResourceException. */ public Object getTranslatedValue(String key) { String mappedKey = getSkinResourceMappedKey(key); if (mappedKey != null) { try{ return getParentContext().getTranslatedValue(mappedKey); } catch (MissingResourceException e) { // log the error and return _LOG.severe(e); return null; } } else return null; } /** * Returns a translated String from the skin's resource bundle. * Logs a severe message if there is a MissingResourceException. */ public String getTranslatedString(String key) { String mappedKey = getSkinResourceMappedKey(key); if (mappedKey != null) { try{ return getParentContext().getTranslatedString(mappedKey); } catch (MissingResourceException e) { // log the error and return _LOG.severe(e); return null; } } else return null; } public Icon getIcon( String iconName ) { String mappedKey = getSkinResourceMappedKey(iconName); if (mappedKey != null) { return getParentContext().getIcon(mappedKey); } else return null; } public Object getStyleClass(String key) { String mappedKey = getSkinResourceMappedKey(key); if (mappedKey != null) { return getParentContext().getStyleClass(mappedKey); } else return null; } /** * @see UIXRenderingContext#getFormEncoder() */ public FormEncoder getFormEncoder() { return _nonCompositeContext.getFormEncoder(); } /** * @see UIXRenderingContext#getURLEncoder() */ public URLEncoder getURLEncoder() { return _nonCompositeContext.getURLEncoder(); } /** * Returns a Configuration object that will be used to * locate paths and return global properties. */ public Configuration getConfiguration() { return _nonCompositeContext.getConfiguration(); } /** * Get an interface that can be used for image lookups and rendering. */ public ImageContext getImageContext() { return _nonCompositeContext.getImageContext(); } /** * Get an interface that can be used for style lookups and generation. */ public StyleContext getStyleContext() { return _nonCompositeContext.getStyleContext(); } public UIXRenderingContext getParentContext() { return _parentContext; } public PartialPageContext getPartialPageContext() { return _nonCompositeContext.getPartialPageContext(); } @Override public Object clone() { CompositeRenderingContext context = (CompositeRenderingContext)super.clone(); // clone the delegated context context._parentContext = (UIXRenderingContext)_parentContext.clone(); return context; } void __setGlobalCurrentDataObject(boolean b) { _globalCurrentDataObject = b; } private UIXRenderingContext _getNonCompositeContext(UIXRenderingContext parent) { while (parent instanceof CompositeRenderingContext) { parent = ((CompositeRenderingContext) parent).getParentContext(); } assert (parent != null); return parent; } private static final int _MAX_COMPOSITE_COUNT = 200; // linked list of available rendering contexts private static CompositeRenderingContext _sContexts; private static int _sCurrCompositeCount; private CompositeRenderingContext _nextContext; private UIXRenderingContext _parentContext; private UIXRenderingContext _nonCompositeContext; private Map _skinResourceKeyMap; private boolean _globalCurrentDataObject; private static final TrinidadLogger _LOG = TrinidadLogger.createTrinidadLogger(CompositeRenderingContext.class); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy