SERIALIZER_TYPE getDeserializer(MessageCodeKey key);\r
\r
/**\r
- * Registers deserializer\r
+ * Registers deserializer.\r
+ * Throws IllegalStateException when there is\r
+ * a deserializer already registered under given key.\r
+ * \r
+ * If the deserializer implements {@link DeserializerRegistryInjector} interface,\r
+ * the deserializer is injected with DeserializerRegistry instance.\r
+ * \r
* @param key used for deserializer lookup\r
* @param deserializer deserializer instance\r
*/\r
\r
/**\r
* Registers serializer\r
+ * Throws IllegalStateException when there is\r
+ * a serializer already registered under given key.\r
+ * \r
+ * If the serializer implements {@link SerializerRegistryInjector} interface,\r
+ * the serializer is injected with SerializerRegistry instance.\r
+ * \r
* @param key used for serializer lookup\r
* @param serializer serializer implementation\r
*/\r
import org.opendaylight.openflowjava.protocol.impl.util.OF10MatchDeserializer;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.match.grouping.Match;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.match.v10.grouping.MatchV10;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
/**
* Stores and registers deserializers
*/
public class DeserializerRegistryImpl implements DeserializerRegistry {
+ private static final Logger LOGGER = LoggerFactory.getLogger(DeserializerRegistryImpl.class);
private Map<MessageCodeKey, OFGeneralDeserializer> registry;
/**
if ((key == null) || (deserializer == null)) {
throw new IllegalArgumentException("MessageCodeKey or Deserializer is null");
}
+ OFGeneralDeserializer desInRegistry = registry.put(key, deserializer);
+ if (desInRegistry != null) {
+ LOGGER.warn("Deserializer for key " + key + " overwritten. Old deserializer: "
+ + desInRegistry.getClass().getName() + ", new deserializer: "
+ + deserializer.getClass().getName() );
+ }
if (deserializer instanceof DeserializerRegistryInjector) {
((DeserializerRegistryInjector) deserializer).injectDeserializerRegistry(this);
}
- registry.put(key, deserializer);
}
@Override
import org.opendaylight.openflowjava.protocol.impl.util.OF13MatchSerializer;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.match.grouping.Match;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.match.v10.grouping.MatchV10;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
/**
* Stores and handles serializers
*/
public class SerializerRegistryImpl implements SerializerRegistry {
+ private static final Logger LOGGER = LoggerFactory.getLogger(SerializerRegistryImpl.class);
private static final short OF10 = EncodeConstants.OF10_VERSION_ID;
private static final short OF13 = EncodeConstants.OF13_VERSION_ID;
private Map<MessageTypeKey<?>, OFGeneralSerializer> registry;
if ((msgTypeKey == null) || (serializer == null)) {
throw new IllegalArgumentException("MessageTypeKey or Serializer is null");
}
+ OFGeneralSerializer serInRegistry = registry.put(msgTypeKey, serializer);
+ if (serInRegistry != null) {
+ LOGGER.warn("Serializer for key " + msgTypeKey + " overwritten. Old serializer: "
+ + serInRegistry.getClass().getName() + ", new serializer: "
+ + serializer.getClass().getName() );
+ }
if (serializer instanceof SerializerRegistryInjector) {
((SerializerRegistryInjector) serializer).injectSerializerRegistry(this);
}
- registry.put(msgTypeKey, serializer);
}
@Override