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%2Fbuilder%2Fimpl%2FIdentitySchemaNodeBuilder.java;h=8c571dd8e25259eba5c2cbc42eaa67e6801da6df;hb=42abb28b99a02f9580f4676ce5c315628e5bcd24;hp=63243d495ff1fa212d0e9d64a2a7ff260799bfcf;hpb=475f8732893197eb41bfa695a4c7dedb45f25f06;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/IdentitySchemaNodeBuilder.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/IdentitySchemaNodeBuilder.java index 63243d495f..8c571dd8e2 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/IdentitySchemaNodeBuilder.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/IdentitySchemaNodeBuilder.java @@ -7,17 +7,22 @@ */ package org.opendaylight.yangtools.yang.parser.builder.impl; -import java.util.*; - +import com.google.common.base.Preconditions; +import com.google.common.collect.ImmutableList; +import java.util.HashSet; +import java.util.Set; import org.opendaylight.yangtools.yang.common.QName; -import org.opendaylight.yangtools.yang.model.api.*; -import org.opendaylight.yangtools.yang.parser.builder.api.AbstractSchemaNodeBuilder; -import org.opendaylight.yangtools.yang.parser.util.Comparators; -import org.opendaylight.yangtools.yang.parser.util.YangParseException; +import org.opendaylight.yangtools.yang.model.api.IdentitySchemaNode; +import org.opendaylight.yangtools.yang.model.api.SchemaPath; +import org.opendaylight.yangtools.yang.parser.builder.api.UnknownSchemaNodeBuilder; +import org.opendaylight.yangtools.yang.parser.builder.util.AbstractSchemaNodeBuilder; +/** + * @deprecated Pre-Beryllium implementation, scheduled for removal. + */ +@Deprecated public final class IdentitySchemaNodeBuilder extends AbstractSchemaNodeBuilder { - private boolean isBuilt; - private final IdentitySchemaNodeImpl instance; + private IdentitySchemaNodeImpl instance; private IdentitySchemaNode baseIdentity; private IdentitySchemaNodeBuilder baseIdentityBuilder; private final Set derivedIdentities = new HashSet<>(); @@ -25,76 +30,41 @@ public final class IdentitySchemaNodeBuilder extends AbstractSchemaNodeBuilder { IdentitySchemaNodeBuilder(final String moduleName, final int line, final QName qname, final SchemaPath path) { super(moduleName, line, qname); - this.schemaPath = path; - instance = new IdentitySchemaNodeImpl(qname, path, derivedIdentities); + this.schemaPath = Preconditions.checkNotNull(path, "Schema Path must not be null"); } - @Override - public IdentitySchemaNode build() { - if (!isBuilt) { - if (!(parentBuilder instanceof ModuleBuilder)) { - throw new YangParseException(moduleName, line, "Identity can be defined only under module (was" + parentBuilder + ")"); - } - if (baseIdentity == null) { - if(baseIdentityBuilder != null) { - baseIdentityBuilder.addDerivedIdentity(instance); - baseIdentity = baseIdentityBuilder.build(); - } - } else { - if(baseIdentity instanceof IdentitySchemaNodeImpl) { - ((IdentitySchemaNodeImpl)baseIdentity).toBuilder().addDerivedIdentity(instance); - } - } - instance.setBaseIdentity(baseIdentity); - - // UNKNOWN NODES - for (UnknownSchemaNodeBuilder b : addedUnknownNodes) { - unknownNodes.add(b.build()); - } - Collections.sort(unknownNodes, Comparators.SCHEMA_NODE_COMP); - instance.addUnknownSchemaNodes(unknownNodes); - - isBuilt = true; - } - - return instance; + IdentitySchemaNodeBuilder(final String moduleName, final IdentitySchemaNode base) { + super(moduleName, 0, base.getQName()); + schemaPath = base.getPath(); + derivedIdentities.addAll(base.getDerivedIdentities()); + unknownNodes.addAll(base.getUnknownSchemaNodes()); } @Override - public SchemaPath getPath() { - return instance.path; - } + public IdentitySchemaNode build() { + if (instance != null) { + return instance; + } - @Override - public String getDescription() { - return instance.description; - } + instance = new IdentitySchemaNodeImpl(qname, schemaPath, derivedIdentities); - @Override - public void setDescription(final String description) { instance.description = description; - } - - @Override - public String getReference() { - return instance.reference; - } - - @Override - public void setReference(final String reference) { instance.reference = reference; - } + instance.status = status; - @Override - public Status getStatus() { - return instance.status; - } + if (baseIdentityBuilder != null) { + baseIdentityBuilder.addDerivedIdentity(instance); + baseIdentity = baseIdentityBuilder.build(); + } + instance.baseIdentity = baseIdentity; - @Override - public void setStatus(Status status) { - if (status != null) { - instance.status = status; + // UNKNOWN NODES + for (UnknownSchemaNodeBuilder b : addedUnknownNodes) { + unknownNodes.add(b.build()); } + instance.unknownNodes = ImmutableList.copyOf(unknownNodes); + + return instance; } public String getBaseIdentityName() { @@ -109,11 +79,7 @@ public final class IdentitySchemaNodeBuilder extends AbstractSchemaNodeBuilder { this.baseIdentityBuilder = baseType; } - public void setBaseIdentity(final IdentitySchemaNode baseType) { - this.baseIdentity = baseType; - } - - public void addDerivedIdentity(IdentitySchemaNode derivedIdentity) { + void addDerivedIdentity(final IdentitySchemaNode derivedIdentity) { if (derivedIdentity != null) { derivedIdentities.add(derivedIdentity); } @@ -124,123 +90,4 @@ public final class IdentitySchemaNodeBuilder extends AbstractSchemaNodeBuilder { return "identity " + qname.getLocalName(); } - public final class IdentitySchemaNodeImpl implements IdentitySchemaNode { - private final QName qname; - private final SchemaPath path; - private IdentitySchemaNode baseIdentity; - private final Set derivedIdentities; - private String description; - private String reference; - private Status status = Status.CURRENT; - private final List unknownNodes = new ArrayList<>(); - - private IdentitySchemaNodeImpl(final QName qname, final SchemaPath path, final Set derivedIdentities) { - this.qname = qname; - this.path = path; - this.derivedIdentities = derivedIdentities; - } - - @Override - public QName getQName() { - return qname; - } - - @Override - public IdentitySchemaNode getBaseIdentity() { - return baseIdentity; - } - - private void setBaseIdentity(final IdentitySchemaNode baseIdentity) { - this.baseIdentity = baseIdentity; - } - - @Override - public Set getDerivedIdentities() { - return Collections.unmodifiableSet(derivedIdentities); - } - - @Override - public String getDescription() { - return description; - } - - @Override - public String getReference() { - return reference; - } - - @Override - public Status getStatus() { - return status; - } - - @Override - public SchemaPath getPath() { - return path; - } - - @Override - public List getUnknownSchemaNodes() { - return Collections.unmodifiableList(unknownNodes); - } - - private void addUnknownSchemaNodes(List unknownSchemaNodes) { - if (unknownSchemaNodes != null) { - this.unknownNodes.addAll(unknownSchemaNodes); - } - } - - public IdentitySchemaNodeBuilder toBuilder() { - return IdentitySchemaNodeBuilder.this; - } - - @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()); - return result; - } - - @Override - public boolean equals(Object obj) { - if (this == obj) { - return true; - } - if (obj == null) { - return false; - } - if (getClass() != obj.getClass()) { - return false; - } - IdentitySchemaNodeImpl other = (IdentitySchemaNodeImpl) 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; - } - - @Override - public String toString() { - StringBuilder sb = new StringBuilder(IdentitySchemaNodeImpl.class.getSimpleName()); - sb.append("["); - sb.append("base=" + baseIdentity); - sb.append(", qname=" + qname); - sb.append("]"); - return sb.toString(); - } - } - }