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=187c593838177ccd21ba20a59d5e77d245804100;hb=e99bf7da4cf4f715e6d899a8c41a8df2853e3055;hp=65e336ca0a039d241b6ef8ec7adaa4f468c4012d;hpb=5f4fc14e4e2be49a7aab7e60fb155f717ef49484;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 65e336ca0a..187c593838 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,57 +7,36 @@ */ package org.opendaylight.yangtools.yang.parser.stmt.rfc6020.effective; -import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableSet; import java.util.Collection; import java.util.HashSet; -import java.util.LinkedList; -import java.util.List; 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; 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; -import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.Utils; -public class RpcEffectiveStatementImpl extends AbstractEffectiveDocumentedNode implements RpcDefinition { - private final QName qname; - private final SchemaPath path; - - private ContainerSchemaNode input; - private ContainerSchemaNode output; - - private Set> typeDefinitions; - private Set groupings; - private List 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(final StmtContext> ctx) { super(ctx); - this.qname = ctx.getStatementArgument(); - this.path = Utils.getSchemaPath(ctx); - - initSubstatements(); - } + this.input = firstEffective(InputEffectiveStatementImpl.class); + this.output = firstEffective(OutputEffectiveStatementImpl.class); - private void initSubstatements() { + // initSubstatements Collection> effectiveSubstatements = effectiveSubstatements(); - - List unknownNodesInit = new LinkedList<>(); Set groupingsInit = new HashSet<>(); Set> typeDefinitionsInit = new HashSet<>(); - 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); @@ -66,47 +45,21 @@ public class RpcEffectiveStatementImpl extends AbstractEffectiveDocumentedNode 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; - } } - - 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; - } - @Override public ContainerSchemaNode getInput() { return input; } - void setInput(final ContainerSchemaNode input) { - this.input = input; - } - @Override public ContainerSchemaNode getOutput() { return output; } - void setOutput(final ContainerSchemaNode output) { - this.output = output; - } - @Override public Set> getTypeDefinitions() { return typeDefinitions; @@ -117,17 +70,12 @@ public class RpcEffectiveStatementImpl extends AbstractEffectiveDocumentedNode getUnknownSchemaNodes() { - return unknownNodes; - } - @Override public int hashCode() { final int prime = 31; int result = 1; - result = prime * result + Objects.hashCode(qname); - result = prime * result + Objects.hashCode(path); + result = prime * result + Objects.hashCode(getQName()); + result = prime * result + Objects.hashCode(getPath()); return result; } @@ -143,7 +91,7 @@ public class RpcEffectiveStatementImpl extends AbstractEffectiveDocumentedNode