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%2FSubmoduleStatementImpl.java;h=41c0a5343d448faf0b6ab2a50a6e43b1c3d05494;hb=refs%2Fchanges%2F68%2F32868%2F1;hp=7349082ec503e8610f5e2bb226838306bba575c2;hpb=beaf8f16074af36d2e822bbd3fc60d7a5ca66b98;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/SubmoduleStatementImpl.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/SubmoduleStatementImpl.java index 7349082ec5..41c0a5343d 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/SubmoduleStatementImpl.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/SubmoduleStatementImpl.java @@ -7,41 +7,67 @@ */ package org.opendaylight.yangtools.yang.parser.stmt.rfc6020; -import static org.opendaylight.yangtools.yang.parser.spi.meta.StmtContextUtils.firstAttributeOf; +import static org.opendaylight.yangtools.yang.parser.spi.SubstatementValidator.MAX; import static org.opendaylight.yangtools.yang.parser.spi.meta.StmtContextUtils.findFirstDeclaredSubstatement; +import static org.opendaylight.yangtools.yang.parser.spi.meta.StmtContextUtils.firstAttributeOf; -import org.opendaylight.yangtools.yang.parser.spi.source.BelongsToPrefixToModuleName; - -import org.opendaylight.yangtools.yang.model.api.stmt.PrefixStatement; -import org.opendaylight.yangtools.yang.parser.spi.SubmoduleNamespace; import com.google.common.base.Optional; import java.net.URI; import java.util.Date; +import org.opendaylight.yangtools.yang.common.SimpleDateFormatUtil; import org.opendaylight.yangtools.yang.model.api.ModuleIdentifier; import org.opendaylight.yangtools.yang.model.api.Rfc6020Mapping; import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement; -import org.opendaylight.yangtools.yang.model.api.stmt.RevisionStatement; -import org.opendaylight.yangtools.yang.parser.builder.impl.ModuleIdentifierImpl; -import org.opendaylight.yangtools.yang.parser.spi.meta.AbstractStatementSupport; -import org.opendaylight.yangtools.yang.parser.spi.meta.InferenceException; -import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext.Mutable; -import org.opendaylight.yangtools.yang.parser.spi.source.SourceException; import org.opendaylight.yangtools.yang.model.api.stmt.BelongsToStatement; +import org.opendaylight.yangtools.yang.model.api.stmt.PrefixStatement; import org.opendaylight.yangtools.yang.model.api.stmt.SubmoduleStatement; import org.opendaylight.yangtools.yang.model.api.stmt.YangVersionStatement; +import org.opendaylight.yangtools.yang.parser.builder.impl.ModuleIdentifierImpl; +import org.opendaylight.yangtools.yang.parser.spi.SubmoduleNamespace; +import org.opendaylight.yangtools.yang.parser.spi.SubstatementValidator; +import org.opendaylight.yangtools.yang.parser.spi.meta.AbstractStatementSupport; import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext; - -public class SubmoduleStatementImpl extends - AbstractRootStatement implements SubmoduleStatement { - - protected SubmoduleStatementImpl( - StmtContext context) { +import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext.Mutable; +import org.opendaylight.yangtools.yang.parser.spi.source.BelongsToPrefixToModuleName; +import org.opendaylight.yangtools.yang.parser.spi.source.SourceException; +import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.effective.SubmoduleEffectiveStatementImpl; + +public class SubmoduleStatementImpl extends AbstractRootStatement implements SubmoduleStatement { + private static final SubstatementValidator SUBSTATEMENT_VALIDATOR = SubstatementValidator.builder(Rfc6020Mapping + .SUBMODULE) + .add(Rfc6020Mapping.ANYXML, 0, MAX) + .add(Rfc6020Mapping.AUGMENT, 0, MAX) + .add(Rfc6020Mapping.BELONGS_TO, 1, 1) + .add(Rfc6020Mapping.CHOICE, 0, MAX) + .add(Rfc6020Mapping.CONTACT, 0, 1) + .add(Rfc6020Mapping.CONTAINER, 0, MAX) + .add(Rfc6020Mapping.DESCRIPTION, 0, 1) + .add(Rfc6020Mapping.DEVIATION, 0, MAX) + .add(Rfc6020Mapping.EXTENSION, 0, MAX) + .add(Rfc6020Mapping.FEATURE, 0, MAX) + .add(Rfc6020Mapping.GROUPING, 0, MAX) + .add(Rfc6020Mapping.IDENTITY, 0, MAX) + .add(Rfc6020Mapping.IMPORT, 0, MAX) + .add(Rfc6020Mapping.INCLUDE, 0, MAX) + .add(Rfc6020Mapping.LEAF, 0, MAX) + .add(Rfc6020Mapping.LEAF_LIST, 0, MAX) + .add(Rfc6020Mapping.LIST, 0, MAX) + .add(Rfc6020Mapping.NOTIFICATION, 0, MAX) + .add(Rfc6020Mapping.ORGANIZATION, 0, 1) + .add(Rfc6020Mapping.REFERENCE, 0, 1) + .add(Rfc6020Mapping.REVISION, 0, MAX) + .add(Rfc6020Mapping.RPC, 0, MAX) + .add(Rfc6020Mapping.TYPEDEF, 0, MAX) + .add(Rfc6020Mapping.USES, 0, MAX) + .add(Rfc6020Mapping.YANG_VERSION, 0, 1) + .build(); + + protected SubmoduleStatementImpl(StmtContext context) { super(context); } - public static class Definition - extends - AbstractStatementSupport> { + public static class Definition extends AbstractStatementSupport> { public Definition() { super(Rfc6020Mapping.SUBMODULE); @@ -61,7 +87,7 @@ public class SubmoduleStatementImpl extends @Override public EffectiveStatement createEffective( StmtContext> ctx) { - throw new UnsupportedOperationException(); + return new SubmoduleEffectiveStatementImpl(ctx); } @Override @@ -69,10 +95,10 @@ public class SubmoduleStatementImpl extends Mutable> stmt) throws SourceException { - Optional revisionDate = Optional - .fromNullable(firstAttributeOf( - stmt.declaredSubstatements(), - RevisionStatement.class)); + Optional revisionDate = Optional.fromNullable(Utils.getLatestRevision(stmt.declaredSubstatements())); + if (!revisionDate.isPresent()) { + revisionDate = Optional.of(SimpleDateFormatUtil.DEFAULT_DATE_REV); + } ModuleIdentifier submoduleIdentifier = new ModuleIdentifierImpl( stmt.getStatementArgument(), Optional. absent(), @@ -85,9 +111,9 @@ public class SubmoduleStatementImpl extends StmtContext prefixSubStmtCtx = findFirstDeclaredSubstatement( stmt, 0, BelongsToStatement.class, PrefixStatement.class); - if(prefixSubStmtCtx == null) { - throw new IllegalArgumentException("Prefix of belongsTo statement is missing in submodule [" - + stmt.getStatementArgument() + "]."); + if (prefixSubStmtCtx == null) { + throw new SourceException(String.format("Prefix of belongsTo statement is missing in submodule [%s]", + stmt.getStatementArgument()), stmt.getStatementSourceReference()); } String prefix = (String) prefixSubStmtCtx.getStatementArgument(); @@ -96,6 +122,12 @@ public class SubmoduleStatementImpl extends belongsToModuleName); } + @Override + public void onFullDefinitionDeclared(Mutable> stmt) throws SourceException { + super.onFullDefinitionDeclared(stmt); + SUBSTATEMENT_VALIDATOR.validate(stmt); + } } @Override