/* * Copyright (c) 2006 Stiftung Deutsches Elektronen-Synchroton, * Member of the Helmholtz Association, (DESY), HAMBURG, GERMANY. * * THIS SOFTWARE IS PROVIDED UNDER THIS LICENSE ON AN "../AS IS" BASIS. * WITHOUT WARRANTY OF ANY KIND, EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED * TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR PARTICULAR PURPOSE AND * NON-INFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE * FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR * THE USE OR OTHER DEALINGS IN THE SOFTWARE. SHOULD THE SOFTWARE PROVE DEFECTIVE * IN ANY RESPECT, THE USER ASSUMES THE COST OF ANY NECESSARY SERVICING, REPAIR OR * CORRECTION. THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL PART OF THIS LICENSE. * NO USE OF ANY SOFTWARE IS AUTHORIZED HEREUNDER EXCEPT UNDER THIS DISCLAIMER. * DESY HAS NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, * OR MODIFICATIONS. * THE FULL LICENSE SPECIFYING FOR THE SOFTWARE THE REDISTRIBUTION, MODIFICATION, * USAGE AND OTHER RIGHTS AND OBLIGATIONS IS INCLUDED WITH THE DISTRIBUTION OF THIS * PROJECT IN THE FILE LICENSE.HTML. IF THE LICENSE IS NOT INCLUDED YOU MAY FIND A COPY * AT HTTP://WWW.DESY.DE/LEGAL/LICENSE.HTM */ package org.csstudio.dal.impl; import java.util.Hashtable; import java.util.Properties; import org.apache.log4j.Logger; import org.csstudio.dal.context.AbstractApplicationContext; import org.csstudio.dal.context.Identifier; import org.csstudio.dal.context.LifecycleReporterSupport; import org.csstudio.dal.spi.Plugs; /** * Default application context implementation */ public class DefaultApplicationContext extends LifecycleReporterSupport implements AbstractApplicationContext { private final String name; protected Properties configuration; protected Identifier identificator; private Logger logger; private Hashtable<String, Object> properties; /** * Creates a new DefaultApplicationContext object. * * @param name application context name */ public DefaultApplicationContext(final String name) { super(); this.name = name; fireInitializing(); fireInitialized(); } /* * (non-Javadoc) * @see org.csstudio.dal.context.AbstractApplicationContext#getConfiguration() */ @Override public Properties getConfiguration(){ if (configuration == null) { configuration = new Properties(System.getProperties()); Plugs.configureSimulatorPlug(configuration); } return configuration; } /* * (non-Javadoc) * @see org.csstudio.dal.context.Identifiable#getIdentifier() */ @Override public Identifier getIdentifier(){ if (identificator == null) return null; return identificator; // TODO Check if this is OK } /* * (non-Javadoc) * @see org.csstudio.dal.context.Identifiable#isDebug() */ @Override public boolean isDebug(){ return false; } /* * (non-Javadoc) * @see org.csstudio.dal.context.AbstractApplicationContext#getName() */ @Override public String getName() { return name; } /** * Destroys context by signaling all listners that lifecycle has * ended and releases all resources. After this point context is not * valid any more. */ @Override public void destroy() { fireDestroying(); fireDestroyed(); } /** * Returns a logger registered to this application context. The name of the logger is * the same as the name of application context. * @return */ public Logger getLogger() { if (logger == null) { return Logger.getLogger(getClass()); } return logger; } @Override public Object getApplicationProperty(final String keyName) { if (properties==null || keyName==null) { return null; } return properties.get(keyName); } @Override public synchronized void putApplicationProperty(final String keyName, final Object value) { if (keyName==null) { return; } if (properties==null) { properties= new Hashtable<String, Object>(); } properties.put(keyName, value); } } /* __oOo__ */