X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-clustering-commons%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2Fnode%2Futils%2Fstream%2FNormalizedNodeInputOutput.java;h=bcb4cbf16f569c3584f10e28d04a6b88059162c1;hb=11666b718f70c7846cd64ebf949a4e91d84e0e65;hp=5ad195a9b7cd207842a859ef6b78d139dc6f76f1;hpb=b4bf55727093657662d8c16a50fa85f87978a586;p=controller.git diff --git a/opendaylight/md-sal/sal-clustering-commons/src/main/java/org/opendaylight/controller/cluster/datastore/node/utils/stream/NormalizedNodeInputOutput.java b/opendaylight/md-sal/sal-clustering-commons/src/main/java/org/opendaylight/controller/cluster/datastore/node/utils/stream/NormalizedNodeInputOutput.java index 5ad195a9b7..bcb4cbf16f 100644 --- a/opendaylight/md-sal/sal-clustering-commons/src/main/java/org/opendaylight/controller/cluster/datastore/node/utils/stream/NormalizedNodeInputOutput.java +++ b/opendaylight/md-sal/sal-clustering-commons/src/main/java/org/opendaylight/controller/cluster/datastore/node/utils/stream/NormalizedNodeInputOutput.java @@ -28,18 +28,7 @@ public final class NormalizedNodeInputOutput { * @throws IOException if an error occurs reading from the input */ public static NormalizedNodeDataInput newDataInput(final @NonNull DataInput input) throws IOException { - final byte marker = input.readByte(); - if (marker != TokenTypes.SIGNATURE_MARKER) { - throw new InvalidNormalizedNodeStreamException(String.format("Invalid signature marker: %d", marker)); - } - - final short version = input.readShort(); - switch (version) { - case TokenTypes.LITHIUM_VERSION: - return new NormalizedNodeInputStreamReader(input, true); - default: - throw new InvalidNormalizedNodeStreamException(String.format("Unhandled stream version %s", version)); - } + return new VersionedNormalizedNodeDataInput(input).delegate(); } /** @@ -50,11 +39,12 @@ public final class NormalizedNodeInputOutput { * @return a new {@link NormalizedNodeDataInput} instance */ public static NormalizedNodeDataInput newDataInputWithoutValidation(final @NonNull DataInput input) { - return new NormalizedNodeInputStreamReader(input, false); + return new VersionedNormalizedNodeDataInput(input); } /** - * Creates a new {@link NormalizedNodeDataOutput} instance that writes to the given output. + * Creates a new {@link NormalizedNodeDataOutput} instance that writes to the given output and latest current + * stream version. * * @param output the DataOutput to write to * @return a new {@link NormalizedNodeDataOutput} instance @@ -62,4 +52,24 @@ public final class NormalizedNodeInputOutput { public static NormalizedNodeDataOutput newDataOutput(final @NonNull DataOutput output) { return new NormalizedNodeOutputStreamWriter(output); } + + /** + * Creates a new {@link NormalizedNodeDataOutput} instance that writes to the given output. + * + * @param output the DataOutput to write to + * @param version Streaming version to use + * @return a new {@link NormalizedNodeDataOutput} instance + */ + public static NormalizedNodeDataOutput newDataOutput(final @NonNull DataOutput output, + final @NonNull NormalizedNodeStreamVersion version) { + switch (version) { + case LITHIUM: + return new LithiumNormalizedNodeOutputStreamWriter(output); + case SODIUM: + return new SodiumNormalizedNodeOutputStreamWriter(output); + default: + throw new IllegalStateException("Unhandled version " + version); + } + } + }