X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2Fmessages%2FVersionedExternalizableMessage.java;h=9548a7ebdc7d4432c6e162915f8e353c04dc4477;hp=622485b09ea58dce6e11c6dd1f78d49a62592106;hb=HEAD;hpb=10006bbb875a6b90e14bda6b8c32d4d801dd228c diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/VersionedExternalizableMessage.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/VersionedExternalizableMessage.java index 622485b09e..9548a7ebdc 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/VersionedExternalizableMessage.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/VersionedExternalizableMessage.java @@ -13,32 +13,39 @@ import java.io.ObjectInput; import java.io.ObjectOutput; import org.eclipse.jdt.annotation.NonNull; import org.opendaylight.controller.cluster.datastore.DataStoreVersions; -import org.opendaylight.controller.cluster.datastore.node.utils.stream.NormalizedNodeStreamVersion; +import org.opendaylight.yangtools.yang.data.codec.binfmt.NormalizedNodeStreamVersion; /** * Abstract base class for a versioned Externalizable message. * * @author Thomas Pantelis */ +@Deprecated(since = "9.0.0", forRemoval = true) public abstract class VersionedExternalizableMessage implements Externalizable, SerializableMessage { private static final long serialVersionUID = 1L; private short version = DataStoreVersions.CURRENT_VERSION; public VersionedExternalizableMessage() { + // Required for externalizable } public VersionedExternalizableMessage(final short version) { this.version = version <= DataStoreVersions.CURRENT_VERSION ? version : DataStoreVersions.CURRENT_VERSION; } - public short getVersion() { + public final short getVersion() { return version; } protected final @NonNull NormalizedNodeStreamVersion getStreamVersion() { - return version < DataStoreVersions.NEON_SR2_VERSION - ? NormalizedNodeStreamVersion.LITHIUM : NormalizedNodeStreamVersion.NEON_SR2; + if (version >= DataStoreVersions.POTASSIUM_VERSION) { + return NormalizedNodeStreamVersion.POTASSIUM; + } else if (version >= DataStoreVersions.PHOSPHORUS_VERSION) { + return NormalizedNodeStreamVersion.MAGNESIUM; + } else { + throw new IllegalStateException("Unsupported version " + version); + } } @Override @@ -54,9 +61,9 @@ public abstract class VersionedExternalizableMessage implements Externalizable, @Override public final Object toSerializable() { final short ver = getVersion(); - if (ver < DataStoreVersions.BORON_VERSION) { + if (ver < DataStoreVersions.SODIUM_SR1_VERSION) { throw new UnsupportedOperationException("Version " + ver - + " is older than the oldest version supported version " + DataStoreVersions.BORON_VERSION); + + " is older than the oldest version supported version " + DataStoreVersions.SODIUM_SR1_VERSION); } return this;