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

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

import java.util.Hashtable;

/**
 * Key class used to quickly retrieve attribute values from UINodes and
 * AttributeMaps.
 * 

* AttributeKeys can not be instantiated directly, instead, the factory * method getAttributeKey is called with the name of the * AttributeKey to retrieve. *

* AttributeKeys have two performance advantages over Strings when used * as keys. *

    *
  1. * AttributeKeys are singletons and can thus use instance equality * to check for equality. *
  2. *
  3. * AttributeKeys that are requested often can be assigned an index * that can then be used by AttributeMap implementations to speed * up value retrieval for these attributes. Both the * FlaggedAttributeMap and the IndexedAttributeMap take advantage * of this feature. *
  4. *
* @version $Name: $ ($Revision: adfrt/faces/adf-faces-impl/src/main/java/oracle/adfinternal/view/faces/ui/AttributeKey.java#0 $) $Date: 10-nov-2005.18:50:10 $ * @see org.apache.myfaces.trinidadinternal.ui.collection.AttributeMap * @see UINode#getAttributeValue * @see MutableUINode#setAttributeValue * @deprecated This class comes from the old Java 1.2 UIX codebase and should not be used anymore. */ @Deprecated public final class AttributeKey { /** * Returns an AttributeKey for the given name, creating the AttributeKey * instance if necessary. This is the only public way to create an * AttributeKey. *

* AttributeKeys created by this method do not have indices. */ // This method must be synchronized; it'd be very bad if // the same attribute key ever got created twice. We // used to use double-checked locking, but that idiom's // broken synchronized public static AttributeKey getAttributeKey( String attrName ) { if (attrName == null) throw new IllegalArgumentException(); AttributeKey attr = _sAttrs.get(attrName); if (attr == null) attr = new AttributeKey(attrName, -1); return attr; } AttributeKey( String attrName ) { this(attrName, -1); } AttributeKey( String attrName, int attrIndex ) { if (attrName == null) throw new IllegalArgumentException(); _attrName = attrName; _attrIndex = attrIndex; _sAttrs.put(attrName, this); } /** * Returns the 0-based index of this AttributeKey, or -1 if the * AttributeKey has no index. */ public int getAttributeIndex() { return _attrIndex; } /** * Returns the name of this AttributeKey. This is the name used to * create the AttributeKey in getAttributeKey. *

* @see #getAttributeKey */ public String getAttributeName() { return _attrName; } @Override public String toString() { return _attrName; } @Override public boolean equals( Object otherObject ) { return (this == otherObject); } @Override public int hashCode() { return _attrName.hashCode(); } private String _attrName; private int _attrIndex; // -= Simon Lessard =- // TODO: Check if synchronization is really required private static Hashtable _sAttrs = new Hashtable(203); // If someone called AttributeKey before UIConstants was // loaded, bad things happen. Prevent this. // By bad things: if the first line of someone's app was: // static public void main(String[] args) // { // AttributeKey attr = AttributeKey.getAttributeKey("source"); // ... // } // Then "attr" would _not_ be the same instance as SOURCE_ATTR. // Which makes stuff blow up. This line fixes that problem. private static final Class _UICONSTANTS_CLASS = UIConstants.class; static { // Hack to eliminate "unused private field" warning _UICONSTANTS_CLASS.getName(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy