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=8f52edd651d79e9ae1a12df080a478098209816a;hp=4e6c7a5f7f2964dc8b4655c7a3d73d508409ae5a;hb=refs%2Fchanges%2F91%2F84091%2F17;hpb=769a4060e445ef39ed1c125bdc2c48ce59d1fbf9 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 4e6c7a5f7f..8f52edd651 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 @@ -7,11 +7,12 @@ */ package org.opendaylight.controller.md.sal.dom.api; +import static java.util.Objects.requireNonNull; + import com.google.common.base.MoreObjects; -import com.google.common.base.Preconditions; import java.util.Objects; -import javax.annotation.Nonnull; -import javax.annotation.Nullable; +import org.eclipse.jdt.annotation.NonNull; +import org.eclipse.jdt.annotation.Nullable; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; import org.opendaylight.yangtools.yang.model.api.SchemaPath; @@ -20,25 +21,29 @@ import org.opendaylight.yangtools.yang.model.api.SchemaPath; * always has global context. It allows an RPC to have a instance identifier * attached, so that there can be multiple implementations bound to different * contexts concurrently. + * + * @deprecated Use {@link org.opendaylight.mdsal.dom.api.DOMRpcIdentifier} instead. */ +@Deprecated public abstract class DOMRpcIdentifier { + private static final class Global extends DOMRpcIdentifier { - private Global(final @Nonnull SchemaPath type) { + private Global(final @NonNull SchemaPath type) { super(type); } @Override public YangInstanceIdentifier getContextReference() { - return null; + return YangInstanceIdentifier.empty(); } } private static final class Local extends DOMRpcIdentifier { private final YangInstanceIdentifier contextReference; - private Local(final @Nonnull SchemaPath type, final @Nonnull YangInstanceIdentifier contextReference) { + private Local(final @NonNull SchemaPath type, final @NonNull YangInstanceIdentifier contextReference) { super(type); - this.contextReference = Preconditions.checkNotNull(contextReference); + this.contextReference = requireNonNull(contextReference); } @Override @@ -50,7 +55,7 @@ public abstract class DOMRpcIdentifier { private final SchemaPath type; private DOMRpcIdentifier(final SchemaPath type) { - this.type = Preconditions.checkNotNull(type); + this.type = requireNonNull(type); } /** @@ -59,7 +64,7 @@ public abstract class DOMRpcIdentifier { * @param type RPC type, SchemaPath of its definition, may not be null * @return A global RPC identifier, guaranteed to be non-null. */ - public static @Nonnull DOMRpcIdentifier create(final @Nonnull SchemaPath type) { + public static @NonNull DOMRpcIdentifier create(final @NonNull SchemaPath type) { return new Global(type); } @@ -70,12 +75,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) { + 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()); } /** @@ -83,7 +96,7 @@ public abstract class DOMRpcIdentifier { * * @return RPC type. */ - public final @Nonnull SchemaPath getType() { + public final @NonNull SchemaPath getType() { return type; } @@ -92,14 +105,14 @@ public abstract class DOMRpcIdentifier { * * @return RPC context reference. */ - public abstract @Nullable YangInstanceIdentifier getContextReference(); + public abstract @NonNull YangInstanceIdentifier getContextReference(); @Override public final int hashCode() { 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; } @@ -120,6 +133,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(); } }