*/
package org.opendaylight.yangtools.yang.data.impl.schema.tree;
-import com.google.common.base.Optional;
import com.google.common.base.Preconditions;
import com.google.common.collect.ImmutableCollection.Builder;
import com.google.common.collect.ImmutableList;
import java.util.Collection;
+import java.util.Optional;
import org.opendaylight.yangtools.concepts.Immutable;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier;
import org.opendaylight.yangtools.yang.data.api.schema.tree.DataTreeConfiguration;
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType;
import org.opendaylight.yangtools.yang.data.api.schema.tree.spi.TreeNode;
-import org.opendaylight.yangtools.yang.model.api.ConstraintDefinition;
import org.opendaylight.yangtools.yang.model.api.ContainerSchemaNode;
import org.opendaylight.yangtools.yang.model.api.DataNodeContainer;
import org.opendaylight.yangtools.yang.model.api.DataSchemaNode;
+import org.opendaylight.yangtools.yang.model.api.ElementCountConstraintAware;
+import org.opendaylight.yangtools.yang.model.api.MandatoryAware;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
enforceOnData(tree.getData());
}
- abstract void enforceOnData(final NormalizedNode<?, ?> normalizedNode);
+ abstract void enforceOnData(NormalizedNode<?, ?> normalizedNode);
private static void findMandatoryNodes(final Builder<YangInstanceIdentifier> builder,
final YangInstanceIdentifier id, final DataNodeContainer schema, final TreeType type) {
findMandatoryNodes(builder, id.node(NodeIdentifier.create(child.getQName())), container, type);
}
} else {
- final ConstraintDefinition constraints = child.getConstraints();
- final Integer minElements = constraints.getMinElements();
- if (constraints.isMandatory() || (minElements != null && minElements.intValue() > 0)) {
+ boolean needEnforce = child instanceof MandatoryAware && ((MandatoryAware) child).isMandatory();
+ if (!needEnforce && child instanceof ElementCountConstraintAware) {
+ needEnforce = ((ElementCountConstraintAware) child)
+ .getElementCountConstraint().map(constraint -> {
+ final Integer min = constraint.getMinElements();
+ return min != null && min > 0;
+ }).orElse(Boolean.FALSE).booleanValue();
+ }
+ if (needEnforce) {
final YangInstanceIdentifier childId = id.node(NodeIdentifier.create(child.getQName()));
LOG.debug("Adding mandatory child {}", childId);
builder.add(childId.toOptimized());