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%2Feffective%2FRpcEffectiveStatementImpl.java;h=478a18d8ef697b401df8b7498b1d7a17ead8e1b0;hb=107826f9cd33c98f7e021e7147f1806e25b9c074;hp=1fcecde23e0ab67808ff54699d8608183a6a82c1;hpb=3d283ec6184505ad5e7eefb173044ff383222e9f;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/RpcEffectiveStatementImpl.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/RpcEffectiveStatementImpl.java index 1fcecde23e..478a18d8ef 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/RpcEffectiveStatementImpl.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/RpcEffectiveStatementImpl.java @@ -7,86 +7,53 @@ */ package org.opendaylight.yangtools.yang.parser.stmt.rfc6020.effective; +import com.google.common.collect.ImmutableSet; import java.util.Collection; import java.util.HashSet; -import java.util.LinkedList; -import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.Utils; -import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement; -import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext; -import org.opendaylight.yangtools.yang.model.api.stmt.RpcStatement; -import com.google.common.collect.ImmutableList; -import com.google.common.collect.ImmutableSet; -import java.util.List; +import java.util.LinkedHashSet; +import java.util.Objects; import java.util.Set; import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.model.api.ContainerSchemaNode; import org.opendaylight.yangtools.yang.model.api.GroupingDefinition; import org.opendaylight.yangtools.yang.model.api.RpcDefinition; -import org.opendaylight.yangtools.yang.model.api.SchemaPath; import org.opendaylight.yangtools.yang.model.api.TypeDefinition; -import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode; - -public class RpcEffectiveStatementImpl extends AbstractEffectiveDocumentedNode implements RpcDefinition { - private final QName qname; - private final SchemaPath path; - - private ContainerSchemaNode input; - private ContainerSchemaNode output; +import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement; +import org.opendaylight.yangtools.yang.model.api.stmt.RpcStatement; +import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext; - ImmutableSet> typeDefinitions; - ImmutableSet groupings; - ImmutableList unknownNodes; +public class RpcEffectiveStatementImpl extends AbstractEffectiveSchemaNode implements RpcDefinition { + private final ContainerSchemaNode input; + private final ContainerSchemaNode output; + private final Set> typeDefinitions; + private final Set groupings; - public RpcEffectiveStatementImpl(StmtContext> ctx) { + public RpcEffectiveStatementImpl(final StmtContext> ctx) { super(ctx); - this.qname = ctx.getStatementArgument(); - this.path = Utils.getSchemaPath(ctx); + this.input = firstEffective(InputEffectiveStatementImpl.class); + this.output = firstEffective(OutputEffectiveStatementImpl.class); - initSubstatements(); - - } - - private void initSubstatements() { + // initSubstatements Collection> effectiveSubstatements = effectiveSubstatements(); - - List unknownNodesInit = new LinkedList<>(); Set groupingsInit = new HashSet<>(); - Set> typeDefinitionsInit = new HashSet<>(); - + Set> mutableTypeDefinitions = new LinkedHashSet<>(); for (EffectiveStatement effectiveStatement : effectiveSubstatements) { - if (effectiveStatement instanceof UnknownSchemaNode) { - UnknownSchemaNode unknownNode = (UnknownSchemaNode) effectiveStatement; - unknownNodesInit.add(unknownNode); - } if (effectiveStatement instanceof GroupingDefinition) { GroupingDefinition groupingDefinition = (GroupingDefinition) effectiveStatement; groupingsInit.add(groupingDefinition); } - if (effectiveStatement instanceof TypeDefinition) { - TypeDefinition typeDefinition = (TypeDefinition) effectiveStatement; - typeDefinitionsInit.add(typeDefinition); - } - if (this.input == null && effectiveStatement instanceof InputEffectiveStatementImpl) { - this.input = (InputEffectiveStatementImpl) effectiveStatement; - } - if (this.output == null && effectiveStatement instanceof OutputEffectiveStatementImpl) { - this.output = (OutputEffectiveStatementImpl) effectiveStatement; + if (effectiveStatement instanceof TypeDefEffectiveStatementImpl) { + TypeDefEffectiveStatementImpl typeDef = (TypeDefEffectiveStatementImpl) effectiveStatement; + TypeDefinition type = typeDef.getTypeDefinition(); + if (!mutableTypeDefinitions.contains(type)) { + mutableTypeDefinitions.add(type); + } else { + throw EffectiveStmtUtils.createNameCollisionSourceException(ctx, effectiveStatement); + } } } - - this.unknownNodes = ImmutableList.copyOf(unknownNodesInit); this.groupings = ImmutableSet.copyOf(groupingsInit); - this.typeDefinitions = ImmutableSet.copyOf(typeDefinitionsInit); - } - - @Override - public QName getQName() { - return qname; - } - - @Override - public SchemaPath getPath() { - return path; + this.typeDefinitions = ImmutableSet.copyOf(mutableTypeDefinitions); } @Override @@ -94,19 +61,11 @@ public class RpcEffectiveStatementImpl extends AbstractEffectiveDocumentedNode> getTypeDefinitions() { return typeDefinitions; @@ -117,17 +76,12 @@ public class RpcEffectiveStatementImpl extends AbstractEffectiveDocumentedNode getUnknownSchemaNodes() { - return unknownNodes; - } - @Override public int hashCode() { final int prime = 31; int result = 1; - result = prime * result + ((qname == null) ? 0 : qname.hashCode()); - result = prime * result + ((path == null) ? 0 : path.hashCode()); + result = prime * result + Objects.hashCode(getQName()); + result = prime * result + Objects.hashCode(getPath()); return result; } @@ -143,21 +97,7 @@ public class RpcEffectiveStatementImpl extends AbstractEffectiveDocumentedNode