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%2Fmd%2Fsal%2Fbinding%2Fimpl%2FBindingDOMNotificationServiceAdapter.java;h=cdf03fa5527d76c911cccb30cc6b40b586f08b6f;hp=6006266cc2d07a2745dca15b6b596415f1a14c9c;hb=123daf0f2b4f600d30c460fe9729ab925b96b545;hpb=745d7a11635b81af7b4e1f1303db071c6c6b198d diff --git a/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/BindingDOMNotificationServiceAdapter.java b/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/BindingDOMNotificationServiceAdapter.java index 6006266cc2..cdf03fa552 100644 --- a/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/BindingDOMNotificationServiceAdapter.java +++ b/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/BindingDOMNotificationServiceAdapter.java @@ -9,13 +9,9 @@ package org.opendaylight.controller.md.sal.binding.impl; import com.google.common.collect.ClassToInstanceMap; import com.google.common.collect.ImmutableSet; -import java.util.ArrayList; -import java.util.Collection; -import java.util.List; import java.util.Set; import org.opendaylight.controller.md.sal.binding.api.NotificationService; import org.opendaylight.controller.md.sal.binding.impl.BindingDOMAdapterBuilder.Factory; -import org.opendaylight.controller.md.sal.dom.api.DOMNotificationListener; import org.opendaylight.controller.md.sal.dom.api.DOMNotificationService; import org.opendaylight.controller.md.sal.dom.api.DOMService; import org.opendaylight.controller.sal.binding.codegen.impl.SingletonHolder; @@ -23,10 +19,7 @@ import org.opendaylight.controller.sal.binding.spi.NotificationInvokerFactory; import org.opendaylight.yangtools.binding.data.codec.api.BindingNormalizedNodeSerializer; import org.opendaylight.yangtools.concepts.AbstractListenerRegistration; import org.opendaylight.yangtools.concepts.ListenerRegistration; -import org.opendaylight.yangtools.yang.binding.Notification; import org.opendaylight.yangtools.yang.binding.NotificationListener; -import org.opendaylight.yangtools.yang.binding.util.BindingReflections; -import org.opendaylight.yangtools.yang.model.api.SchemaPath; public class BindingDOMNotificationServiceAdapter implements NotificationService, AutoCloseable { @@ -40,34 +33,20 @@ public class BindingDOMNotificationServiceAdapter implements NotificationService }; private final BindingNormalizedNodeSerializer codec; private final DOMNotificationService domNotifService; - private final NotificationInvokerFactory notificationInvokerFactory; public BindingDOMNotificationServiceAdapter(final BindingNormalizedNodeSerializer codec, final DOMNotificationService domNotifService, final NotificationInvokerFactory notificationInvokerFactory) { this.codec = codec; this.domNotifService = domNotifService; - this.notificationInvokerFactory = notificationInvokerFactory; } @Override public ListenerRegistration registerNotificationListener(final T listener) { - final NotificationInvokerFactory.NotificationInvoker invoker = notificationInvokerFactory.invokerFor(listener); - final DOMNotificationListener domListener = new BindingDOMNotificationListenerAdapter(codec, invoker); - final Collection schemaPaths = convertNotifTypesToSchemaPath(invoker.getSupportedNotifications()); - final ListenerRegistration domRegistration = - domNotifService.registerNotificationListener(domListener, schemaPaths); + final BindingDOMNotificationListenerAdapter domListener = new BindingDOMNotificationListenerAdapter(codec, listener); + final ListenerRegistration domRegistration = + domNotifService.registerNotificationListener(domListener, domListener.getSupportedNotifications()); return new ListenerRegistrationImpl<>(listener, domRegistration); } - - - private Collection convertNotifTypesToSchemaPath(final Set> notificationTypes) { - final List schemaPaths = new ArrayList<>(); - for (final Class notificationType : notificationTypes) { - schemaPaths.add(SchemaPath.create(true, BindingReflections.findQName(notificationType))); - } - return schemaPaths; - } - @Override public void close() throws Exception { @@ -89,7 +68,6 @@ public class BindingDOMNotificationServiceAdapter implements NotificationService private static class Builder extends BindingDOMAdapterBuilder { - @Override protected NotificationService createInstance(final BindingToNormalizedNodeCodec codec, final ClassToInstanceMap delegates) { @@ -102,8 +80,5 @@ public class BindingDOMNotificationServiceAdapter implements NotificationService public Set> getRequiredDelegates() { return ImmutableSet.of(DOMNotificationService.class); } - - - } }