package org.opendaylight.controller.config.yang.md.sal.binding.impl;
-import java.util.Collections;
-import java.util.Set;
-
import org.opendaylight.controller.config.api.DependencyResolver;
import org.opendaylight.controller.config.api.DependencyResolverFactory;
import org.opendaylight.controller.config.api.DynamicMBeanWithInstance;
import org.opendaylight.controller.config.spi.Module;
import org.osgi.framework.BundleContext;
+import java.util.Collections;
+import java.util.Set;
+
/**
*
*/
org.opendaylight.controller.config.yang.md.sal.binding.impl.AbstractBindingBrokerImplSingletonModuleFactory {
private static final String SINGLETON_NAME = "binding-broker-singleton";
- public static BindingBrokerImplSingletonModule SINGLETON;
public static ModuleIdentifier SINGLETON_IDENTIFIER = new ModuleIdentifier(NAME, SINGLETON_NAME);
@Override
@Override
public Module createModule(String instanceName, DependencyResolver dependencyResolver,
DynamicMBeanWithInstance old, BundleContext bundleContext) throws Exception {
- throw new UnsupportedOperationException("Only default instance supported.");
+ Module instance = super.createModule(instanceName, dependencyResolver, old, bundleContext);
+ ((BindingBrokerImplSingletonModule)instance).setBundleContext(bundleContext);
+ return instance;
}
-
+
@Override
public Set<BindingBrokerImplSingletonModule> getDefaultModules(DependencyResolverFactory dependencyResolverFactory,
BundleContext bundleContext) {
- if (SINGLETON == null) {
- DependencyResolver dependencyResolver = dependencyResolverFactory
- .createDependencyResolver(SINGLETON_IDENTIFIER);
- SINGLETON = new BindingBrokerImplSingletonModule(SINGLETON_IDENTIFIER, dependencyResolver);
- SINGLETON.setBundleContext(bundleContext);
- }
+ DependencyResolver dependencyResolver = dependencyResolverFactory
+ .createDependencyResolver(SINGLETON_IDENTIFIER);
+ BindingBrokerImplSingletonModule instance = new BindingBrokerImplSingletonModule(SINGLETON_IDENTIFIER,
+ dependencyResolver);
+ instance.setBundleContext(bundleContext);
- return Collections.singleton(SINGLETON);
+ return Collections.singleton(instance);
}
}