1 /* Copyright (C)2013 Pantheon Technologies, s.r.o. All rights reserved. */
\r
2 package org.openflow.lib.serialization;
\r
4 import io.netty.buffer.ByteBuf;
\r
6 import org.opendaylight.yangtools.yang.binding.DataObject;
\r
9 * @author michal.polkorab
\r
12 public class SerializationFactory {
\r
15 * Transforms POJO message into ByteBuf
\r
16 * @param version version used for encoding received message
\r
17 * @param out ByteBuf for storing and sending transformed message
\r
18 * @param message POJO message
\r
20 public static <E extends DataObject> void messageToBuffer(short version, ByteBuf out, E message) {
\r
21 @SuppressWarnings("unchecked")
\r
22 MessageTypeKey<E> msgTypeKey = new MessageTypeKey<E>(version, (Class<E>) message.getClass());
\r
23 OfSerializer<E> encoder = EncoderTable.getInstance().getEncoder(msgTypeKey);
\r
24 encoder.messageToBuffer(version, out, message);
\r
34 7: GET_CONFIG_REQUEST
\r
45 18: MULTIPART_REQUEST
\r
49 22: QUEUE_GET_CONFIG_REQUEST
\r
50 23: QUEUE_GET_CONFIG_REPLY
\r
53 26: GET_ASYNC_REQUEST
\r