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%2FAbstractEffectiveDocumentedDataNodeContainer.java;h=5056929b80d9be52ac22ef0ccadca86a593a434a;hb=30c67c4d780e897d972d60bb79d546b512516f90;hp=f17f3348d5bd41257da5d13001dd2d40cadcb768;hpb=1f53275ab208027b01a60c697f576ce9fca7db22;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/AbstractEffectiveDocumentedDataNodeContainer.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/AbstractEffectiveDocumentedDataNodeContainer.java index f17f3348d5..5056929b80 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/AbstractEffectiveDocumentedDataNodeContainer.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/stmt/rfc6020/effective/AbstractEffectiveDocumentedDataNodeContainer.java @@ -7,17 +7,18 @@ */ package org.opendaylight.yangtools.yang.parser.stmt.rfc6020.effective; -import com.google.common.collect.ImmutableSet; +import org.opendaylight.yangtools.yang.model.util.ExtendedType; +import java.util.LinkedHashSet; +import java.util.LinkedHashMap; +import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableMap; import java.util.Collection; -import java.util.HashMap; import java.util.HashSet; import java.util.Map; import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement; import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext; import org.opendaylight.yangtools.yang.model.api.meta.DeclaredStatement; - import java.util.Set; import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.model.api.DataNodeContainer; @@ -42,30 +43,47 @@ public abstract class AbstractEffectiveDocumentedDataNodeContainer> effectiveSubstatements = effectiveSubstatements(); - Map mutableChildNodes = new HashMap(); - Set mutableGroupings = new HashSet(); - Set mutableUses = new HashSet(); - Set> mutableTypeDefinitions = new HashSet>(); - Set mutablePublicChildNodes = new HashSet(); + Map mutableChildNodes = new LinkedHashMap<>(); + Set mutableGroupings = new HashSet<>(); + Set mutableUses = new HashSet<>(); + Set> mutableTypeDefinitions = new LinkedHashSet<>(); + Set mutablePublicChildNodes = new LinkedHashSet<>(); for (EffectiveStatement effectiveStatement : effectiveSubstatements) { if (effectiveStatement instanceof DataSchemaNode) { DataSchemaNode dataSchemaNode = (DataSchemaNode) effectiveStatement; - - mutableChildNodes.put(dataSchemaNode.getQName(), dataSchemaNode); - mutablePublicChildNodes.add(dataSchemaNode); + if (!mutableChildNodes.containsKey(dataSchemaNode.getQName())) { + mutableChildNodes.put(dataSchemaNode.getQName(), + dataSchemaNode); + mutablePublicChildNodes.add(dataSchemaNode); + } else { + throw EffectiveStmtUtils.createNameCollisionSourceException(ctx, effectiveStatement); + } } if (effectiveStatement instanceof UsesNode) { UsesNode usesNode = (UsesNode) effectiveStatement; - mutableUses.add(usesNode); + if (!mutableUses.contains(usesNode)) { + mutableUses.add(usesNode); + } else { + throw EffectiveStmtUtils.createNameCollisionSourceException(ctx, effectiveStatement); + } } - if (effectiveStatement instanceof TypeDefinition) { - TypeDefinition typeDef = (TypeDefinition) effectiveStatement; - mutableTypeDefinitions.add(typeDef); + if (effectiveStatement instanceof TypeDefEffectiveStatementImpl) { + TypeDefEffectiveStatementImpl typeDef = (TypeDefEffectiveStatementImpl) effectiveStatement; + ExtendedType extendedType = typeDef.buildType(); + if (!mutableTypeDefinitions.contains(extendedType)) { + mutableTypeDefinitions.add(extendedType); + } else { + throw EffectiveStmtUtils.createNameCollisionSourceException(ctx, effectiveStatement); + } } if (effectiveStatement instanceof GroupingDefinition) { GroupingDefinition grp = (GroupingDefinition) effectiveStatement; - mutableGroupings.add(grp); + if (!mutableGroupings.contains(grp)) { + mutableGroupings.add(grp); + } else { + throw EffectiveStmtUtils.createNameCollisionSourceException(ctx, effectiveStatement); + } } }