package org.opendaylight.yangtools.yang.data.tree.impl;
import static java.util.Objects.requireNonNull;
-import static org.opendaylight.yangtools.yang.data.tree.impl.MandatoryDescendant.getAugIdentifierOfChild;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableList.Builder;
import org.opendaylight.yangtools.yang.data.tree.api.DataTreeConfiguration;
import org.opendaylight.yangtools.yang.data.tree.api.TreeType;
import org.opendaylight.yangtools.yang.data.tree.impl.node.TreeNode;
-import org.opendaylight.yangtools.yang.data.util.DataSchemaContextNode;
-import org.opendaylight.yangtools.yang.model.api.AugmentationSchemaNode;
import org.opendaylight.yangtools.yang.model.api.ContainerSchemaNode;
-import org.opendaylight.yangtools.yang.model.api.CopyableNode;
import org.opendaylight.yangtools.yang.model.api.DataNodeContainer;
import org.opendaylight.yangtools.yang.model.api.DataSchemaNode;
import org.opendaylight.yangtools.yang.model.api.ElementCountConstraintAware;
}
final var builder = ImmutableList.<MandatoryDescendant>builder();
- final var isAugmentingNode = schema instanceof CopyableNode && ((CopyableNode) schema).isAugmenting();
- findMandatoryNodes(builder, YangInstanceIdentifier.empty(), schema, treeConfig.getTreeType(), isAugmentingNode);
+ findMandatoryNodes(builder, YangInstanceIdentifier.empty(), schema, treeConfig.getTreeType());
final var mandatoryNodes = builder.build();
return mandatoryNodes.isEmpty() ? null : new MandatoryLeafEnforcer(mandatoryNodes);
}
enforceOnData(tree.getData());
}
- private static void findMandatoryNodes(final Builder<MandatoryDescendant> builder,
- final YangInstanceIdentifier id, final DataNodeContainer schema, final TreeType type,
- final boolean augmentedSubtree) {
+ private static void findMandatoryNodes(final Builder<MandatoryDescendant> builder, final YangInstanceIdentifier id,
+ final DataNodeContainer schema, final TreeType type) {
for (final DataSchemaNode child : schema.getChildNodes()) {
if (SchemaAwareApplyOperation.belongsToTree(type, child)) {
if (child instanceof ContainerSchemaNode container) {
if (!container.isPresenceContainer()) {
- if (!augmentedSubtree) {
- // this container is not part of augmented subtree.
- final boolean parentSchemaAugmenting = schema instanceof CopyableNode copyable
- && copyable.isAugmenting();
- if (container.isAugmenting() && !parentSchemaAugmenting) {
- // the container is augmenting, but the parent schema is not. Meaning this is the root
- // of the augmentation (the augmented subtree starts here). The container has to be
- // represented by AugmentationID and the whole subtree needs to be based on it.
- final AugmentationSchemaNode aug = getAugIdentifierOfChild(schema, child);
- findMandatoryNodes(builder, id.node(DataSchemaContextNode
- .augmentationIdentifierFrom(aug)).node(NodeIdentifier.create(container.getQName())),
- container, type, true);
- continue;
- }
- }
// the container is either:
// - not in an augmented subtree and not augmenting
// - in an augmented subtree
// in both cases just append the NodeID to the ongoing ID and continue the search.
- findMandatoryNodes(builder, id.node(NodeIdentifier.create(container.getQName())),
- container, type, augmentedSubtree);
+ findMandatoryNodes(builder, id.node(NodeIdentifier.create(container.getQName())), container,
+ type);
}
} else {
boolean needEnforce = child instanceof MandatoryAware aware && aware.isMandatory();
.orElse(Boolean.FALSE);
}
if (needEnforce) {
- final MandatoryDescendant desc = MandatoryDescendant.create(id, schema, child,
- augmentedSubtree);
+ final MandatoryDescendant desc = MandatoryDescendant.create(id, schema, child);
LOG.debug("Adding mandatory child {}", desc);
builder.add(desc);
}