X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-dom-broker%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fmd%2Fsal%2Fdom%2Fstore%2Fimpl%2FMutableDataTree.java;h=f252744876f0b8da325523fdcce62c8bad3a7552;hb=812fe0fadea37749120885c5d55a388b470b508d;hp=ddf65b6d275389d98ac86e6a5971685ea6e683e1;hpb=8b3405d23e3018afdc4cb5e99bab442ced26e304;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 ddf65b6d27..f252744876 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 @@ -7,7 +7,6 @@ */ package org.opendaylight.controller.md.sal.dom.store.impl; -import static com.google.common.base.Preconditions.checkArgument; import static com.google.common.base.Preconditions.checkState; import java.util.Map.Entry; @@ -32,7 +31,7 @@ class MutableDataTree { final NodeModification rootModification; final ModificationApplyOperation strategyTree; - private boolean sealed = false; + private boolean sealed = false; private MutableDataTree(final DataAndMetadataSnapshot snapshot, final ModificationApplyOperation strategyTree) { this.snapshot = snapshot; @@ -51,50 +50,52 @@ class MutableDataTree { } public Optional> read(final InstanceIdentifier path) { - Entry modification = TreeNodeUtils.findClosest(rootModification, path); - return getModifiedVersion(path, modification); - } + Entry modification = TreeNodeUtils.findClosestsOrFirstMatch(rootModification, path, NodeModification.IS_TERMINAL_PREDICATE); - private Optional> getModifiedVersion(final InstanceIdentifier path, final Entry modification) { Optional result = resolveSnapshot(modification); - if(result.isPresent()) { + if (result.isPresent()) { NormalizedNode data = result.get().getData(); - return NormalizedNodeUtils.findNode(modification.getKey(),data, path); + return NormalizedNodeUtils.findNode(modification.getKey(), data, path); } return Optional.absent(); } - private Optional resolveSnapshot(final Entry keyModification) { + private Optional resolveSnapshot( + final Entry keyModification) { InstanceIdentifier path = keyModification.getKey(); NodeModification modification = keyModification.getValue(); - return resolveSnapshot(path,modification); + return resolveSnapshot(path, modification); } - private Optional resolveSnapshot(final InstanceIdentifier path, final NodeModification modification) { + private Optional resolveSnapshot(final InstanceIdentifier path, + final NodeModification modification) { try { - return resolveModificationStrategy(path).apply(modification,modification.getOriginal()); + Optional> potentialSnapshot = modification.getSnapshotCache(); + if(potentialSnapshot.isPresent()) { + return potentialSnapshot.get(); + } + return resolveModificationStrategy(path).apply(modification, modification.getOriginal(), + StoreUtils.increase(snapshot.getMetadataTree().getSubtreeVersion())); } catch (Exception e) { - log.error("Could not create snapshot for {},",e); + log.error("Could not create snapshot for {}", path,e); throw e; } } private ModificationApplyOperation resolveModificationStrategy(final InstanceIdentifier path) { - log.trace("Resolving modification apply strategy for {}",path); - Optional strategy = TreeNodeUtils.findNode(strategyTree, path); - checkArgument(strategy.isPresent(),"Provided path %s is not supported by data store. No schema available for it.",path); - return strategy.get(); + log.trace("Resolving modification apply strategy for {}", path); + return TreeNodeUtils.findNodeChecked(strategyTree, path); } - private NodeModification resolveModificationFor(final InstanceIdentifier path) { + private OperationWithModification resolveModificationFor(final InstanceIdentifier path) { NodeModification modification = rootModification; // We ensure strategy is present. - resolveModificationStrategy(path); + ModificationApplyOperation operation = resolveModificationStrategy(path); for (PathArgument pathArg : path.getPath()) { modification = modification.modifyChild(pathArg); } - return modification; + return OperationWithModification.from(operation, modification); } public static MutableDataTree from(final DataAndMetadataSnapshot snapshot, final ModificationApplyOperation resolver) { @@ -107,6 +108,17 @@ class MutableDataTree { } private void checkSealed() { - checkState(!sealed , "Data Tree is sealed. No further modifications allowed."); + checkState(!sealed, "Data Tree is sealed. No further modifications allowed."); + } + + protected NodeModification getRootModification() { + return rootModification; } + + @Override + public String toString() { + return "MutableDataTree [modification=" + rootModification + "]"; + } + + }