DecimalContainer decimalCont = decimalContainerNode.get();
assertEquals(66.66, decimalCont.getDecimalLeaf().getValue().doubleValue(), 0.001);
assertEquals(66.66, decimalCont.getDecimalLeaf2().getValue().doubleValue(), 0.001);
- assertEquals(99.9, decimalCont.getDecimalLeaf3().getValue().doubleValue(), 0.01);
+ assertEquals(99.99, decimalCont.getDecimalLeaf3().getValue().doubleValue(), 0.001);
assertEquals(66.66, decimalCont.getDecimalLeaf4().getValue().doubleValue(), 0.001);
assertEquals(120.55, decimalCont.getDecimalLeaf5().doubleValue(), 0.001);
assertEquals(null, decimalCont.getDecimalLeaf6());
IdentityrefContainer idrefCont = identityrefContainerNode.get();
assertNull(idrefCont.getIdentityrefLeaf());
+ assertEquals("MyDerivedIdentity", idrefCont.getIdentityrefLeaf2().getSimpleName());
+ assertEquals("MyDerivedIdentity", idrefCont.getIdentityrefLeaf3().getSimpleName());
+ assertEquals("MyDerivedIdentity2", idrefCont.getIdentityrefLeaf4().getSimpleName());
+ assertEquals("MyDerivedImportedIdentity", idrefCont.getIdentityrefLeaf5().getSimpleName());
+ assertEquals("MyDerivedIdentity", idrefCont.getIdentityrefLeaf6().getSimpleName());
+ assertNull(idrefCont.getIdentityrefLeaf7());
}
}
import com.google.common.base.Optional;
import com.google.common.base.Preconditions;
import com.google.common.collect.ImmutableCollection;
-import com.google.common.collect.ImmutableList;
-import com.google.common.collect.ImmutableSet;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
+import java.util.Set;
import javax.annotation.Nullable;
import org.opendaylight.mdsal.binding.dom.codec.api.BindingCodecTreeNode;
import org.opendaylight.mdsal.binding.dom.codec.api.BindingNormalizedNodeCachingCodec;
import org.opendaylight.yangtools.yang.binding.DataObject;
import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
import org.opendaylight.yangtools.yang.binding.InstanceIdentifier.PathArgument;
+import org.opendaylight.yangtools.yang.common.QName;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
import org.opendaylight.yangtools.yang.data.api.schema.LeafNode;
import org.opendaylight.yangtools.yang.data.api.schema.LeafSetEntryNode;
import org.opendaylight.yangtools.yang.data.api.schema.stream.NormalizedNodeStreamWriter;
import org.opendaylight.yangtools.yang.data.impl.codec.TypeDefinitionAwareCodec;
import org.opendaylight.yangtools.yang.model.api.DataSchemaNode;
-import org.opendaylight.yangtools.yang.model.api.IdentitySchemaNode;
import org.opendaylight.yangtools.yang.model.api.LeafSchemaNode;
+import org.opendaylight.yangtools.yang.model.api.Module;
+import org.opendaylight.yangtools.yang.model.api.ModuleImport;
+import org.opendaylight.yangtools.yang.model.api.SchemaContext;
import org.opendaylight.yangtools.yang.model.api.TypeDefinition;
+import org.opendaylight.yangtools.yang.model.api.type.IdentityrefTypeDefinition;
final class LeafNodeCodecContext<D extends DataObject> extends NodeCodecContext<D> implements NodeContextSupplier {
private final DataSchemaNode schema;
private final Object defaultObject;
- public LeafNodeCodecContext(final DataSchemaNode schema, final Codec<Object, Object> codec, final Method getter) {
+ public LeafNodeCodecContext(final DataSchemaNode schema, final Codec<Object, Object> codec, final Method getter,
+ final SchemaContext schemaContext) {
this.yangIdentifier = new YangInstanceIdentifier.NodeIdentifier(schema.getQName());
this.valueCodec = Preconditions.checkNotNull(codec);
this.getter = getter;
this.schema = Preconditions.checkNotNull(schema);
- this.defaultObject = createDefaultObject(schema, valueCodec);
+ this.defaultObject = createDefaultObject(schema, valueCodec, schemaContext);
}
- private static Object createDefaultObject(final DataSchemaNode schema, final Codec<Object, Object> codec) {
+ private static Object createDefaultObject(final DataSchemaNode schema, final Codec<Object, Object> codec,
+ final SchemaContext schemaContext) {
if (schema instanceof LeafSchemaNode) {
Object defaultValue = ((LeafSchemaNode) schema).getDefault();
TypeDefinition<?> type = ((LeafSchemaNode) schema).getType();
if (defaultValue != null) {
+ if (type instanceof IdentityrefTypeDefinition) {
+ return qnameDomValueFromString(codec, schema, (String) defaultValue, schemaContext);
+ }
return domValueFromString(codec, type, defaultValue);
}
else {
defaultValue = type.getDefaultValue();
if (defaultValue != null) {
- if (defaultValue instanceof Boolean) {
- return codec.deserialize(defaultValue);
- }
-
- if (defaultValue instanceof IdentitySchemaNode) {
- defaultValue = ((IdentitySchemaNode) defaultValue).getQName();
- return codec.deserialize(defaultValue);
- }
-
- if (defaultValue instanceof ImmutableList) {
- return codec.deserialize(ImmutableSet.copyOf((ImmutableList) defaultValue));
- }
-
- if (defaultValue instanceof List) {
- return codec.deserialize(defaultValue);
+ if (type instanceof IdentityrefTypeDefinition) {
+ return qnameDomValueFromString(codec, schema, (String) defaultValue, schemaContext);
}
return domValueFromString(codec, type, defaultValue);
}
return null;
}
+ private static Object qnameDomValueFromString(final Codec<Object, Object> codec, final DataSchemaNode schema,
+ final String defaultValue, final SchemaContext schemaContext) {
+ int prefixEndIndex = defaultValue.indexOf(':');
+ QName qname;
+ if (prefixEndIndex != -1) {
+ String defaultValuePrefix = defaultValue.substring(0, prefixEndIndex);
+
+ Module module = schemaContext.findModuleByNamespaceAndRevision(schema.getQName().getNamespace(),
+ schema.getQName().getRevision());
+
+ if (module.getPrefix().equals(defaultValuePrefix)) {
+ qname = QName.create(module.getQNameModule(), defaultValue.substring(prefixEndIndex + 1));
+ return codec.deserialize(qname);
+ } else {
+ Set<ModuleImport> imports = module.getImports();
+ for (ModuleImport moduleImport : imports) {
+ if (moduleImport.getPrefix().equals(defaultValuePrefix)) {
+ Module importedModule = schemaContext.findModuleByName(moduleImport.getModuleName(),
+ moduleImport.getRevision());
+ qname = QName.create(importedModule.getQNameModule(), defaultValue.substring(prefixEndIndex + 1));
+ return codec.deserialize(qname);
+ }
+ }
+ return null;
+ }
+ }
+
+ qname = QName.create(schema.getQName(), defaultValue);
+ return codec.deserialize(qname);
+ }
+
private static Object domValueFromString(final Codec<Object, Object> codec, final TypeDefinition<?> type,
Object defaultValue) {
TypeDefinitionAwareCodec typeDefAwareCodec = TypeDefinitionAwareCodec.from(type);
namespace "urn:opendaylight:params:xml:ns:default:value:test";
prefix "def-val-test";
+ import opendaylight-default-value-test-2 {
+ prefix def-val-test-2;
+ revision-date 2016-01-11;
+ }
+
typedef tiny-signed-integer {
type int8 {
range "-20..-1";
typedef my-derived-decimal2 {
type my-decimal {
- fraction-digits 1;
- range "77.7 .. 111.1";
+ fraction-digits 2;
+ range "77.77 .. 111.11";
}
- default "99.9";
+ default "99.99";
}
typedef my-derived-decimal3 {
}
identity my-identity {
- description "identity for testing purposes";
+ description "parent identity for testing purposes";
+ }
+
+ identity my-derived-identity {
+ base my-identity;
+ description "child identity for testing purposes";
+ }
+
+ identity my-derived-identity2 {
+ base my-derived-identity;
+ description "another child identity for testing purposes";
}
typedef my-identityref {
}
}
+ typedef my-identityref2 {
+ type identityref {
+ base my-identity;
+ }
+ default "my-derived-identity";
+ }
+
container tiny-int-container {
presence "presence container";
leaf identityref-leaf {
type my-identityref;
}
+
+ leaf identityref-leaf2 {
+ type my-identityref;
+ default "my-derived-identity";
+ }
+
+ leaf identityref-leaf3 {
+ type my-identityref2;
+ }
+
+ leaf identityref-leaf4 {
+ type my-identityref;
+ default "my-derived-identity2";
+ }
+
+ leaf identityref-leaf5 {
+ type def-val-test-2:my-imported-identityref;
+ default def-val-test-2:my-derived-imported-identity;
+ }
+
+ leaf identityref-leaf6 {
+ type my-identityref;
+ default "def-val-test:my-derived-identity";
+ }
+
+ leaf identityref-leaf7 {
+ type def-val-test-2:my-imported-identityref;
+ default invalid-prefix:my-derived-imported-identity;
+ }
}
}
\ No newline at end of file