Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
   *
   * Copyright (c) 1997-2010 Oracle and/or its affiliates. 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_1_1.html
  * or packager/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 packager/legal/LICENSE.txt.
  *
  * GPL Classpath Exception:
  * Oracle designates this particular file as subject to the "Classpath"
  * exception as provided by Oracle in the GPL Version 2 section of the License
  * file that accompanied this code.
  *
  * Modifications:
  * If applicable, add the following below the License Header, with the fields
  * enclosed by brackets [] replaced by your own identifying information:
  * "Portions Copyright [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 javax.faces.component;
 
 import static javax.faces.component.UIComponentBase.saveAttachedState;
 import static javax.faces.component.UIComponentBase.restoreAttachedState;
 import java.util.*;
A base implementation for maps which implement the PartialStateHolder and TransientStateHolder interfaces. This can be used as a base-class for all state-holder implementations in components, converters and validators and other implementations of the StateHolder interface.
 
 @SuppressWarnings({"unchecked"})
 
     private UIComponent component;
     private boolean isTransient;
     private Map<SerializableObjectdeltaMap;
     private Map<SerializableObjectdefaultMap;
     private Map<ObjectObjecttransientState;
     
     // ------------------------------------------------------------ Constructors
 
 
     public ComponentStateHelper(UIComponent component) {
 
         this. = component;
         this. = new HashMap<Serializable,Object>();
         this. = new HashMap<Serializable,Object>();
         this. = null;
     }
 
 
     // ------------------------------------------------ Methods from StateHelper
 

    
Put the object in the main-map and/or the delta-map, if necessary.

Parameters:
key
value
Returns:
the original value in the delta-map, if not present, the old value in the main map
 
     public Object put(Serializable keyObject value) {
 
         if(.initialStateMarked() || value instanceof PartialStateHolder) {
             Object retVal = .put(keyvalue);
 
             if(retVal==null) {
                 return .put(key,value);
             }
             else {
                 .put(key,value);
                return retVal;
            }
        }
        else {
            return .put(key,value);
        }
    }


    
We need to remove from both maps, if we do remove an existing key.

Parameters:
key
Returns:
the removed object in the delta-map. if not present, the removed object from the main map
    public Object remove(Serializable key) {
        if(.initialStateMarked()) {
            Object retVal = .remove(key);
            if(retVal==null) {
                return .remove(key);
            }
            else {
                .remove(key);
                return retVal;
            }
        }
        else {
            return .remove(key);
        }
    }


    
    public Object put(Serializable keyString mapKeyObject value) {
        Object ret = null;
        if (.initialStateMarked()) {
            Map<String,ObjectdMap = (Map<String,Object>) .get(key);
            if (dMap == null) {
                dMap = new HashMap<String,Object>(5);
                .put(keydMap);
            }
            ret = dMap.put(mapKeyvalue);
        }
        Map<String,Objectmap = (Map<String,Object>) get(key);
        if (map == null) {
            map = new HashMap<String,Object>(8);
            .put(keymap);
        }
        if (ret == null) {
            return map.put(mapKeyvalue);
        } else {
            map.put(mapKeyvalue);
            return ret;
        }
    }


    
Get the object from the main-map. As everything is written through from the delta-map to the main-map, this should be enough.

Parameters:
key
Returns:
    public Object get(Serializable key) {
        return .get(key);
    }


    
    public Object eval(Serializable key) {
        return eval(keynull);
    }


    
    public Object eval(Serializable keyObject defaultValue) {
        Object retVal = get(key);
        if (retVal == null) {
            ValueExpression ve = .getValueExpression(key.toString());
            if (ve != null) {
                retVal = ve.getValue(.getFacesContext().getELContext());
            }
        }
        return ((retVal != null) ? retVal : defaultValue);
    }


    
    public void add(Serializable keyObject value) {
        if (.initialStateMarked()) {
            List<ObjectdeltaList = (List<Object>) .get(key);
            if (deltaList == null) {
                deltaList = new ArrayList<Object>(4);
                .put(keydeltaList);
            }
            deltaList.add(value);
        }
        List<Objectitems = (List<Object>) get(key);
        if (items == null) {
            items = new ArrayList<Object>(4);
            .put(keyitems);
        }
        items.add(value);
    }


    
    public Object remove(Serializable keyObject valueOrKey) {
        Object source = get(key);
        if (source instanceof Collection) {
            return removeFromList(keyvalueOrKey);
        } else if (source instanceof Map) {
            return removeFromMap(keyvalueOrKey.toString());
        }
        return null;
    }
    // ------------------------------------------------ Methods from StateHolder


    
One and only implementation of save-state - makes all other implementations unnecessary.

Parameters:
context
Returns:
the saved state
    public Object saveState(FacesContext context) {
        if (context == null) {
            throw new NullPointerException();
        }
        if(.initialStateMarked()) {
            return saveMap(context);
        }
        else {
            return saveMap(context);
        }
    }



    
One and only implementation of restore state. Makes all other implementations unnecessary.

Parameters:
context FacesContext
state the state to be restored.
    public void restoreState(FacesContext contextObject state) {
        if (context == null) {
            throw new NullPointerException();
        }
        if (state == null) {
            return;
        }
        
        if (!.initialStateMarked() && !.isEmpty())
        {
            .clear();
            if( != null && !.isEmpty())
            {
                .clear();
            }
        }
        
        Object[] savedState = (Object[]) state;
        if (savedState[savedState.length - 1] != null) {
            . = (BooleansavedState[savedState.length - 1];
        }
        int length = (savedState.length-1)/2;
        for (int i = 0; i < lengthi++) {
           Object value = savedState[i * 2 + 1];
           if (..equals(value)) {
               value = null;
           }
            Serializable serializable = (SerializablesavedState[i * 2];
            if (value != null) {
                if (value instanceof Collection) {
                    value = restoreAttachedState(contextvalue);
                } else if (value instanceof StateHolderSaver) {
                    value = ((StateHolderSavervalue).restore(context);
                } else {
                    value = (value instanceof Serializable
                             ? value
                             : restoreAttachedState(contextvalue));
                }
            }
            if (value instanceof Map) {
                for (Map.Entry<StringObjectentry : ((Map<StringObject>) value)
                      .entrySet()) {
                    this.put(serializableentry.getKey(), entry.getValue());
                }
            } else if (value instanceof List) {
                List<Objectlist = (Listget(serializable);
                for (Object o : ((List<Object>) value)) {
                    if (list == null || !list.contains(o)) {
                        this.add(serializableo);
                    }
                }
            } else {
                put(serializablevalue);
            }
        }
    }


    
    public boolean isTransient() {
        return ;
    }

    
    
    public void setTransient(boolean newTransientValue) {
         = newTransientValue;
    }
    // --------------------------------------------------------- Private Methods
    private Object saveMap(FacesContext contextMap<SerializableObjectmap) {
        if (map.isEmpty()) {
            if (!.initialStateMarked()) {
                // only need to propagate the component's delta status when
                // delta tracking has been disabled.  We're assuming that
                // the VDL will reset the status when the view is reconstructed,
                // so no need to save the state if the saved state is the default.
                return new Object[] { .initialStateMarked() };
            }
            return null;
        }
        Object[] savedState = new Object[map.size() * 2 + 1];
        int i=0;
        for(Map.Entry<SerializableObjectentry : map.entrySet()) {
            Object value = entry.getValue();
            if (value == null) {
                value = .;
            }
            savedState[i * 2] = entry.getKey();
            if (value instanceof Collection
                  || value instanceof StateHolder
                  || value instanceof Map
                  || !(value instanceof Serializable)) {
                value = saveAttachedState(context,value);
            }
            savedState[i * 2 + 1] = value;
            i++;
        }
        if (!.initialStateMarked()) {
            savedState[savedState.length - 1] = .initialStateMarked();
        }
        return savedState;
    }
    private Object removeFromList(Serializable keyObject value) {
        Object ret = null;
        if (.initialStateMarked() || value instanceof PartialStateHolder) {
            Collection<ObjectdeltaList = (Collection<Object>) .get(key);
            if (deltaList != null) {
                ret = deltaList.remove(value);
                if (deltaList.isEmpty()) {
                    .remove(key);
                }
            }
        }
        Collection<Objectlist = (Collection<Object>) get(key);
        if (list != null) {
            if (ret == null) {
                ret = list.remove(value);
            } else {
                list.remove(value);
            }
            if (list.isEmpty()) {
                .remove(key);
            }
        }
        return ret;
    }
    private Object removeFromMap(Serializable keyString mapKey) {
        Object ret = null;
        if (.initialStateMarked()) {
            Map<String,ObjectdMap = (Map<String,Object>) .get(key);
            if (dMap != null) {
                ret = dMap.remove(mapKey);
                if (dMap.isEmpty()) {
                    .remove(key);
                }
            }
        }
        Map<String,Objectmap = (Map<String,Object>) get(key);
        if (map != null) {
            if (ret == null) {
                ret = map.remove(mapKey);
            } else {
                map.remove(mapKey);
            }
            if (map.isEmpty()) {
                .remove(key);
            }
        }
        if (ret != null && !.initialStateMarked()) {
            .remove(key);
        }
        return ret;
    }
    public Object getTransient(Object key)
    {
        return ( == null) ? null : .get(key);
    }
    public Object getTransient(Object keyObject defaultValue)
    {
        Object returnValue = ( == null) ? null : .get(key);
        if (returnValue != null)
        {
            return returnValue;
        }
        return defaultValue;
    }
    public Object putTransient(Object keyObject value)
    {
        if ( == null)
        {
             = new HashMap<ObjectObject>();
        }
        return .put(keyvalue);
    }
    @SuppressWarnings("unchecked")
    public void restoreTransientState(FacesContext contextObject state)
    {
         = (Map<ObjectObject>) state;
    }
    
    public Object saveTransientState(FacesContext context)
    {
        return ;
    }
New to GrepCode? Check out our FAQ X