X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;ds=sidebyside;f=opendaylight%2Fmd-sal%2Fsal-dom-broker%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fmd%2Fsal%2Fdom%2Fstore%2Fimpl%2FMutableDataTree.java;h=1002cd54b51b9afab310ec0e28d949c2fb2584a5;hb=3f10df4865b301abdeff3d916c0eff22156a6eac;hp=14d82799d76ec3d0a58b7797ab9d718163072c6c;hpb=f776809962df87deeaa533ba995cc6fceba64d0e;p=controller.git diff --git a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/store/impl/MutableDataTree.java b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/store/impl/MutableDataTree.java index 14d82799d7..1002cd54b5 100644 --- a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/store/impl/MutableDataTree.java +++ b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/store/impl/MutableDataTree.java @@ -18,6 +18,7 @@ import org.opendaylight.controller.md.sal.dom.store.impl.tree.TreeNodeUtils; import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier; import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.PathArgument; import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; +import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNodeContainer; import org.opendaylight.yangtools.yang.data.impl.schema.NormalizedNodeUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -33,13 +34,13 @@ class MutableDataTree { private static final Logger LOG = LoggerFactory.getLogger(MutableDataTree.class); private final AtomicBoolean sealed = new AtomicBoolean(); private final ModificationApplyOperation strategyTree; - private final DataAndMetadataSnapshot snapshot; private final NodeModification rootModification; + private final DataTree.Snapshot snapshot; - private MutableDataTree(final DataAndMetadataSnapshot snapshot, final ModificationApplyOperation strategyTree) { - this.snapshot = snapshot; - this.strategyTree = strategyTree; - this.rootModification = NodeModification.createUnmodified(snapshot.getMetadataTree()); + private MutableDataTree(final DataTree.Snapshot snapshot, final ModificationApplyOperation strategyTree) { + this.snapshot = Preconditions.checkNotNull(snapshot); + this.strategyTree = Preconditions.checkNotNull(strategyTree); + this.rootModification = NodeModification.createUnmodified(snapshot.getRootNode()); } public void write(final InstanceIdentifier path, final NormalizedNode value) { @@ -47,6 +48,24 @@ class MutableDataTree { resolveModificationFor(path).write(value); } + public void merge(final InstanceIdentifier path, final NormalizedNode data) { + checkSealed(); + mergeImpl(resolveModificationFor(path),data); + } + + private void mergeImpl(final OperationWithModification op,final NormalizedNode data) { + + if(data instanceof NormalizedNodeContainer) { + @SuppressWarnings({ "rawtypes", "unchecked" }) + NormalizedNodeContainer> dataContainer = (NormalizedNodeContainer) data; + for(NormalizedNode child : dataContainer.getValue()) { + PathArgument childId = child.getIdentifier(); + mergeImpl(op.forChild(childId), child); + } + } + op.merge(data); + } + public void delete(final InstanceIdentifier path) { checkSealed(); resolveModificationFor(path).delete(); @@ -78,9 +97,9 @@ class MutableDataTree { return potentialSnapshot.get(); } return resolveModificationStrategy(path).apply(modification, modification.getOriginal(), - StoreUtils.increase(snapshot.getMetadataTree().getSubtreeVersion())); + StoreUtils.increase(snapshot.getRootNode().getSubtreeVersion())); } catch (Exception e) { - LOG.error("Could not create snapshot for {}", path,e); + LOG.error("Could not create snapshot for {}:{}", path,modification,e); throw e; } } @@ -100,7 +119,7 @@ class MutableDataTree { return OperationWithModification.from(operation, modification); } - public static MutableDataTree from(final DataAndMetadataSnapshot snapshot, final ModificationApplyOperation resolver) { + public static MutableDataTree from(final DataTree.Snapshot snapshot, final ModificationApplyOperation resolver) { return new MutableDataTree(snapshot, resolver); }