Yuta HIGUCHI | a8a53eb | 2014-09-25 17:47:55 -0700 | [diff] [blame] | 1 | package org.onlab.onos.store.serializers; |
| 2 | |
| 3 | import org.onlab.onos.net.ConnectPoint; |
| 4 | import org.onlab.onos.net.LinkKey; |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 5 | |
Yuta HIGUCHI | a8a53eb | 2014-09-25 17:47:55 -0700 | [diff] [blame] | 6 | import com.esotericsoftware.kryo.Kryo; |
| 7 | import com.esotericsoftware.kryo.Serializer; |
| 8 | import com.esotericsoftware.kryo.io.Input; |
| 9 | import com.esotericsoftware.kryo.io.Output; |
| 10 | |
| 11 | /** |
| 12 | * Kryo Serializer for {@link LinkKey}. |
| 13 | */ |
| 14 | public class LinkKeySerializer extends Serializer<LinkKey> { |
| 15 | |
| 16 | /** |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 17 | * Creates {@link LinkKey} serializer instance. |
Yuta HIGUCHI | a8a53eb | 2014-09-25 17:47:55 -0700 | [diff] [blame] | 18 | */ |
| 19 | public LinkKeySerializer() { |
| 20 | // non-null, immutable |
| 21 | super(false, true); |
| 22 | } |
| 23 | |
| 24 | @Override |
| 25 | public void write(Kryo kryo, Output output, LinkKey object) { |
| 26 | kryo.writeClassAndObject(output, object.src()); |
| 27 | kryo.writeClassAndObject(output, object.dst()); |
| 28 | } |
| 29 | |
| 30 | @Override |
| 31 | public LinkKey read(Kryo kryo, Input input, Class<LinkKey> type) { |
| 32 | ConnectPoint src = (ConnectPoint) kryo.readClassAndObject(input); |
| 33 | ConnectPoint dst = (ConnectPoint) kryo.readClassAndObject(input); |
Yuta HIGUCHI | 18ab8a9 | 2014-10-13 11:16:19 -0700 | [diff] [blame] | 34 | return LinkKey.linkKey(src, dst); |
Yuta HIGUCHI | a8a53eb | 2014-09-25 17:47:55 -0700 | [diff] [blame] | 35 | } |
| 36 | } |