Committed by
Jonathan Hart
Added kryo serializer for ImmutableByteSequence
Serialization was failing when the inner ByteBuffer instance was a HeapByteBuffer. Also, simplified ImmutableByteSequence.toString() Change-Id: I4f75086a9b6536205fb43b78a0e4d2bfce9e8a5c
Showing
3 changed files
with
54 additions
and
5 deletions
| 1 | +/* | ||
| 2 | + * Copyright 2016-present Open Networking Laboratory | ||
| 3 | + * | ||
| 4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
| 5 | + * you may not use this file except in compliance with the License. | ||
| 6 | + * You may obtain a copy of the License at | ||
| 7 | + * | ||
| 8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
| 9 | + * | ||
| 10 | + * Unless required by applicable law or agreed to in writing, software | ||
| 11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
| 12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
| 13 | + * See the License for the specific language governing permissions and | ||
| 14 | + * limitations under the License. | ||
| 15 | + */ | ||
| 16 | + | ||
| 17 | +package org.onosproject.store.serializers; | ||
| 18 | + | ||
| 19 | +import com.esotericsoftware.kryo.Kryo; | ||
| 20 | +import com.esotericsoftware.kryo.Serializer; | ||
| 21 | +import com.esotericsoftware.kryo.io.Input; | ||
| 22 | +import com.esotericsoftware.kryo.io.Output; | ||
| 23 | +import org.onlab.util.ImmutableByteSequence; | ||
| 24 | + | ||
| 25 | +/** | ||
| 26 | + * Kryo serializer for {@link ImmutableByteSequence}. | ||
| 27 | + */ | ||
| 28 | +public class ImmutableByteSequenceSerializer extends Serializer<ImmutableByteSequence> { | ||
| 29 | + | ||
| 30 | + /** | ||
| 31 | + * Creates a new {@link ImmutableByteSequence} serializer instance. | ||
| 32 | + */ | ||
| 33 | + public ImmutableByteSequenceSerializer() { | ||
| 34 | + // non-null, immutable. | ||
| 35 | + super(false, true); | ||
| 36 | + } | ||
| 37 | + | ||
| 38 | + @Override | ||
| 39 | + public void write(Kryo kryo, Output output, ImmutableByteSequence object) { | ||
| 40 | + byte[] data = object.asArray(); | ||
| 41 | + output.writeInt(data.length); | ||
| 42 | + output.write(data); | ||
| 43 | + } | ||
| 44 | + | ||
| 45 | + @Override | ||
| 46 | + public ImmutableByteSequence read(Kryo kryo, Input input, Class<ImmutableByteSequence> type) { | ||
| 47 | + int length = input.readInt(); | ||
| 48 | + byte[] data = new byte[length]; | ||
| 49 | + input.read(data); | ||
| 50 | + return ImmutableByteSequence.copyFrom(data); | ||
| 51 | + } | ||
| 52 | +} |
| ... | @@ -537,7 +537,7 @@ public final class KryoNamespaces { | ... | @@ -537,7 +537,7 @@ public final class KryoNamespaces { |
| 537 | ) | 537 | ) |
| 538 | .register(ClosedOpenRange.class) | 538 | .register(ClosedOpenRange.class) |
| 539 | .register(DiscreteResourceCodec.class) | 539 | .register(DiscreteResourceCodec.class) |
| 540 | - .register(ImmutableByteSequence.class) | 540 | + .register(new ImmutableByteSequenceSerializer(), ImmutableByteSequence.class) |
| 541 | .build("API"); | 541 | .build("API"); |
| 542 | 542 | ||
| 543 | 543 | ... | ... |
| ... | @@ -16,7 +16,6 @@ | ... | @@ -16,7 +16,6 @@ |
| 16 | 16 | ||
| 17 | package org.onlab.util; | 17 | package org.onlab.util; |
| 18 | 18 | ||
| 19 | -import com.google.common.base.MoreObjects; | ||
| 20 | import com.google.common.base.Objects; | 19 | import com.google.common.base.Objects; |
| 21 | 20 | ||
| 22 | import java.nio.ByteBuffer; | 21 | import java.nio.ByteBuffer; |
| ... | @@ -238,8 +237,6 @@ public final class ImmutableByteSequence { | ... | @@ -238,8 +237,6 @@ public final class ImmutableByteSequence { |
| 238 | 237 | ||
| 239 | @Override | 238 | @Override |
| 240 | public String toString() { | 239 | public String toString() { |
| 241 | - return MoreObjects.toStringHelper(this) | 240 | + return HexString.toHexString(value.array()); |
| 242 | - .addValue(HexString.toHexString(asArray())) | ||
| 243 | - .toString(); | ||
| 244 | } | 241 | } |
| 245 | } | 242 | } |
| ... | \ No newline at end of file | ... | \ No newline at end of file | ... | ... |
-
Please register or login to post a comment