Remove trailing whitespace
[openflowjava.git] / openflow-protocol-api / src / main / java / org / opendaylight / openflowjava / protocol / api / extensibility / DeserializerExtensionProvider.java
index b821b168dd4f3f5e7948b1adeeab289cfbf6e56c..516113b8e7989dc81ef7f96ed71dea08350b351b 100644 (file)
-/*\r
- * Copyright (c) 2014 Pantheon Technologies s.r.o. and others. All rights reserved.\r
- *\r
- * This program and the accompanying materials are made available under the\r
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,\r
- * and is available at http://www.eclipse.org/legal/epl-v10.html\r
- */\r
-\r
-package org.opendaylight.openflowjava.protocol.api.extensibility;\r
-\r
-import org.opendaylight.openflowjava.protocol.api.keys.MatchEntryDeserializerKey;\r
-import org.opendaylight.openflowjava.protocol.api.keys.experimenter.ExperimenterActionDeserializerKey;\r
-import org.opendaylight.openflowjava.protocol.api.keys.experimenter.ExperimenterDeserializerKey;\r
-import org.opendaylight.openflowjava.protocol.api.keys.experimenter.ExperimenterInstructionDeserializerKey;\r
-\r
-/**\r
- * Provides methods for deserialization part of extensibility\r
- * @author michal.polkorab\r
- */\r
-public interface DeserializerExtensionProvider {\r
-\r
-    /**\r
-     * Unregisters custom deserializer\r
-     * @param key used for deserializer lookup\r
-     * @return true if deserializer was removed,\r
-     *  false if no deserializer was found under specified key\r
-     */\r
-    public boolean unregisterDeserializer(ExperimenterDeserializerKey key);\r
-\r
-    /**\r
-     * Registers action deserializer\r
-     * @param key used for deserializer lookup\r
-     * @param deserializer deserializer instance\r
-     */\r
-    public void registerActionDeserializer(ExperimenterActionDeserializerKey key,\r
-            OFGeneralDeserializer deserializer);\r
-\r
-    /**\r
-     * Registers instruction deserializer\r
-     * @param key used for deserializer lookup\r
-     * @param deserializer deserializer instance\r
-     */\r
-    public void registerInstructionDeserializer(ExperimenterInstructionDeserializerKey key,\r
-            OFGeneralDeserializer deserializer);\r
-\r
-    /**\r
-     * Registers match entry deserializer\r
-     * @param key used for deserializer lookup\r
-     * @param deserializer deserializer instance\r
-     */\r
-    public void registerMatchEntryDeserializer(MatchEntryDeserializerKey key,\r
-            OFGeneralDeserializer deserializer);\r
-}\r
+/*
+ * Copyright (c) 2014 Pantheon Technologies s.r.o. and others. All rights reserved.
+ *
+ * This program and the accompanying materials are made available under the
+ * terms of the Eclipse Public License v1.0 which accompanies this distribution,
+ * and is available at http://www.eclipse.org/legal/epl-v10.html
+ */
+
+package org.opendaylight.openflowjava.protocol.api.extensibility;
+
+import org.opendaylight.openflowjava.protocol.api.keys.MatchEntryDeserializerKey;
+import org.opendaylight.openflowjava.protocol.api.keys.experimenter.ExperimenterActionDeserializerKey;
+import org.opendaylight.openflowjava.protocol.api.keys.experimenter.ExperimenterDeserializerKey;
+import org.opendaylight.openflowjava.protocol.api.keys.experimenter.ExperimenterIdDeserializerKey;
+import org.opendaylight.openflowjava.protocol.api.keys.experimenter.ExperimenterInstructionDeserializerKey;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.ErrorMessage;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.ExperimenterMessage;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartReplyMessage;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.meter.band.header.meter.band.MeterBandExperimenterCase;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.queue.property.header.QueueProperty;
+
+/**
+ * Provides methods for deserialization part of extensibility.
+ * In case of handling multiple multiple structures of same type (actions,
+ * instructions, match entries, ... ) which are differentiated by
+ * vendor / experimenter subtype, vendor has to switch / choose between
+ * these subtypes. <br />
+ *
+ * This has to be done in this way because of experimenter headers, which
+ * provide only vendor / experimenter ID. Subtype position may be different
+ * for different vendors (or not present at all) - that's why vendor has to
+ * handle it in his own implementations.
+ * @author michal.polkorab
+ */
+public interface DeserializerExtensionProvider {
+
+    /**
+     * Unregisters custom deserializer
+     * @param key used for deserializer lookup
+     * @return true if deserializer was removed,
+     *  false if no deserializer was found under specified key
+     */
+    boolean unregisterDeserializer(ExperimenterDeserializerKey key);
+
+    /**
+     * Registers action deserializer
+     * @param key used for deserializer lookup
+     * @param deserializer deserializer instance
+     */
+    void registerActionDeserializer(ExperimenterActionDeserializerKey key,
+            OFGeneralDeserializer deserializer);
+
+    /**
+     * Registers instruction deserializer
+     * @param key used for deserializer lookup
+     * @param deserializer deserializer instance
+     */
+    void registerInstructionDeserializer(ExperimenterInstructionDeserializerKey key,
+            OFGeneralDeserializer deserializer);
+
+    /**
+     * Registers match entry deserializer
+     * @param key used for deserializer lookup
+     * @param deserializer deserializer instance
+     */
+    void registerMatchEntryDeserializer(MatchEntryDeserializerKey key,
+            OFGeneralDeserializer deserializer);
+
+    /**
+     * Registers error message deserializer
+     * @param key used for deserializer lookup
+     * @param deserializer deserializer instance
+     */
+    void registerErrorDeserializer(ExperimenterIdDeserializerKey key,
+            OFDeserializer<ErrorMessage> deserializer);
+
+    /**
+     * Registers experimenter (vendor) message deserializer
+     * @param key used for deserializer lookup
+     * @param deserializer deserializer instance
+     */
+    void registerExperimenterMessageDeserializer(ExperimenterIdDeserializerKey key,
+            OFDeserializer<ExperimenterMessage> deserializer);
+
+    /**
+     * Registers multipart-reply (stats) message deserializer
+     * @param key used for deserializer lookup
+     * @param deserializer deserializer instance
+     */
+    void registerMultipartReplyMessageDeserializer(ExperimenterIdDeserializerKey key,
+            OFDeserializer<MultipartReplyMessage> deserializer);
+
+    /**
+     * Registers multipart-reply table-features message deserializer
+     * @param key used for deserializer lookup
+     * @param deserializer deserializer instance
+     */
+    void registerMultipartReplyTFDeserializer(ExperimenterIdDeserializerKey key,
+            OFGeneralDeserializer deserializer);
+
+    /**
+     * Registers meter band deserializer (used in multipart-reply meter-config)
+     * @param key used for deserializer lookup
+     * @param deserializer deserializer instance
+     */
+    void registerMeterBandDeserializer(ExperimenterIdDeserializerKey key,
+            OFDeserializer<MeterBandExperimenterCase> deserializer);
+
+    /**
+     * Registers queue property (QUEUE_GET_CONFIG_REPLY message) deserializer
+     * @param key used for deserializer lookup
+     * @param deserializer deserializer instance
+     */
+    void registerQueuePropertyDeserializer(ExperimenterIdDeserializerKey key,
+            OFDeserializer<QueueProperty> deserializer);
+}
\ No newline at end of file