Bug 4295: Fixed incorrectly introduced nodes when MERGE was followed by DELETE
[yangtools.git] / yang / yang-data-impl / src / main / java / org / opendaylight / yangtools / yang / data / impl / schema / transform / dom / parser / LeafNodeDomParser.java
index 2e8ab87bd749d0134ee6ad68f9cf058d2e263bb7..e059deadf9ea534880687d5e578cd36358749c91 100644 (file)
@@ -7,9 +7,11 @@
  */
 package org.opendaylight.yangtools.yang.data.impl.schema.transform.dom.parser;
 
+import com.google.common.base.Preconditions;
 import java.util.Map;
-
 import org.opendaylight.yangtools.yang.common.QName;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier;
+import org.opendaylight.yangtools.yang.data.api.schema.LeafNode;
 import org.opendaylight.yangtools.yang.data.impl.codec.xml.XmlCodecProvider;
 import org.opendaylight.yangtools.yang.data.impl.schema.transform.base.parser.LeafNodeBaseParser;
 import org.opendaylight.yangtools.yang.data.impl.schema.transform.dom.DomUtils;
@@ -17,30 +19,32 @@ import org.opendaylight.yangtools.yang.model.api.LeafSchemaNode;
 import org.opendaylight.yangtools.yang.model.api.SchemaContext;
 import org.w3c.dom.Element;
 
-import com.google.common.base.Preconditions;
-
 final class LeafNodeDomParser extends LeafNodeBaseParser<Element> {
 
     private final XmlCodecProvider codecProvider;
     private final SchemaContext ctx;
 
-    LeafNodeDomParser(XmlCodecProvider codecProvider, final SchemaContext schema) {
+    LeafNodeDomParser(final XmlCodecProvider codecProvider, final SchemaContext schema) {
         this.ctx = schema;
         this.codecProvider = Preconditions.checkNotNull(codecProvider);
     }
 
-    @Deprecated
-    LeafNodeDomParser(XmlCodecProvider codecProvider) {
-        this(codecProvider, null);
+    LeafNodeDomParser(final XmlCodecProvider codecProvider, final SchemaContext schema,
+        final BuildingStrategy<NodeIdentifier, LeafNode<?>> strategy) {
+        super(strategy);
+        this.ctx = schema;
+        this.codecProvider = Preconditions.checkNotNull(codecProvider);
     }
 
     @Override
-    protected Object parseLeaf(Element xmlElement, LeafSchemaNode schema) {
-        return ctx == null ? DomUtils.parseXmlValue(xmlElement, codecProvider, schema.getType()) : DomUtils.parseXmlValue(xmlElement, codecProvider, schema, schema.getType(), ctx);
+    protected Object parseLeaf(final Element xmlElement, final LeafSchemaNode schema) {
+        return ctx == null ? DomUtils.parseXmlValue(xmlElement, codecProvider, schema.getType())
+                : DomUtils.parseXmlValue(xmlElement, codecProvider, schema, schema.getType(), ctx);
     }
 
     @Override
-    protected Map<QName, String> getAttributes(Element element) {
+    protected Map<QName, String> getAttributes(final Element element) {
         return DomUtils.toAttributes(element.getAttributes());
     }
+
 }