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%2FTypedefStatementImpl.java;h=0d845ca773c19d579d3a7b703c59bf2f9cf181b9;hb=354c0475d65f0382e6c52b86b98f5c9f3b1a5e74;hp=5ab0e3cb52653859d6a6c62d429301a9001f2b67;hpb=30c67c4d780e897d972d60bb79d546b512516f90;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/TypedefStatementImpl.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/TypedefStatementImpl.java index 5ab0e3cb52..0d845ca773 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/TypedefStatementImpl.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/TypedefStatementImpl.java @@ -15,8 +15,10 @@ import org.opendaylight.yangtools.yang.model.api.stmt.DescriptionStatement; import org.opendaylight.yangtools.yang.model.api.stmt.ReferenceStatement; import org.opendaylight.yangtools.yang.model.api.stmt.StatusStatement; import org.opendaylight.yangtools.yang.model.api.stmt.TypeStatement; +import org.opendaylight.yangtools.yang.model.api.stmt.TypedefEffectiveStatement; import org.opendaylight.yangtools.yang.model.api.stmt.TypedefStatement; import org.opendaylight.yangtools.yang.model.api.stmt.UnitsStatement; +import org.opendaylight.yangtools.yang.parser.spi.SubstatementValidator; import org.opendaylight.yangtools.yang.parser.spi.TypeNamespace; import org.opendaylight.yangtools.yang.parser.spi.meta.AbstractDeclaredStatement; import org.opendaylight.yangtools.yang.parser.spi.meta.AbstractStatementSupport; @@ -25,8 +27,17 @@ import org.opendaylight.yangtools.yang.parser.spi.source.SourceException; import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.effective.TypeDefEffectiveStatementImpl; public class TypedefStatementImpl extends AbstractDeclaredStatement implements TypedefStatement { - - protected TypedefStatementImpl(StmtContext context) { + private static final SubstatementValidator SUBSTATEMENT_VALIDATOR = SubstatementValidator.builder(Rfc6020Mapping + .TYPEDEF) + .add(Rfc6020Mapping.DEFAULT, 0, 1) + .add(Rfc6020Mapping.DESCRIPTION, 0, 1) + .add(Rfc6020Mapping.REFERENCE, 0, 1) + .add(Rfc6020Mapping.STATUS, 0, 1) + .add(Rfc6020Mapping.TYPE, 1, 1) + .add(Rfc6020Mapping.UNITS, 0, 1) + .build(); + + protected TypedefStatementImpl(final StmtContext context) { super(context); } @@ -38,30 +49,31 @@ public class TypedefStatementImpl extends AbstractDeclaredStatement imple } @Override - public QName parseArgumentValue(StmtContext ctx, String value) throws SourceException { + public QName parseArgumentValue(final StmtContext ctx, final String value) { return Utils.qNameFromArgument(ctx, value); } @Override - public TypedefStatement createDeclared(StmtContext ctx) { + public TypedefStatement createDeclared(final StmtContext ctx) { return new TypedefStatementImpl(ctx); } @Override public EffectiveStatement createEffective( - StmtContext> ctx) { + final StmtContext> ctx) { return new TypeDefEffectiveStatementImpl(ctx); } @Override - public void onStatementDefinitionDeclared( - StmtContext.Mutable> stmt) - throws SourceException { + public void onFullDefinitionDeclared(final StmtContext.Mutable> stmt) { + super.onFullDefinitionDeclared(stmt); + SUBSTATEMENT_VALIDATOR.validate(stmt); if (stmt != null && stmt.getParentContext() != null) { - if (stmt.getParentContext().getFromNamespace(TypeNamespace.class, stmt.getStatementArgument()) != null) { - throw new IllegalArgumentException(String.format("Duplicate name for typedef %s", - stmt.getStatementArgument())); - } + final StmtContext existing = stmt.getParentContext() + .getFromNamespace(TypeNamespace.class, stmt.getStatementArgument()); + SourceException.throwIf(existing != null, stmt.getStatementSourceReference(), + "Duplicate name for typedef %s", stmt.getStatementArgument()); stmt.getParentContext().addContext(TypeNamespace.class, stmt.getStatementArgument(), stmt); }