X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;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=0f0ce0dc9dd24fb41bc54bde70c196ba2d4d511e;hp=1bf15c182f5f93196fe0c3d27fc0438295df2812;hb=b2f1e02e9c650f9c9dbbe8eb5b7fa52210276866;hpb=a35fe9ae149bd4c7089d48665ccc8bff580bce53 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 1bf15c182f..0f0ce0dc9d 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 @@ -1,19 +1,35 @@ -/** - * Generated file - - * Generated from: yang module name: opendaylight-sal-binding-broker-impl yang module local name: runtime-generated-mapping - * Generated by: org.opendaylight.controller.config.yangjmxgenerator.plugin.JMXGenerator - * Generated at: Wed Nov 20 18:20:19 CET 2013 +/* + * Copyright (c) 2014 Cisco Systems, Inc. and others. All rights reserved. * - * Do not modify this file unless it is present under src/main directory + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v1.0 which accompanies this distribution, + * and is available at http://www.eclipse.org/legal/epl-v10.html */ package org.opendaylight.controller.config.yang.md.sal.binding.impl; -import javassist.ClassPool; +import java.util.Hashtable; +import java.util.Map.Entry; +import java.util.Set; -import org.opendaylight.controller.sal.binding.dom.serializer.impl.RuntimeGeneratedMappingServiceImpl; +import org.opendaylight.controller.sal.binding.codegen.impl.SingletonHolder; +import org.opendaylight.yangtools.concepts.Delegator; +import org.opendaylight.yangtools.sal.binding.generator.impl.RuntimeGeneratedMappingServiceImpl; +import org.opendaylight.yangtools.yang.binding.DataContainer; +import org.opendaylight.yangtools.yang.binding.DataObject; +import org.opendaylight.yangtools.yang.binding.RpcService; +import org.opendaylight.yangtools.yang.common.QName; +import org.opendaylight.yangtools.yang.data.api.CompositeNode; +import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier; +import org.opendaylight.yangtools.yang.data.impl.codec.BindingIndependentMappingService; +import org.opendaylight.yangtools.yang.data.impl.codec.CodecRegistry; +import org.opendaylight.yangtools.yang.data.impl.codec.DeserializationException; +import org.opendaylight.yangtools.yang.model.api.SchemaServiceListener; import org.osgi.framework.BundleContext; +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; /** @@ -22,6 +38,8 @@ import com.google.common.base.Preconditions; public final class RuntimeMappingModule extends org.opendaylight.controller.config.yang.md.sal.binding.impl.AbstractRuntimeMappingModule { + private static final Logger LOG = LoggerFactory.getLogger(RuntimeMappingModule.class); + private BundleContext bundleContext; public RuntimeMappingModule(org.opendaylight.controller.config.api.ModuleIdentifier identifier, @@ -49,13 +67,30 @@ public final class RuntimeMappingModule extends @Override public java.lang.AutoCloseable createInstance() { - RuntimeGeneratedMappingServiceImpl service = new RuntimeGeneratedMappingServiceImpl(); - ClassPool pool = new ClassPool(); // Should be default singleton - service.setPool(pool); - service.start(getBundleContext()); + + RuntimeGeneratedMappingServiceProxy potential = tryToReuseGlobalInstance(); + if(potential != null) { + return potential; + } + + final RuntimeGeneratedMappingServiceImpl service = new RuntimeGeneratedMappingServiceImpl(SingletonHolder.CLASS_POOL); + bundleContext.registerService(SchemaServiceListener.class, service, new Hashtable()); return service; } + private RuntimeGeneratedMappingServiceProxy tryToReuseGlobalInstance() { + ServiceReference serviceRef = getBundleContext().getServiceReference(BindingIndependentMappingService.class); + if(serviceRef == null) { + return null; + } + + BindingIndependentMappingService delegate = bundleContext.getService(serviceRef); + if (delegate == null) { + return null; + } + return new RuntimeGeneratedMappingServiceProxy(getBundleContext(),serviceRef,delegate); + } + private BundleContext getBundleContext() { return bundleContext; } @@ -63,4 +98,94 @@ public final class RuntimeMappingModule extends public void setBundleContext(BundleContext bundleContext) { this.bundleContext = bundleContext; } + + private static final class RuntimeGeneratedMappingServiceProxy implements // + BindingIndependentMappingService, // + Delegator, // + AutoCloseable { + + private BindingIndependentMappingService delegate; + private ServiceReference reference; + private BundleContext bundleContext; + + public RuntimeGeneratedMappingServiceProxy(BundleContext bundleContext, + ServiceReference serviceRef, + BindingIndependentMappingService delegate) { + this.bundleContext = Preconditions.checkNotNull(bundleContext); + this.reference = Preconditions.checkNotNull(serviceRef); + this.delegate = Preconditions.checkNotNull(delegate); + } + + @Override + public CodecRegistry getCodecRegistry() { + return delegate.getCodecRegistry(); + } + + @Override + public CompositeNode toDataDom(DataObject data) { + return delegate.toDataDom(data); + } + + @Override + public Entry toDataDom( + Entry, DataObject> entry) { + return delegate.toDataDom(entry); + } + + @Override + public InstanceIdentifier toDataDom( + org.opendaylight.yangtools.yang.binding.InstanceIdentifier path) { + return delegate.toDataDom(path); + } + + @Override + public DataObject dataObjectFromDataDom( + 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(InstanceIdentifier entry) + throws DeserializationException { + return delegate.fromDataDom(entry); + } + + @Override + public Set getRpcQNamesFor(Class service) { + return delegate.getRpcQNamesFor(service); + } + + @Override + public Optional> getRpcServiceClassFor(String namespace, String revision) { + return delegate.getRpcServiceClassFor(namespace,revision); + } + + @Override + public DataContainer dataObjectFromDataDom(Class inputClass, CompositeNode domInput) { + return delegate.dataObjectFromDataDom(inputClass, domInput); + } + + @Override + public void close() { + if(delegate != null) { + delegate = null; + + try { + bundleContext.ungetService(reference); + } catch (IllegalStateException e) { + // Indicates the BundleContext is no longer valid which can happen normally on shutdown. + LOG.debug( "Error unregistering service", e ); + } + + bundleContext= null; + reference = null; + } + } + + @Override + public BindingIndependentMappingService getDelegate() { + return delegate; + } + } }