/*******************************************************************************
* Mission Control Technologies, Copyright (c) 2009-2012, United States Government
* as represented by the Administrator of the National Aeronautics and Space
* Administration. All rights reserved.
*
* The MCT platform is licensed 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.
*
* MCT includes source code licensed under additional open source licenses. See
* the MCT Open Source Licenses file included with this distribution or the About
* MCT Licenses dialog available at runtime from the MCT Help menu for additional
* information.
*******************************************************************************/
package org.acme.example.component;
import gov.nasa.arc.mct.services.component.ComponentRegistry;
import java.util.concurrent.atomic.AtomicReference;
/**
* The <code>ComponentRegistryAccess</code> class is used to inject an instance of the <code>ComponentRegistry</code> using declarative
* services. This OSGi component does not expose an interface (see OSGI-INF/component.xml) and thus will be usable from other bundles (
* the class is not exported from this bundle). This class is thread safe as this may be access
* from multiple threads and the registry instance must be visible across all threads.
* @author chris.webster@nasa.gov
*
*/
public class ComponentRegistryAccess {
private static AtomicReference<ComponentRegistry> registry =
new AtomicReference<ComponentRegistry>();
// this is not a traditional singleton as this class is created by the OSGi declarative services mechanism.
/**
* Returns the component registry instance. This will not return null as the cardinality of
* the component specified through the OSGi components services is 1.
* @return a component registry service instance
*/
public static ComponentRegistry getComponentRegistry() {
return registry.get();
}
/**
* set the active instance of the <code>ComponentRegistry</code>. This method is invoked by
* OSGi (see the OSGI-INF/component.xml file for additional details).
* @param componentRegistry available in MCT
*/
public void setRegistry(ComponentRegistry componentRegistry) {
registry.set(componentRegistry);
}
/**
* release the active instance of the <code>ComponentRegistry</code>. This method is invoked by
* OSGi (see the OSGI-INF/component.xml file for additional details).
* @param componentRegistry to be released
*/
public void releaseRegistry(ComponentRegistry componentRegistry) {
registry.set(null);
}
}