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%2FAnyXmlEffectiveStatementImpl.java;h=b0b21af6256bf3705a9f62224dabea2c85228743;hb=ea32c2c6fac2ebe9d0e30c9c4e5279c5ef0d2314;hp=ed1e6db53bcf18dd4d85e00a850f730c0cf09150;hpb=30c67c4d780e897d972d60bb79d546b512516f90;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/AnyXmlEffectiveStatementImpl.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/AnyXmlEffectiveStatementImpl.java index ed1e6db53b..b0b21af625 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/AnyXmlEffectiveStatementImpl.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/AnyXmlEffectiveStatementImpl.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,111 +7,24 @@ */ package org.opendaylight.yangtools.yang.parser.stmt.rfc6020.effective; -import java.util.Set; -import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContextUtils; - -import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext.TypeOfCopy; -import java.util.Collection; -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.model.api.stmt.AnyxmlStatement; -import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext; import com.google.common.base.Optional; -import com.google.common.collect.ImmutableList; -import java.util.List; +import java.util.Objects; import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.model.api.AnyXmlSchemaNode; -import org.opendaylight.yangtools.yang.model.api.ConstraintDefinition; import org.opendaylight.yangtools.yang.model.api.DerivableSchemaNode; -import org.opendaylight.yangtools.yang.model.api.SchemaPath; -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.AnyxmlStatement; +import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext; -public class AnyXmlEffectiveStatementImpl extends - AbstractEffectiveDocumentedNode implements +public class AnyXmlEffectiveStatementImpl extends AbstractEffectiveDataSchemaNode implements AnyXmlSchemaNode, DerivableSchemaNode { - private final QName qname; - private final SchemaPath path; - - boolean configuration = true; - AnyXmlSchemaNode original; - ConstraintDefinition constraintsDef; - boolean augmenting; - boolean addedByUses; - ImmutableList unknownNodes; + private final AnyXmlSchemaNode original; public AnyXmlEffectiveStatementImpl( - StmtContext> ctx) { + final StmtContext> ctx) { super(ctx); - this.qname = ctx.getStatementArgument(); - this.path = Utils.getSchemaPath(ctx); - this.constraintsDef = new EffectiveConstraintDefinitionImpl(this); - - initSubstatementCollectionsAndFields(); - initCopyType(ctx); - } - - private void initCopyType( - StmtContext> ctx) { - - Set copyTypesFromOriginal = StmtContextUtils.getCopyTypesFromOriginal(ctx); - - if(copyTypesFromOriginal.contains(TypeOfCopy.ADDED_BY_AUGMENTATION)) { - augmenting = true; - } - if(copyTypesFromOriginal.contains(TypeOfCopy.ADDED_BY_USES)) { - addedByUses = true; - } - if(copyTypesFromOriginal.contains(TypeOfCopy.ADDED_BY_USES_AUGMENTATION)) { - addedByUses = augmenting = true; - } - - if (ctx.getTypeOfCopy() != TypeOfCopy.ORIGINAL) { - original = (AnyXmlSchemaNode) ctx.getOriginalCtx().buildEffective(); - } - } - - private void initSubstatementCollectionsAndFields() { - Collection> effectiveSubstatements = effectiveSubstatements(); - - List unknownNodesInit = new LinkedList<>(); - - boolean configurationInit = false; - for (EffectiveStatement effectiveStatement : effectiveSubstatements) { - if (effectiveStatement instanceof UnknownSchemaNode) { - UnknownSchemaNode unknownNode = (UnknownSchemaNode) effectiveStatement; - unknownNodesInit.add(unknownNode); - } - if (!configurationInit - && effectiveStatement instanceof ConfigEffectiveStatementImpl) { - ConfigEffectiveStatementImpl configStmt = (ConfigEffectiveStatementImpl) effectiveStatement; - this.configuration = configStmt.argument(); - configurationInit = true; - } - } - - this.unknownNodes = ImmutableList.copyOf(unknownNodesInit); - } - - @Override - public QName getQName() { - return qname; - } - - @Override - public SchemaPath getPath() { - return path; - } - - @Override - public boolean isAugmenting() { - return augmenting; - } - - @Override - public boolean isAddedByUses() { - return addedByUses; + this.original = ctx.getOriginalCtx() == null ? null : (AnyXmlSchemaNode) ctx.getOriginalCtx().buildEffective(); } @Override @@ -119,94 +32,38 @@ public class AnyXmlEffectiveStatementImpl extends return Optional.fromNullable(original); } - @Override - public boolean isConfiguration() { - return configuration; - } - - @Override - public ConstraintDefinition getConstraints() { - return constraintsDef; - } - - @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; } - private boolean checkQname(AnyXmlEffectiveStatementImpl other) { - if (qname == null) { - if (other.qname != null) { - return false; - } - } else if (!qname.equals(other.qname)) { - return false; - } - return true; - } - - private boolean checkPath(AnyXmlEffectiveStatementImpl other) { - if (path == null) { - if (other.path != null) { - return false; - } - } else if (!path.equals(other.path)) { - return false; - } - return true; - } - - private boolean checkObject(final Object obj) { - if (obj == null) { - return false; - } - if (getClass() != obj.getClass()) { - return false; - } - return true; - } - @Override public boolean equals(final Object obj) { if (this == obj) { return true; } - - if (!checkObject(obj)) { - return false; - } - - AnyXmlEffectiveStatementImpl other = (AnyXmlEffectiveStatementImpl) obj; - - if (!checkQname(other)) { + if (obj == null) { return false; } - - if (!checkPath(other)) { + if (getClass() != obj.getClass()) { return false; } - return true; + AnyXmlEffectiveStatementImpl other = (AnyXmlEffectiveStatementImpl) obj; + return Objects.equals(getQName(), other.getQName()) && Objects.equals(getPath(), other.getPath()); } @Override public String toString() { - StringBuilder sb = new StringBuilder( - AnyXmlEffectiveStatementImpl.class.getSimpleName()); + StringBuilder sb = new StringBuilder(AnyXmlEffectiveStatementImpl.class.getSimpleName()); sb.append("["); - sb.append("qname=").append(qname); - sb.append(", path=").append(path); + sb.append("qname=").append(getQName()); + sb.append(", path=").append(getPath()); sb.append("]"); return sb.toString(); } - }