X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-binding-broker%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fconfig%2Fyang%2Fmd%2Fsal%2Fbinding%2Fimpl%2FRuntimeMappingModule.java;h=b0c2d742e214046be839cca263dbc0652005aa9b;hb=28ad802448833cad483f185cfe442497ddc5c296;hp=a15b1d746c5f5709374387f996056f6f979e2025;hpb=55f2161ed7a2118fedb0b4e50a3dbb8f23aa1611;p=controller.git diff --git a/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/config/yang/md/sal/binding/impl/RuntimeMappingModule.java b/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/config/yang/md/sal/binding/impl/RuntimeMappingModule.java index a15b1d746c..b0c2d742e2 100644 --- a/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/config/yang/md/sal/binding/impl/RuntimeMappingModule.java +++ b/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/config/yang/md/sal/binding/impl/RuntimeMappingModule.java @@ -7,18 +7,12 @@ */ package org.opendaylight.controller.config.yang.md.sal.binding.impl; -import com.google.common.base.Optional; -import com.google.common.base.Preconditions; import java.util.Hashtable; import java.util.Map.Entry; import java.util.Set; -import javassist.ClassPool; -import org.opendaylight.controller.md.sal.binding.impl.BindingToNormalizedNodeCodec; + import org.opendaylight.controller.sal.binding.codegen.impl.SingletonHolder; -import org.opendaylight.yangtools.binding.data.codec.gen.impl.StreamWriterGenerator; -import org.opendaylight.yangtools.binding.data.codec.impl.BindingNormalizedNodeCodecRegistry; import org.opendaylight.yangtools.concepts.Delegator; -import org.opendaylight.yangtools.sal.binding.generator.impl.GeneratedClassLoadingStrategy; import org.opendaylight.yangtools.sal.binding.generator.impl.RuntimeGeneratedMappingServiceImpl; import org.opendaylight.yangtools.yang.binding.DataContainer; import org.opendaylight.yangtools.yang.binding.DataObject; @@ -35,6 +29,9 @@ import org.osgi.framework.ServiceReference; import org.slf4j.Logger; import org.slf4j.LoggerFactory; +import com.google.common.base.Optional; +import com.google.common.base.Preconditions; + /** * */ @@ -45,14 +42,14 @@ public final class RuntimeMappingModule extends private BundleContext bundleContext; - public RuntimeMappingModule(final org.opendaylight.controller.config.api.ModuleIdentifier identifier, - final org.opendaylight.controller.config.api.DependencyResolver dependencyResolver) { + public RuntimeMappingModule(org.opendaylight.controller.config.api.ModuleIdentifier identifier, + org.opendaylight.controller.config.api.DependencyResolver dependencyResolver) { super(identifier, dependencyResolver); } - public RuntimeMappingModule(final org.opendaylight.controller.config.api.ModuleIdentifier identifier, - final org.opendaylight.controller.config.api.DependencyResolver dependencyResolver, - final RuntimeMappingModule oldModule, final java.lang.AutoCloseable oldInstance) { + public RuntimeMappingModule(org.opendaylight.controller.config.api.ModuleIdentifier identifier, + org.opendaylight.controller.config.api.DependencyResolver dependencyResolver, + RuntimeMappingModule oldModule, java.lang.AutoCloseable oldInstance) { super(identifier, dependencyResolver, oldModule, oldInstance); } @@ -64,48 +61,41 @@ public final class RuntimeMappingModule extends } @Override - public boolean canReuseInstance(final AbstractRuntimeMappingModule oldModule) { + public boolean canReuseInstance(AbstractRuntimeMappingModule oldModule) { return true; } @Override public java.lang.AutoCloseable createInstance() { - final GeneratedClassLoadingStrategy classLoading = getGlobalClassLoadingStrategy(); - final BindingIndependentMappingService legacyMapping = getGlobalLegacyMappingService(classLoading); - BindingNormalizedNodeCodecRegistry codecRegistry = new BindingNormalizedNodeCodecRegistry(new StreamWriterGenerator(SingletonHolder.JAVASSIST)); - BindingToNormalizedNodeCodec instance = new BindingToNormalizedNodeCodec(classLoading, legacyMapping, codecRegistry); - bundleContext.registerService(SchemaContextListener.class, instance, new Hashtable()); - return instance; - } - private BindingIndependentMappingService getGlobalLegacyMappingService(final GeneratedClassLoadingStrategy classLoading) { - BindingIndependentMappingService potential = tryToReuseGlobalMappingServiceInstance(); - if(potential == null) { - potential = new RuntimeGeneratedMappingServiceImpl(ClassPool.getDefault(),classLoading); - bundleContext.registerService(SchemaContextListener.class, (SchemaContextListener) potential, new Hashtable()); + RuntimeGeneratedMappingServiceProxy potential = tryToReuseGlobalInstance(); + if(potential != null) { + return potential; } - return potential; - } - private GeneratedClassLoadingStrategy getGlobalClassLoadingStrategy() { - ServiceReference ref = bundleContext.getServiceReference(GeneratedClassLoadingStrategy.class); - return bundleContext.getService(ref); + final RuntimeGeneratedMappingServiceImpl service = new RuntimeGeneratedMappingServiceImpl(SingletonHolder.CLASS_POOL); + bundleContext.registerService(SchemaContextListener.class, service, new Hashtable()); + return service; } - private BindingIndependentMappingService tryToReuseGlobalMappingServiceInstance() { + private RuntimeGeneratedMappingServiceProxy tryToReuseGlobalInstance() { ServiceReference serviceRef = getBundleContext().getServiceReference(BindingIndependentMappingService.class); if(serviceRef == null) { return null; } - return bundleContext.getService(serviceRef); + BindingIndependentMappingService delegate = bundleContext.getService(serviceRef); + if (delegate == null) { + return null; + } + return new RuntimeGeneratedMappingServiceProxy(getBundleContext(),serviceRef,delegate); } private BundleContext getBundleContext() { return bundleContext; } - public void setBundleContext(final BundleContext bundleContext) { + public void setBundleContext(BundleContext bundleContext) { this.bundleContext = bundleContext; } @@ -118,9 +108,9 @@ public final class RuntimeMappingModule extends private ServiceReference reference; private BundleContext bundleContext; - public RuntimeGeneratedMappingServiceProxy(final BundleContext bundleContext, - final ServiceReference serviceRef, - final BindingIndependentMappingService delegate) { + public RuntimeGeneratedMappingServiceProxy(BundleContext bundleContext, + ServiceReference serviceRef, + BindingIndependentMappingService delegate) { this.bundleContext = Preconditions.checkNotNull(bundleContext); this.reference = Preconditions.checkNotNull(serviceRef); this.delegate = Preconditions.checkNotNull(delegate); @@ -132,47 +122,47 @@ public final class RuntimeMappingModule extends } @Override - public CompositeNode toDataDom(final DataObject data) { + public CompositeNode toDataDom(DataObject data) { return delegate.toDataDom(data); } @Override public Entry toDataDom( - final Entry, DataObject> entry) { + Entry, DataObject> entry) { return delegate.toDataDom(entry); } @Override public YangInstanceIdentifier toDataDom( - final org.opendaylight.yangtools.yang.binding.InstanceIdentifier path) { + org.opendaylight.yangtools.yang.binding.InstanceIdentifier path) { return delegate.toDataDom(path); } @Override public DataObject dataObjectFromDataDom( - final org.opendaylight.yangtools.yang.binding.InstanceIdentifier path, - final CompositeNode result) throws DeserializationException { + org.opendaylight.yangtools.yang.binding.InstanceIdentifier path, + CompositeNode result) throws DeserializationException { return delegate.dataObjectFromDataDom(path, result); } @Override - public org.opendaylight.yangtools.yang.binding.InstanceIdentifier fromDataDom(final YangInstanceIdentifier entry) + public org.opendaylight.yangtools.yang.binding.InstanceIdentifier fromDataDom(YangInstanceIdentifier entry) throws DeserializationException { return delegate.fromDataDom(entry); } @Override - public Set getRpcQNamesFor(final Class service) { + public Set getRpcQNamesFor(Class service) { return delegate.getRpcQNamesFor(service); } @Override - public Optional> getRpcServiceClassFor(final String namespace, final String revision) { + public Optional> getRpcServiceClassFor(String namespace, String revision) { return delegate.getRpcServiceClassFor(namespace,revision); } @Override - public DataContainer dataObjectFromDataDom(final Class inputClass, final CompositeNode domInput) { + public DataContainer dataObjectFromDataDom(Class inputClass, CompositeNode domInput) { return delegate.dataObjectFromDataDom(inputClass, domInput); }