X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-dom-broker%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fmd%2Fsal%2Fdom%2Fbroker%2Fimpl%2FPingPongDataBroker.java;h=994522fed3db4588b0cbf70f026bcaee7b46a032;hb=ae6c61499e2c7c76e0406ce397657cd31ddd4d3f;hp=715a13677af54e9796dfe076f4d7032cd361bc0a;hpb=d70f418d19fa09b1efc8fa4ce4ed35f0cf59b73b;p=controller.git diff --git a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/broker/impl/PingPongDataBroker.java b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/broker/impl/PingPongDataBroker.java index 715a13677a..994522fed3 100644 --- a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/broker/impl/PingPongDataBroker.java +++ b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/broker/impl/PingPongDataBroker.java @@ -7,20 +7,28 @@ */ package org.opendaylight.controller.md.sal.dom.broker.impl; -import com.google.common.base.Preconditions; -import javax.annotation.Nonnull; +import static java.util.Objects.requireNonNull; + +import org.eclipse.jdt.annotation.NonNull; import org.opendaylight.controller.md.sal.common.api.data.TransactionChainListener; import org.opendaylight.controller.md.sal.dom.api.DOMDataBroker; +import org.opendaylight.controller.md.sal.dom.api.DOMDataTreeChangeListener; +import org.opendaylight.controller.md.sal.dom.api.DOMDataTreeChangeService; +import org.opendaylight.controller.md.sal.dom.api.DOMDataTreeIdentifier; import org.opendaylight.controller.md.sal.dom.spi.ForwardingDOMDataBroker; +import org.opendaylight.yangtools.concepts.ListenerRegistration; /** * An implementation of a {@link DOMDataBroker}, which forwards most requests to a delegate. * + *

* Its interpretation of the API contract is somewhat looser, specifically it does not * guarantee transaction ordering between transactions allocated directly from the broker * and its transaction chains. */ -public final class PingPongDataBroker extends ForwardingDOMDataBroker implements AutoCloseable { +@Deprecated(forRemoval = true) +public final class PingPongDataBroker extends ForwardingDOMDataBroker implements AutoCloseable, + DOMDataTreeChangeService { private final DOMDataBroker delegate; /** @@ -29,8 +37,8 @@ public final class PingPongDataBroker extends ForwardingDOMDataBroker implements * * @param delegate Backend broker, may not be null. */ - public PingPongDataBroker(final @Nonnull DOMDataBroker delegate) { - this.delegate = Preconditions.checkNotNull(delegate); + public PingPongDataBroker(final @NonNull DOMDataBroker delegate) { + this.delegate = requireNonNull(delegate); } @Override @@ -45,6 +53,23 @@ public final class PingPongDataBroker extends ForwardingDOMDataBroker implements @Override public void close() { - // TODO Auto-generated method stub + // intentionally NOOP + } + + @Override + public ListenerRegistration registerDataTreeChangeListener( + final DOMDataTreeIdentifier treeId, final L listener) { + final DOMDataTreeChangeService treeService = (DOMDataTreeChangeService) delegate.getSupportedExtensions() + .get(DOMDataTreeChangeService.class); + if (treeService != null) { + return treeService.registerDataTreeChangeListener(treeId, listener); + } + + throw new UnsupportedOperationException("Delegate " + delegate + " does not support required functionality"); + } + + @Override + public String toString() { + return "PingPongDataBroker backed by " + delegate; } }