2 * Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.yangtools.yang.parser.rfc7950.stmt.notification;
10 import com.google.common.collect.ImmutableSet;
11 import java.util.Collection;
12 import java.util.LinkedHashSet;
13 import java.util.Objects;
15 import org.eclipse.jdt.annotation.NonNull;
16 import org.opendaylight.yangtools.yang.common.QName;
17 import org.opendaylight.yangtools.yang.model.api.AugmentationSchemaNode;
18 import org.opendaylight.yangtools.yang.model.api.MustDefinition;
19 import org.opendaylight.yangtools.yang.model.api.NotificationDefinition;
20 import org.opendaylight.yangtools.yang.model.api.SchemaPath;
21 import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement;
22 import org.opendaylight.yangtools.yang.model.api.stmt.NotificationEffectiveStatement;
23 import org.opendaylight.yangtools.yang.model.api.stmt.NotificationStatement;
24 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.AbstractEffectiveDocumentedDataNodeContainer;
25 import org.opendaylight.yangtools.yang.parser.spi.meta.CopyHistory;
26 import org.opendaylight.yangtools.yang.parser.spi.meta.CopyType;
27 import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext;
29 final class NotificationEffectiveStatementImpl
30 extends AbstractEffectiveDocumentedDataNodeContainer<QName, NotificationStatement>
31 implements NotificationDefinition, NotificationEffectiveStatement {
32 private final @NonNull QName qname;
33 private final @NonNull SchemaPath path;
34 private final ImmutableSet<AugmentationSchemaNode> augmentations;
35 private final boolean augmenting;
36 private final boolean addedByUses;
37 private final ImmutableSet<MustDefinition> mustConstraints;
39 NotificationEffectiveStatementImpl(
40 final StmtContext<QName, NotificationStatement, EffectiveStatement<QName, NotificationStatement>> ctx) {
42 this.qname = ctx.coerceStatementArgument();
43 this.path = ctx.getSchemaPath().get();
45 // initSubstatementCollections
46 final Set<AugmentationSchemaNode> augmentationsInit = new LinkedHashSet<>();
47 for (final EffectiveStatement<?, ?> effectiveStatement : effectiveSubstatements()) {
48 if (effectiveStatement instanceof AugmentationSchemaNode) {
49 final AugmentationSchemaNode augmentationSchema = (AugmentationSchemaNode) effectiveStatement;
50 augmentationsInit.add(augmentationSchema);
53 this.augmentations = ImmutableSet.copyOf(augmentationsInit);
54 this.mustConstraints = ImmutableSet.copyOf(this.allSubstatementsOfType(MustDefinition.class));
57 final CopyHistory copyTypesFromOriginal = ctx.getCopyHistory();
58 if (copyTypesFromOriginal.contains(CopyType.ADDED_BY_USES_AUGMENTATION)) {
59 this.augmenting = true;
60 this.addedByUses = true;
62 this.augmenting = copyTypesFromOriginal.contains(CopyType.ADDED_BY_AUGMENTATION);
63 this.addedByUses = copyTypesFromOriginal.contains(CopyType.ADDED_BY_USES);
68 public QName getQName() {
73 public SchemaPath getPath() {
78 public Collection<MustDefinition> getMustConstraints() {
79 return mustConstraints;
83 public Set<AugmentationSchemaNode> getAvailableAugmentations() {
89 public boolean isAugmenting() {
95 public boolean isAddedByUses() {
100 public int hashCode() {
101 final int prime = 31;
103 result = prime * result + Objects.hashCode(qname);
104 result = prime * result + Objects.hashCode(path);
109 public boolean equals(final Object obj) {
116 if (getClass() != obj.getClass()) {
119 final NotificationEffectiveStatementImpl other = (NotificationEffectiveStatementImpl) obj;
120 return Objects.equals(qname, other.qname) && Objects.equals(path, other.path);
124 public String toString() {
125 return NotificationEffectiveStatementImpl.class.getSimpleName() + "[qname=" + qname + ", path=" + path + "]";