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;
10 import com.google.common.collect.ImmutableSet;
11 import java.util.LinkedHashSet;
12 import java.util.Optional;
14 import org.eclipse.jdt.annotation.NonNull;
15 import org.opendaylight.yangtools.yang.common.QName;
16 import org.opendaylight.yangtools.yang.model.api.AugmentationSchemaNode;
17 import org.opendaylight.yangtools.yang.model.api.AugmentationTarget;
18 import org.opendaylight.yangtools.yang.model.api.DataSchemaNode;
19 import org.opendaylight.yangtools.yang.model.api.RevisionAwareXPath;
20 import org.opendaylight.yangtools.yang.model.api.SchemaPath;
21 import org.opendaylight.yangtools.yang.model.api.meta.DeclaredStatement;
22 import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement;
23 import org.opendaylight.yangtools.yang.model.api.stmt.WhenEffectiveStatement;
24 import org.opendaylight.yangtools.yang.parser.spi.meta.CopyHistory;
25 import org.opendaylight.yangtools.yang.parser.spi.meta.CopyType;
26 import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext;
28 public abstract class AbstractEffectiveSimpleDataNodeContainer<D extends DeclaredStatement<QName>> extends
29 AbstractEffectiveDocumentedDataNodeContainer<QName, D> implements AugmentationTarget, DataSchemaNode {
31 private final ImmutableSet<AugmentationSchemaNode> augmentations;
32 private final RevisionAwareXPath whenCondition;
33 private final @NonNull SchemaPath path;
34 private final boolean configuration;
35 private final boolean addedByUses;
36 private final boolean augmenting;
38 protected AbstractEffectiveSimpleDataNodeContainer(final StmtContext<QName, D, ?> ctx) {
41 this.path = ctx.getSchemaPath().get();
42 this.configuration = ctx.isConfiguration();
44 whenCondition = findFirstEffectiveSubstatementArgument(WhenEffectiveStatement.class).orElse(null);
46 // initSubstatementCollectionsAndFields
48 Set<AugmentationSchemaNode> augmentationsInit = new LinkedHashSet<>();
49 for (EffectiveStatement<?, ?> effectiveStatement : effectiveSubstatements()) {
50 if (effectiveStatement instanceof AugmentationSchemaNode) {
51 augmentationsInit.add((AugmentationSchemaNode) effectiveStatement);
54 this.augmentations = ImmutableSet.copyOf(augmentationsInit);
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() {
69 return path.getLastComponent();
73 public SchemaPath getPath() {
79 public boolean isAugmenting() {
85 public boolean isAddedByUses() {
90 public boolean isConfiguration() {
95 public Set<AugmentationSchemaNode> getAvailableAugmentations() {
100 public final Optional<RevisionAwareXPath> getWhenCondition() {
101 return Optional.ofNullable(whenCondition);