001 // Copyright 2005 The Apache Software Foundation
002 //
003 // Licensed under the Apache License, Version 2.0 (the "License");
004 // you may not use this file except in compliance with the License.
005 // You may obtain a copy of the License at
006 //
007 // http://www.apache.org/licenses/LICENSE-2.0
008 //
009 // Unless required by applicable law or agreed to in writing, software
010 // distributed under the License is distributed on an "AS IS" BASIS,
011 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
012 // See the License for the specific language governing permissions and
013 // limitations under the License.
014
015 package org.apache.tapestry.engine.state;
016
017 import java.util.HashMap;
018 import java.util.Map;
019
020 /**
021 * The application scope is for objects that are global to all users and all sessions.
022 * Traditionally, that's stored in the servlet context, but there's no advantage to doing that over
023 * just using a Map.
024 *
025 * @author Howard M. Lewis Ship
026 * @since 4.0
027 */
028 public class ApplicationScopeManager implements StateObjectPersistenceManager
029 {
030 private Map _objects = new HashMap();
031
032 public synchronized boolean exists(String objectName)
033 {
034 return false;
035 }
036
037 public synchronized Object get(String objectName, StateObjectFactory factory)
038 {
039 Object result = _objects.get(objectName);
040
041 if (result == null)
042 {
043 result = factory.createStateObject();
044 _objects.put(objectName, result);
045 }
046
047 return result;
048 }
049
050 public synchronized void store(String objectName, Object stateObject)
051 {
052 _objects.put(objectName, stateObject);
053 }
054
055 }