X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;ds=sidebyside;f=yang%2Fyang-data-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fyangtools%2Fyang%2Fdata%2Fimpl%2Fschema%2Ftree%2FModificationApplyOperation.java;h=60b83b17911bd6844e88ff42adf2899b526de2d0;hb=9041b2200d7c48962615f414ed884cb54a7573df;hp=c890a28b09335ce6f520d2f21c2a7f6956f9dbf3;hpb=b43b9ed6f627a4a1d2ecc6081ed4f0024761e4a3;p=yangtools.git diff --git a/yang/yang-data-impl/src/main/java/org/opendaylight/yangtools/yang/data/impl/schema/tree/ModificationApplyOperation.java b/yang/yang-data-impl/src/main/java/org/opendaylight/yangtools/yang/data/impl/schema/tree/ModificationApplyOperation.java index c890a28b09..60b83b1791 100644 --- a/yang/yang-data-impl/src/main/java/org/opendaylight/yangtools/yang/data/impl/schema/tree/ModificationApplyOperation.java +++ b/yang/yang-data-impl/src/main/java/org/opendaylight/yangtools/yang/data/impl/schema/tree/ModificationApplyOperation.java @@ -7,9 +7,9 @@ */ package org.opendaylight.yangtools.yang.data.impl.schema.tree; -import com.google.common.base.Optional; -import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; +import java.util.Optional; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument; +import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; import org.opendaylight.yangtools.yang.data.api.schema.tree.DataValidationFailedException; import org.opendaylight.yangtools.yang.data.api.schema.tree.StoreTreeNode; import org.opendaylight.yangtools.yang.data.api.schema.tree.spi.TreeNode; @@ -18,27 +18,28 @@ import org.opendaylight.yangtools.yang.data.api.schema.tree.spi.Version; /** * Operation responsible for applying {@link ModifiedNode} on tree. * + *

* Operation is composite - operation on top level node consists of * suboperations on child nodes. This allows to walk operation hierarchy and * invoke suboperations independently. * + *

* Implementation notes *

* + *

* Hierarchical composite operation which is responsible for applying * modification on particular subtree and creating updated subtree */ abstract class ModificationApplyOperation implements StoreTreeNode { /** - * - * Implementation of this operation must be stateless and must not change - * state of this object. + * Implementation of this operation must be stateless and must not change state of this object. * * @param modification * NodeModification to be applied @@ -46,36 +47,48 @@ abstract class ModificationApplyOperation implements StoreTreeNode apply(ModifiedNode modification, Optional storeMeta, Version version); + abstract Optional apply(ModifiedNode modification, Optional storeMeta, + Version version); /** - * - * Checks if provided node modification could be applied to current metadata node. - * - * @param modification Modification - * @param current Metadata Node to which modification should be applied - * @return true if modification is applicable - * false if modification is no applicable - * @throws DataValidationFailedException - */ - abstract void checkApplicable(YangInstanceIdentifier path, NodeModification modification, Optional current) throws DataValidationFailedException; + * Checks if provided node modification could be applied to current metadata node. + * + * @param path Path to modification + * @param modification Modification + * @param current Metadata Node to which modification should be applied + * @param version Metadata version + * @throws DataValidationFailedException if the modification is not applicable + */ + abstract void checkApplicable(ModificationPath path, NodeModification modification, + Optional current, Version version) throws DataValidationFailedException; /** + * Performs a quick structural verification of NodeModification, such as written values / types uses right + * structural elements. * - * Performs structural verification of NodeModification, such as writen values / types - * uses right structural elements. + * @param modification data to be verified. + * @throws IllegalArgumentException If provided NodeModification does not adhere to the + * structure. + */ + abstract void quickVerifyStructure(NormalizedNode modification); + + /** + * Performs a full structural verification of NodeModification, such as written values / types uses right + * structural elements. Unlike {@link #quickVerifyStructure(NormalizedNode)} this includes recursively checking + * children, too. * - * @param modification to be verified. - * @throws IllegalArgumentException If provided NodeModification does not adhere to the structure. + * @param modification data to be verified. + * @throws IllegalArgumentException If provided NodeModification does not adhere to the + * structure. */ - abstract void verifyStructure(ModifiedNode modification) throws IllegalArgumentException; + abstract void fullVerifyStructure(NormalizedNode modification); /** * Return the tracking policy for this node's children. @@ -85,11 +98,24 @@ abstract class ModificationApplyOperation implements StoreTreeNode value, Version version); + + /** + * Returns a suboperation for specified tree node. * - * @return Reference to suboperation for specified tree node, {@link Optional#absent()} - * if suboperation is not supported for specified tree node. + * @return Reference to suboperation for specified tree node, {@link Optional#empty()} + * if suboperation is not supported for specified tree node. */ @Override public abstract Optional getChild(PathArgument child); + + abstract void recursivelyVerifyStructure(NormalizedNode value); }