X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=yang%2Fyang-parser-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fyangtools%2Fyang%2Fparser%2Fstmt%2Frfc6020%2FAnyxmlStatementImpl.java;h=b057490b38993e7f3960b71b7324cb26f1720303;hb=8ed061d33cfa59b8073c43844c8b3e6e502fe476;hp=135b20988bdd3722650896b277bde734c72df706;hpb=42a5ab126bea6cdbc1eb3693044a024ed468ac4e;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/AnyxmlStatementImpl.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/AnyxmlStatementImpl.java index 135b20988b..b057490b38 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/AnyxmlStatementImpl.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/AnyxmlStatementImpl.java @@ -1,4 +1,4 @@ -/* +/** * Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved. * * This program and the accompanying materials are made available under the @@ -7,12 +7,15 @@ */ package org.opendaylight.yangtools.yang.parser.stmt.rfc6020; -import static org.opendaylight.yangtools.yang.parser.spi.SubstatementValidator.MAX; - +import com.google.common.base.Optional; import java.util.Collection; +import java.util.Map; +import javax.annotation.Nonnull; import org.opendaylight.yangtools.yang.common.QName; -import org.opendaylight.yangtools.yang.model.api.Rfc6020Mapping; +import org.opendaylight.yangtools.yang.model.api.ContainerSchemaNode; +import org.opendaylight.yangtools.yang.model.api.YangStmtMapping; import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement; +import org.opendaylight.yangtools.yang.model.api.meta.StatementDefinition; import org.opendaylight.yangtools.yang.model.api.stmt.AnyxmlStatement; import org.opendaylight.yangtools.yang.model.api.stmt.ConfigStatement; import org.opendaylight.yangtools.yang.model.api.stmt.DescriptionStatement; @@ -20,67 +23,96 @@ import org.opendaylight.yangtools.yang.model.api.stmt.IfFeatureStatement; import org.opendaylight.yangtools.yang.model.api.stmt.MandatoryStatement; import org.opendaylight.yangtools.yang.model.api.stmt.MustStatement; import org.opendaylight.yangtools.yang.model.api.stmt.ReferenceStatement; +import org.opendaylight.yangtools.yang.model.api.stmt.SchemaNodeIdentifier; import org.opendaylight.yangtools.yang.model.api.stmt.StatusStatement; +import org.opendaylight.yangtools.yang.model.api.stmt.UnknownStatement; import org.opendaylight.yangtools.yang.model.api.stmt.WhenStatement; import org.opendaylight.yangtools.yang.parser.spi.SubstatementValidator; import org.opendaylight.yangtools.yang.parser.spi.meta.AbstractDeclaredStatement; import org.opendaylight.yangtools.yang.parser.spi.meta.AbstractStatementSupport; import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext; import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext.Mutable; -import org.opendaylight.yangtools.yang.parser.spi.source.SourceException; +import org.opendaylight.yangtools.yang.parser.spi.source.AnyxmlSchemaLocationNamespace; +import org.opendaylight.yangtools.yang.parser.stmt.reactor.StatementContextBase; import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.effective.AnyXmlEffectiveStatementImpl; +import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.effective.YangModeledAnyXmlEffectiveStatementImpl; public class AnyxmlStatementImpl extends AbstractDeclaredStatement implements AnyxmlStatement { - private static final SubstatementValidator SUBSTATEMENT_VALIDATOR = SubstatementValidator.builder(Rfc6020Mapping + private static final SubstatementValidator SUBSTATEMENT_VALIDATOR = SubstatementValidator.builder(YangStmtMapping .ANYXML) - .add(Rfc6020Mapping.CONFIG, 0, 1) - .add(Rfc6020Mapping.DESCRIPTION, 0, 1) - .add(Rfc6020Mapping.IF_FEATURE, 0, MAX) - .add(Rfc6020Mapping.MANDATORY, 0, 1) - .add(Rfc6020Mapping.MUST, 0, MAX) - .add(Rfc6020Mapping.REFERENCE, 0, 1) - .add(Rfc6020Mapping.STATUS, 0, 1) - .add(Rfc6020Mapping.WHEN, 0, 1) + .addOptional(YangStmtMapping.CONFIG) + .addOptional(YangStmtMapping.DESCRIPTION) + .addAny(YangStmtMapping.IF_FEATURE) + .addOptional(YangStmtMapping.MANDATORY) + .addAny(YangStmtMapping.MUST) + .addOptional(YangStmtMapping.REFERENCE) + .addOptional(YangStmtMapping.STATUS) + .addOptional(YangStmtMapping.WHEN) + .addOptional(SupportedExtensionsMapping.ANYXML_SCHEMA_LOCATION) .build(); - protected AnyxmlStatementImpl(StmtContext context) { + protected AnyxmlStatementImpl(final StmtContext context) { super(context); } - public static class Definition extends AbstractStatementSupport> { + public static class Definition extends + AbstractStatementSupport> { public Definition() { - super(Rfc6020Mapping.ANYXML); + super(YangStmtMapping.ANYXML); } @Override - public QName parseArgumentValue(StmtContext ctx, String value) { - return Utils.qNameFromArgument(ctx,value); + public QName parseArgumentValue(final StmtContext ctx, final String value) { + return Utils.qNameFromArgument(ctx, value); } @Override - public void onStatementAdded(Mutable> stmt) { + public void onStatementAdded(final Mutable> stmt) { stmt.getParentContext().addToNs(ChildSchemaNodes.class, stmt.getStatementArgument(), stmt); } @Override - public AnyxmlStatement createDeclared(StmtContext ctx) { + public AnyxmlStatement createDeclared(final StmtContext ctx) { return new AnyxmlStatementImpl(ctx); } @Override - public EffectiveStatement createEffective(StmtContext> ctx) { - return new AnyXmlEffectiveStatementImpl(ctx); + public EffectiveStatement createEffective( + final StmtContext> ctx) { + final Map, EffectiveStatement>>> schemaLocations = ctx + .getAllFromCurrentStmtCtxNamespace(AnyxmlSchemaLocationNamespace.class); + if (schemaLocations != null && !schemaLocations.isEmpty()) { + final SchemaNodeIdentifier anyXmlSchemaNodeIdentifier = schemaLocations.values().iterator().next() + .getStatementArgument(); + final Optional anyXmlSchema = getAnyXmlSchema(ctx, anyXmlSchemaNodeIdentifier); + if (anyXmlSchema.isPresent()) { + return new YangModeledAnyXmlEffectiveStatementImpl(ctx, anyXmlSchema.get()); + } + } + return new AnyXmlEffectiveStatementImpl(ctx); + } + + private static Optional getAnyXmlSchema( + final StmtContext> ctx, + final SchemaNodeIdentifier contentSchemaPath) { + final StatementContextBase findNode = Utils.findNode(ctx.getRoot(), contentSchemaPath); + if (findNode != null) { + final EffectiveStatement anyXmlSchemaNode = findNode.buildEffective(); + if (anyXmlSchemaNode instanceof ContainerSchemaNode) { + return Optional.of((ContainerSchemaNode) anyXmlSchemaNode); + } + } + return Optional.absent(); } @Override - public void onFullDefinitionDeclared(Mutable> stmt) throws SourceException { - super.onFullDefinitionDeclared(stmt); - SUBSTATEMENT_VALIDATOR.validate(stmt); + protected SubstatementValidator getSubstatementValidator() { + return SUBSTATEMENT_VALIDATOR; } } + @Nonnull @Override public QName getName() { return argument(); @@ -91,11 +123,13 @@ public class AnyxmlStatementImpl extends AbstractDeclaredStatement implem return firstDeclared(WhenStatement.class); } + @Nonnull @Override public Collection getIfFeatures() { return allDeclared(IfFeatureStatement.class); } + @Nonnull @Override public Collection getMusts() { return allDeclared(MustStatement.class);