BUG-4258: implement enumeration value canonicalization 96/26596/1
authorRobert Varga <rovarga@cisco.com>
Fri, 4 Sep 2015 16:57:35 +0000 (18:57 +0200)
committerRobert Varga <nite@hq.sk>
Mon, 7 Sep 2015 10:12:49 +0000 (10:12 +0000)
Convert the internal lookup set to a Map, which contains interned
strings. When asked to deserialize() a String, perform a lookup in the
Map and return the interned string instance instead of the serialized
instance.

Change-Id: I1eff1f3bd23446bf8b1090a386bb2d31d205f904
Signed-off-by: Robert Varga <rovarga@cisco.com>
(cherry picked from commit bf8bb3bbd805b64478de8ca0487c3e6f63125fc9)

yang/yang-data-impl/src/main/java/org/opendaylight/yangtools/yang/data/impl/codec/EnumStringCodec.java

index a24b8b7db46d7858c645d6b866c77be2c45a36ed..00f879bc6317df40d435b28a657c0292e8d4c9a4 100644 (file)
@@ -9,32 +9,29 @@ package org.opendaylight.yangtools.yang.data.impl.codec;
 
 import com.google.common.base.Optional;
 import com.google.common.base.Preconditions;
-import com.google.common.collect.ImmutableSet;
-import com.google.common.collect.Sets;
-import java.util.List;
-import java.util.Set;
+import com.google.common.collect.ImmutableMap;
+import com.google.common.collect.ImmutableMap.Builder;
+import java.util.Map;
 import org.opendaylight.yangtools.yang.data.api.codec.EnumCodec;
 import org.opendaylight.yangtools.yang.model.api.type.EnumTypeDefinition;
 import org.opendaylight.yangtools.yang.model.api.type.EnumTypeDefinition.EnumPair;
 
- class EnumStringCodec extends TypeDefinitionAwareCodec<String, EnumTypeDefinition> implements
-        EnumCodec<String> {
-
-    private final Set<String> values;
+class EnumStringCodec extends TypeDefinitionAwareCodec<String, EnumTypeDefinition> implements EnumCodec<String> {
+    private final Map<String, String> values;
 
     protected EnumStringCodec(final Optional<EnumTypeDefinition> typeDef) {
         super(typeDef, String.class);
-        if(typeDef.isPresent()) {
-            final List<EnumPair> enumValues = typeDef.get().getValues();
-            final Set<String> valuesBuilder = Sets.newHashSetWithExpectedSize(enumValues.size());
-            for( final EnumPair pair: enumValues ) {
-                valuesBuilder.add( pair.getName() );
+        if (typeDef.isPresent()) {
+            final Builder<String, String> b = ImmutableMap.<String, String>builder();
+            for (final EnumPair pair : typeDef.get().getValues()) {
+                // Intern the String to get wide reuse
+                final String v = pair.getName().intern();
+                b.put(v, v);
             }
-            values = ImmutableSet.copyOf(valuesBuilder);
+            values = b.build();
         } else {
             values = null;
         }
-
     }
 
     static TypeDefinitionAwareCodec<?,EnumTypeDefinition> from(final EnumTypeDefinition normalizedType) {
@@ -44,14 +41,19 @@ import org.opendaylight.yangtools.yang.model.api.type.EnumTypeDefinition.EnumPai
     @Override
     public final String deserialize(final String s) {
         if (values != null) {
-            Preconditions.checkArgument(values.contains(s), "Invalid value '%s' for enum type. Allowed values are: %s",
-                    s, values);
+            // Lookup the serialized string in the values. Returned string is the interned instance, which we want
+            // to use as the result.
+            final String result = values.get(s);
+            Preconditions.checkArgument(result != null, "Invalid value '%s' for enum type. Allowed values are: %s",
+                s, values.keySet());
+            return result;
+        } else {
+            return s;
         }
-        return s;
     }
 
     @Override
     public final String serialize(final String data) {
         return data == null ? "" : data;
     }
-}
\ No newline at end of file
+}