X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-clustering-commons%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2Fnode%2Futils%2Fserialization%2FValueType.java;h=9eec8a300a81f2fc304beb7d9978ec7aef26b331;hb=c37b95d3a9347913a4854b2f448e216cd17cae87;hp=8169c9e9ae4c13bf5a08bc790f5c272e468faf35;hpb=ae91c971cb8abe701185bc479edacdb7638555e4;p=controller.git diff --git a/opendaylight/md-sal/sal-clustering-commons/src/main/java/org/opendaylight/controller/cluster/datastore/node/utils/serialization/ValueType.java b/opendaylight/md-sal/sal-clustering-commons/src/main/java/org/opendaylight/controller/cluster/datastore/node/utils/serialization/ValueType.java index 8169c9e9ae..9eec8a300a 100644 --- a/opendaylight/md-sal/sal-clustering-commons/src/main/java/org/opendaylight/controller/cluster/datastore/node/utils/serialization/ValueType.java +++ b/opendaylight/md-sal/sal-clustering-commons/src/main/java/org/opendaylight/controller/cluster/datastore/node/utils/serialization/ValueType.java @@ -8,29 +8,95 @@ package org.opendaylight.controller.cluster.datastore.node.utils.serialization; -import com.google.common.base.Preconditions; import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap.Builder; import java.math.BigDecimal; import java.math.BigInteger; import java.util.Map; import java.util.Set; +import org.opendaylight.controller.cluster.datastore.node.utils.QNameFactory; import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; public enum ValueType { - SHORT_TYPE, - BYTE_TYPE, - INT_TYPE, - LONG_TYPE, - BOOL_TYPE, - QNAME_TYPE, - BITS_TYPE, - YANG_IDENTIFIER_TYPE, - STRING_TYPE, - BIG_INTEGER_TYPE, - BIG_DECIMAL_TYPE, - BINARY_TYPE; + SHORT_TYPE { + @Override + Object deserialize(final String str) { + return Short.valueOf(str); + } + }, + BYTE_TYPE { + @Override + Object deserialize(final String str) { + return Byte.valueOf(str); + } + }, + INT_TYPE { + @Override + Object deserialize(final String str) { + return Integer.valueOf(str); + } + }, + LONG_TYPE { + @Override + Object deserialize(final String str) { + return Long.valueOf(str); + } + }, + BOOL_TYPE { + @Override + Object deserialize(final String str) { + return Boolean.valueOf(str); + } + }, + QNAME_TYPE { + @Override + Object deserialize(final String str) { + return QNameFactory.create(str); + } + }, + BITS_TYPE { + @Override + Object deserialize(final String str) { + throw new UnsupportedOperationException("Should have been caught by caller"); + } + }, + YANG_IDENTIFIER_TYPE { + @Override + Object deserialize(final String str) { + throw new UnsupportedOperationException("Should have been caught by caller"); + } + }, + STRING_TYPE { + @Override + Object deserialize(final String str) { + return str; + } + }, + BIG_INTEGER_TYPE { + @Override + Object deserialize(final String str) { + return new BigInteger(str); + } + }, + BIG_DECIMAL_TYPE { + @Override + Object deserialize(final String str) { + return new BigDecimal(str); + } + }, + BINARY_TYPE { + @Override + Object deserialize(final String str) { + throw new UnsupportedOperationException("Should have been caught by caller"); + } + }, + NULL_TYPE { + @Override + Object deserialize(final String str) { + return null; + } + }; private static final Map, ValueType> TYPES; @@ -52,8 +118,12 @@ public enum ValueType { TYPES = b.build(); } + abstract Object deserialize(String str); + public static final ValueType getSerializableType(Object node) { - Preconditions.checkNotNull(node, "node should not be null"); + if(node == null){ + return NULL_TYPE; + } final ValueType type = TYPES.get(node.getClass()); if (type != null) {