X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;ds=sidebyside;f=yang%2Fyang-parser-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fyangtools%2Fyang%2Fparser%2Fbuilder%2Fimpl%2FNotificationBuilder.java;h=fb1b7af7c76592c9efc6c4fcf8c5cf8e729f8386;hb=928ed47df94246551cc726ab0c32f48066850aab;hp=824bd1a262cc2cf8a1cef670ab5435a288de7252;hpb=49423f30f3759958b5706dd78743f06f9c1475ce;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/NotificationBuilder.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/NotificationBuilder.java index 824bd1a262..fb1b7af7c7 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/NotificationBuilder.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/NotificationBuilder.java @@ -7,113 +7,59 @@ */ package org.opendaylight.yangtools.yang.parser.builder.impl; -import java.net.URI; +import com.google.common.base.Preconditions; +import com.google.common.collect.ImmutableList; +import com.google.common.collect.ImmutableSet; import java.util.ArrayList; -import java.util.Date; import java.util.List; -import java.util.Set; - import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.model.api.AugmentationSchema; -import org.opendaylight.yangtools.yang.model.api.DataSchemaNode; -import org.opendaylight.yangtools.yang.model.api.GroupingDefinition; import org.opendaylight.yangtools.yang.model.api.NotificationDefinition; import org.opendaylight.yangtools.yang.model.api.SchemaPath; -import org.opendaylight.yangtools.yang.model.api.Status; -import org.opendaylight.yangtools.yang.model.api.TypeDefinition; -import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode; -import org.opendaylight.yangtools.yang.model.api.UsesNode; -import org.opendaylight.yangtools.yang.parser.builder.api.AbstractDataNodeContainerBuilder; import org.opendaylight.yangtools.yang.parser.builder.api.AugmentationSchemaBuilder; import org.opendaylight.yangtools.yang.parser.builder.api.AugmentationTargetBuilder; -import org.opendaylight.yangtools.yang.parser.builder.api.DataSchemaNodeBuilder; -import org.opendaylight.yangtools.yang.parser.builder.api.GroupingBuilder; import org.opendaylight.yangtools.yang.parser.builder.api.SchemaNodeBuilder; -import org.opendaylight.yangtools.yang.parser.builder.api.TypeDefinitionBuilder; -import org.opendaylight.yangtools.yang.parser.builder.api.UsesNodeBuilder; -import org.opendaylight.yangtools.yang.parser.util.ParserUtils; +import org.opendaylight.yangtools.yang.parser.builder.api.UnknownSchemaNodeBuilder; +import org.opendaylight.yangtools.yang.parser.builder.util.AbstractDocumentedDataNodeContainerBuilder; import org.opendaylight.yangtools.yang.parser.util.YangParseException; -import com.google.common.base.Preconditions; -import com.google.common.collect.ImmutableList; -import com.google.common.collect.ImmutableSet; - -public final class NotificationBuilder extends AbstractDataNodeContainerBuilder implements SchemaNodeBuilder, - AugmentationTargetBuilder { +public final class NotificationBuilder extends AbstractDocumentedDataNodeContainerBuilder implements SchemaNodeBuilder, +AugmentationTargetBuilder { private NotificationDefinitionImpl instance; // SchemaNode args private SchemaPath schemaPath; - private String description; - private String reference; - private Status status = Status.CURRENT; // AugmentationTarget args private final List augmentations = new ArrayList<>(); private final List augmentationBuilders = new ArrayList<>(); NotificationBuilder(final String moduleName, final int line, final QName qname, final SchemaPath path) { super(moduleName, line, qname); - this.schemaPath = path; + this.schemaPath = Preconditions.checkNotNull(path, "Schema Path must not be null"); } - NotificationBuilder(final String moduleName, final int line, final QName qname, final SchemaPath path, final NotificationDefinition base) { - super(moduleName, line, qname); - this.schemaPath = path; - - description = base.getDescription(); - reference = base.getReference(); - status = base.getStatus(); - - URI ns = qname.getNamespace(); - Date rev = qname.getRevision(); - String pref = qname.getPrefix(); - addedChildNodes.addAll(ParserUtils.wrapChildNodes(moduleName, line, base.getChildNodes(), path, ns, rev, pref)); - addedGroupings.addAll(ParserUtils.wrapGroupings(moduleName, line, base.getGroupings(), path, ns, rev, pref)); - addedTypedefs.addAll(ParserUtils.wrapTypedefs(moduleName, line, base, path, ns, rev, pref)); - addedUnknownNodes.addAll(ParserUtils.wrapUnknownNodes(moduleName, line, base.getUnknownSchemaNodes(), path, ns, - rev, pref)); + NotificationBuilder(final String moduleName, final int line, final QName qname, final SchemaPath path, + final NotificationDefinition base) { + super(moduleName, line, qname, path, base); + this.schemaPath = Preconditions.checkNotNull(path, "Schema Path must not be null"); + addedUnknownNodes.addAll(BuilderUtils.wrapUnknownNodes(moduleName, line, base.getUnknownSchemaNodes(), path, + qname)); augmentations.addAll(base.getAvailableAugmentations()); - usesNodes.addAll(base.getUses()); + } @Override public NotificationDefinition build() { - if (!(parentBuilder instanceof ModuleBuilder)) { - throw new YangParseException(moduleName, line, "Notification can be defined only under module (was " + parentBuilder + ")"); + if (!(getParent() instanceof ModuleBuilder)) { + throw new YangParseException(getModuleName(), getLine(), + "Notification can be defined only under module (was " + getParent() + ")"); } if (instance != null) { return instance; } + buildChildren(); - instance = new NotificationDefinitionImpl(qname, schemaPath); - - instance.description = description; - instance.reference = reference; - instance.status = status; - - // CHILD NODES - for (DataSchemaNodeBuilder node : addedChildNodes) { - childNodes.add(node.build()); - } - instance.childNodes = ImmutableSet.copyOf(childNodes); - - // GROUPINGS - for (GroupingBuilder builder : addedGroupings) { - groupings.add(builder.build()); - } - instance.groupings = ImmutableSet.copyOf(groupings); - - // TYPEDEFS - for (TypeDefinitionBuilder entry : addedTypedefs) { - typedefs.add(entry.build()); - } - instance.typeDefinitions = ImmutableSet.copyOf(typedefs); - - // USES - for (UsesNodeBuilder builder : addedUsesNodes) { - usesNodes.add(builder.build()); - } - instance.uses = ImmutableSet.copyOf(usesNodes); + instance = new NotificationDefinitionImpl(qname, schemaPath, this); // AUGMENTATIONS for (AugmentationSchemaBuilder builder : augmentationBuilders) { @@ -130,57 +76,16 @@ public final class NotificationBuilder extends AbstractDataNodeContainerBuilder return instance; } - - @Override - public Set getTypeDefinitionBuilders() { - return addedTypedefs; - } - - @Override - public void addTypedef(final TypeDefinitionBuilder type) { - addedTypedefs.add(type); - } - @Override public SchemaPath getPath() { return schemaPath; } @Override - public void setPath(SchemaPath path) { + public void setPath(final SchemaPath path) { this.schemaPath = path; } - @Override - public String getDescription() { - return description; - } - - @Override - public void setDescription(final String description) { - this.description = description; - } - - @Override - public String getReference() { - return reference; - } - - @Override - public void setReference(final String reference) { - this.reference = reference; - } - - @Override - public Status getStatus() { - return status; - } - - @Override - public void setStatus(Status status) { - this.status = Preconditions.checkNotNull(status, "status cannot be null"); - } - @Override public void addAugmentation(final AugmentationSchemaBuilder augment) { augmentationBuilders.add(augment); @@ -191,133 +96,9 @@ public final class NotificationBuilder extends AbstractDataNodeContainerBuilder return "notification " + getQName().getLocalName(); } - private static final class NotificationDefinitionImpl implements NotificationDefinition { - private final QName qname; - private final SchemaPath path; - private String description; - private String reference; - private Status status; - private ImmutableSet augmentations; - private ImmutableSet childNodes; - private ImmutableSet groupings; - private ImmutableSet> typeDefinitions; - private ImmutableSet uses; - private ImmutableList unknownNodes; - - private NotificationDefinitionImpl(final QName qname, final SchemaPath path) { - this.qname = qname; - this.path = path; - } - - @Override - public QName getQName() { - return qname; - } - - @Override - public SchemaPath getPath() { - return path; - } - - @Override - public String getDescription() { - return description; - } - - @Override - public String getReference() { - return reference; - } - - @Override - public Status getStatus() { - return status; - } - - @Override - public Set getChildNodes() { - return childNodes; - } - - @Override - public Set getGroupings() { - return groupings; - } - - @Override - public Set getUses() { - return uses; - } - - @Override - public Set> getTypeDefinitions() { - return typeDefinitions; - } - - @Override - public Set getAvailableAugmentations() { - return augmentations; - } - - @Override - public List getUnknownSchemaNodes() { - return unknownNodes; - } - - @Override - public DataSchemaNode getDataChildByName(final QName name) { - return getChildNode(childNodes, name); - } - - @Override - public DataSchemaNode getDataChildByName(final String name) { - return getChildNode(childNodes, name); - } - - @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(final Object obj) { - if (this == obj) { - return true; - } - if (obj == null) { - return false; - } - if (getClass() != obj.getClass()) { - return false; - } - final NotificationDefinitionImpl other = (NotificationDefinitionImpl) 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(NotificationDefinitionImpl.class.getSimpleName()); - sb.append("[qname=" + qname + ", path=" + path + "]"); - return sb.toString(); - } + @Override + protected String getStatementName() { + return "notification"; } }