X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-dom-api%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fmd%2Fsal%2Fdom%2Fapi%2FDOMRpcIdentifier.java;h=63e646debd7a884699c73ff4fb881d851ec8892e;hp=671671c90514691c1f1b8f8b1afd6c003678a2a7;hb=e1ede0942d3bff1f1b150816e6bfa96ed9366c20;hpb=0dcdc14a4ff38b39fed0d07658941a09a4c043fd;ds=sidebyside diff --git a/opendaylight/md-sal/sal-dom-api/src/main/java/org/opendaylight/controller/md/sal/dom/api/DOMRpcIdentifier.java b/opendaylight/md-sal/sal-dom-api/src/main/java/org/opendaylight/controller/md/sal/dom/api/DOMRpcIdentifier.java index 671671c905..63e646debd 100644 --- a/opendaylight/md-sal/sal-dom-api/src/main/java/org/opendaylight/controller/md/sal/dom/api/DOMRpcIdentifier.java +++ b/opendaylight/md-sal/sal-dom-api/src/main/java/org/opendaylight/controller/md/sal/dom/api/DOMRpcIdentifier.java @@ -9,12 +9,10 @@ package org.opendaylight.controller.md.sal.dom.api; import com.google.common.base.MoreObjects; import com.google.common.base.Preconditions; -import java.util.Collections; import java.util.Objects; import javax.annotation.Nonnull; import javax.annotation.Nullable; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; -import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument; import org.opendaylight.yangtools.yang.model.api.SchemaPath; /** @@ -25,8 +23,6 @@ import org.opendaylight.yangtools.yang.model.api.SchemaPath; */ public abstract class DOMRpcIdentifier { - private static final YangInstanceIdentifier GLOBAL_CONTEXT = YangInstanceIdentifier.create(Collections.emptySet()); - private static final class Global extends DOMRpcIdentifier { private Global(final @Nonnull SchemaPath type) { super(type); @@ -34,7 +30,7 @@ public abstract class DOMRpcIdentifier { @Override public YangInstanceIdentifier getContextReference() { - return GLOBAL_CONTEXT; + return YangInstanceIdentifier.EMPTY; } } @@ -75,12 +71,20 @@ public abstract class DOMRpcIdentifier { * @param contextReference Context reference, null means a global RPC identifier. * @return A global RPC identifier, guaranteed to be non-null. */ - public static @Nonnull DOMRpcIdentifier create(final @Nonnull SchemaPath type, final @Nullable YangInstanceIdentifier contextReference) { - if (contextReference == null || GLOBAL_CONTEXT.equals(contextReference)) { + public static @Nonnull DOMRpcIdentifier create(final @Nonnull SchemaPath type, + final @Nullable YangInstanceIdentifier contextReference) { + if (contextReference == null || contextReference.isEmpty()) { return new Global(type); - } else { - return new Local(type, contextReference); } + return new Local(type, contextReference); + } + + public static DOMRpcIdentifier fromMdsal(final org.opendaylight.mdsal.dom.api.DOMRpcIdentifier mdsal) { + return create(mdsal.getType(), mdsal.getContextReference()); + } + + public org.opendaylight.mdsal.dom.api.DOMRpcIdentifier toMdsal() { + return org.opendaylight.mdsal.dom.api.DOMRpcIdentifier.create(type, getContextReference()); } /** @@ -104,7 +108,7 @@ public abstract class DOMRpcIdentifier { final int prime = 31; int result = 1; result = prime * result + type.hashCode(); - result = prime * result + (getContextReference() == null ? 0 : getContextReference().hashCode()); + result = prime * result + getContextReference().hashCode(); return result; } @@ -125,6 +129,7 @@ public abstract class DOMRpcIdentifier { @Override public final String toString() { - return MoreObjects.toStringHelper(this).omitNullValues().add("type", type).add("contextReference", getContextReference()).toString(); + return MoreObjects.toStringHelper(this).omitNullValues().add("type", type).add("contextReference", + getContextReference()).toString(); } }