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%2FNotificationEffectiveStatementImpl.java;h=32dedfe635a8d088205c2cea1af92e7facce8388;hb=b392ed1eb50e13d298496fed050cd617c04fa14a;hp=b53772ae92ae421fe1297951e6f15f72ba8cad4c;hpb=ed4fee64bc9bdb4005d11aa35355e9367065998f;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/NotificationEffectiveStatementImpl.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/NotificationEffectiveStatementImpl.java index b53772ae92..32dedfe635 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/NotificationEffectiveStatementImpl.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/NotificationEffectiveStatementImpl.java @@ -7,89 +7,114 @@ */ package org.opendaylight.yangtools.yang.parser.stmt.rfc6020.effective; -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.model.api.stmt.NotificationStatement; -import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext; import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableSet; +import java.util.ArrayList; +import java.util.LinkedHashSet; import java.util.List; +import java.util.Objects; import java.util.Set; +import javax.annotation.Nonnull; import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.model.api.AugmentationSchema; +import org.opendaylight.yangtools.yang.model.api.ConstraintDefinition; import org.opendaylight.yangtools.yang.model.api.NotificationDefinition; 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.NotificationStatement; +import org.opendaylight.yangtools.yang.parser.spi.meta.CopyHistory; +import org.opendaylight.yangtools.yang.parser.spi.meta.CopyType; +import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext; -public class NotificationEffectiveStatementImpl - extends - AbstractEffectiveDocumentedDataNodeContainer - implements NotificationDefinition { +public class NotificationEffectiveStatementImpl extends + AbstractEffectiveDocumentedDataNodeContainer implements NotificationDefinition { private final QName qname; private final SchemaPath path; - ImmutableSet augmentations; - ImmutableList unknownNodes; + private final ConstraintDefinition constraints; + private final Set augmentations; + private final List unknownNodes; + private final boolean augmenting; + private final boolean addedByUses; public NotificationEffectiveStatementImpl( - StmtContext> ctx) { + final StmtContext> ctx) { super(ctx); this.qname = ctx.getStatementArgument(); - this.path = Utils.getSchemaPath(ctx); + this.path = ctx.getSchemaPath().get(); - initSubstatementCollections(); - } - - private void initSubstatementCollections() { - Collection> effectiveSubstatements = effectiveSubstatements(); + this.constraints = EffectiveConstraintDefinitionImpl.forParent(this); - List unknownNodesInit = new LinkedList<>(); - Set augmentationsInit = new HashSet<>(); - - for (EffectiveStatement effectiveStatement : effectiveSubstatements) { + // initSubstatementCollections + final List unknownNodesInit = new ArrayList<>(); + final Set augmentationsInit = new LinkedHashSet<>(); + for (final EffectiveStatement effectiveStatement : effectiveSubstatements()) { if (effectiveStatement instanceof UnknownSchemaNode) { - UnknownSchemaNode unknownNode = (UnknownSchemaNode) effectiveStatement; + final UnknownSchemaNode unknownNode = (UnknownSchemaNode) effectiveStatement; unknownNodesInit.add(unknownNode); } if (effectiveStatement instanceof AugmentationSchema) { - AugmentationSchema augmentationSchema = (AugmentationSchema) effectiveStatement; + final AugmentationSchema augmentationSchema = (AugmentationSchema) effectiveStatement; augmentationsInit.add(augmentationSchema); } } - this.unknownNodes = ImmutableList.copyOf(unknownNodesInit); this.augmentations = ImmutableSet.copyOf(augmentationsInit); + + // initCopyType + final CopyHistory copyTypesFromOriginal = ctx.getCopyHistory(); + if (copyTypesFromOriginal.contains(CopyType.ADDED_BY_USES_AUGMENTATION)) { + this.addedByUses = this.augmenting = true; + } else { + this.augmenting = copyTypesFromOriginal.contains(CopyType.ADDED_BY_AUGMENTATION); + this.addedByUses = copyTypesFromOriginal.contains(CopyType.ADDED_BY_USES); + } } + @Nonnull @Override public QName getQName() { return qname; } + @Nonnull @Override public SchemaPath getPath() { return path; } + @Override + public ConstraintDefinition getConstraints() { + return constraints; + } + @Override public Set getAvailableAugmentations() { return augmentations; } + @Nonnull @Override public List getUnknownSchemaNodes() { return unknownNodes; } + @Override + public boolean isAugmenting() { + return augmenting; + } + + @Override + public boolean isAddedByUses() { + return addedByUses; + } + @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(qname); + result = prime * result + Objects.hashCode(path); return result; } @@ -105,29 +130,11 @@ public class NotificationEffectiveStatementImpl return false; } final NotificationEffectiveStatementImpl other = (NotificationEffectiveStatementImpl) 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(qname, other.qname) && Objects.equals(path, other.path); } @Override public String toString() { - StringBuilder sb = new StringBuilder( - NotificationEffectiveStatementImpl.class.getSimpleName()); - sb.append("[qname=").append(qname).append(", path=").append(path) - .append("]"); - return sb.toString(); + return NotificationEffectiveStatementImpl.class.getSimpleName() + "[qname=" + qname + ", path=" + path + "]"; } -} \ No newline at end of file +}