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%2FOutputEffectiveStatementImpl.java;h=6c3b619a170130c58db967dd2ec93ed947542284;hb=179aa00ecdcbc9a8c1db053f07e030d7d9564221;hp=0d061e115b260b861d0c0fcdbe095e602a6e9242;hpb=fc97aa32d83e94cf8a8d61df31541b0b9b9f980e;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/OutputEffectiveStatementImpl.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/OutputEffectiveStatementImpl.java index 0d061e115b..6c3b619a17 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/OutputEffectiveStatementImpl.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/OutputEffectiveStatementImpl.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,149 +7,25 @@ */ package org.opendaylight.yangtools.yang.parser.stmt.rfc6020.effective; -import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext.TypeOfCopy; - -import java.util.HashSet; -import java.util.LinkedList; -import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.Utils; -import com.google.common.collect.ImmutableList; -import com.google.common.collect.ImmutableSet; -import java.util.List; -import java.util.Set; -import org.opendaylight.yangtools.yang.model.api.AugmentationSchema; -import org.opendaylight.yangtools.yang.model.api.ConstraintDefinition; -import org.opendaylight.yangtools.yang.model.api.SchemaPath; -import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode; +import java.util.Objects; import org.opendaylight.yangtools.yang.common.QName; -import org.opendaylight.yangtools.yang.model.api.ContainerSchemaNode; -import java.util.Collection; -import org.opendaylight.yangtools.yang.model.api.stmt.OutputStatement; import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement; +import org.opendaylight.yangtools.yang.model.api.stmt.OutputStatement; import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext; -public class OutputEffectiveStatementImpl extends - AbstractEffectiveDocumentedDataNodeContainer - implements ContainerSchemaNode { - - private final QName qname; - private final SchemaPath path; - private final boolean presence; - - boolean augmenting; - boolean addedByUses; - boolean configuration; - ContainerSchemaNode original; - ConstraintDefinition constraints; - - private ImmutableSet augmentations; - private ImmutableList unknownNodes; +public final class OutputEffectiveStatementImpl extends AbstractEffectiveContainerSchemaNode { public OutputEffectiveStatementImpl( - StmtContext> ctx) { + final StmtContext> ctx) { super(ctx); - - qname = ctx.getStatementArgument(); - path = Utils.getSchemaPath(ctx); - presence = (firstEffective(PresenceEffectiveStatementImpl.class) == null) ? false - : true; - // :TODO init other fields - - initSubstatementCollections(); - initCopyType(ctx); - } - - private void initCopyType( - StmtContext> ctx) { - - TypeOfCopy typeOfCopy = ctx.getTypeOfCopy(); - switch (typeOfCopy) { - case ADDED_BY_AUGMENTATION: - augmenting = true; - original = (ContainerSchemaNode) ctx.getOriginalCtx() - .buildEffective(); - break; - case ADDED_BY_USES: - addedByUses = true; - original = (ContainerSchemaNode) ctx.getOriginalCtx() - .buildEffective(); - break; - default: - break; - } - } - - private void initSubstatementCollections() { - Collection> effectiveSubstatements = effectiveSubstatements(); - - List unknownNodesInit = new LinkedList<>(); - Set augmentationsInit = new HashSet<>(); - - for (EffectiveStatement effectiveStatement : effectiveSubstatements) { - if (effectiveStatement instanceof UnknownSchemaNode) { - UnknownSchemaNode unknownNode = (UnknownSchemaNode) effectiveStatement; - unknownNodesInit.add(unknownNode); - } - if (effectiveStatement instanceof AugmentationSchema) { - AugmentationSchema augmentationSchema = (AugmentationSchema) effectiveStatement; - augmentationsInit.add(augmentationSchema); - } - } - - this.unknownNodes = ImmutableList.copyOf(unknownNodesInit); - this.augmentations = ImmutableSet.copyOf(augmentationsInit); - } - - @Override - public QName getQName() { - return qname; - } - - @Override - public SchemaPath getPath() { - return path; - } - - @Override - public boolean isAugmenting() { - return augmenting; - } - - @Override - public boolean isAddedByUses() { - return addedByUses; - } - - @Override - public boolean isConfiguration() { - return configuration; - } - - @Override - public ConstraintDefinition getConstraints() { - return constraints; - } - - @Override - public Set getAvailableAugmentations() { - return augmentations; - } - - @Override - public boolean isPresenceContainer() { - return presence; - } - - @Override - public List 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; } @@ -165,26 +41,12 @@ public class OutputEffectiveStatementImpl extends return false; } OutputEffectiveStatementImpl other = (OutputEffectiveStatementImpl) obj; - if (qname == null) { - if (other.qname != null) { - return false; - } - } else if (!qname.equals(other.qname)) { - return false; - } - if (path == null) { - if (other.path != null) { - return false; - } - } else if (!path.equals(other.path)) { - return false; - } - return true; + return Objects.equals(getQName(), other.getQName()) && Objects.equals(getPath(), other.getPath()); } @Override public String toString() { - return "RPC Output " + qname.getLocalName(); + return "RPC Output " + getQName().getLocalName(); } }