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%2FDeviationBuilder.java;h=4a89a959a7dd30fe227cdd9c684445882fdb3aed;hb=42abb28b99a02f9580f4676ce5c315628e5bcd24;hp=71d1f06ef5e453750aa2122e4a19231a76702624;hpb=6f0eeb681698cb64eadd97ff88f92d0b31b545a1;p=yangtools.git diff --git a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/DeviationBuilder.java b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/DeviationBuilder.java index 71d1f06ef5..4a89a959a7 100644 --- a/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/DeviationBuilder.java +++ b/yang/yang-parser-impl/src/main/java/org/opendaylight/yangtools/yang/parser/builder/impl/DeviationBuilder.java @@ -7,44 +7,42 @@ */ package org.opendaylight.yangtools.yang.parser.builder.impl; -import java.util.*; - -import org.opendaylight.yangtools.yang.model.api.*; -import org.opendaylight.yangtools.yang.model.api.Deviation.Deviate; -import org.opendaylight.yangtools.yang.parser.builder.api.AbstractBuilder; -import org.opendaylight.yangtools.yang.parser.util.*; - import com.google.common.collect.ImmutableList; - +import java.util.List; +import java.util.Objects; +import org.opendaylight.yangtools.yang.model.api.Deviation; +import org.opendaylight.yangtools.yang.model.api.Deviation.Deviate; +import org.opendaylight.yangtools.yang.model.api.SchemaPath; +import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode; +import org.opendaylight.yangtools.yang.parser.builder.api.UnknownSchemaNodeBuilder; +import org.opendaylight.yangtools.yang.parser.builder.util.AbstractBuilder; +import org.opendaylight.yangtools.yang.parser.util.YangParseException; + +/** + * @deprecated Pre-Beryllium implementation, scheduled for removal. + */ +@Deprecated public final class DeviationBuilder extends AbstractBuilder { private DeviationImpl instance; - private final String targetPathStr; - private SchemaPath targetPath; + private final SchemaPath targetPath; private Deviate deviate; private String reference; - DeviationBuilder(final String moduleName, final int line, final String targetPathStr) { + DeviationBuilder(final String moduleName, final int line, final SchemaPath targetPath) { super(moduleName, line); - if (!targetPathStr.startsWith("/")) { - throw new YangParseException(moduleName, line, - "Deviation argument string must be an absolute schema node identifier."); - } - this.targetPathStr = targetPathStr; - this.targetPath = ParserUtils.parseXPathString(targetPathStr); + this.targetPath = targetPath; } @Override public Deviation build() { - if (targetPath == null) { - throw new YangParseException(moduleName, line, "Unresolved deviation target"); - } - if (instance != null) { return instance; } + if (targetPath == null) { + throw new YangParseException(getModuleName(), getLine(), "Unresolved deviation target"); + } - instance = new DeviationImpl(); - instance.targetPath = targetPath; + instance = new DeviationImpl(targetPath); instance.deviate = deviate; instance.reference = reference; @@ -61,10 +59,6 @@ public final class DeviationBuilder extends AbstractBuilder { return targetPath; } - public void setTargetPath(final SchemaPath targetPath) { - this.targetPath = targetPath; - } - public void setDeviate(final String deviate) { if ("not-supported".equals(deviate)) { this.deviate = Deviate.NOT_SUPPORTED; @@ -75,7 +69,7 @@ public final class DeviationBuilder extends AbstractBuilder { } else if ("delete".equals(deviate)) { this.deviate = Deviate.DELETE; } else { - throw new YangParseException(moduleName, line, "Unsupported type of 'deviate' statement: " + deviate); + throw new YangParseException(getModuleName(), getLine(), "Unsupported type of 'deviate' statement: " + deviate); } } @@ -85,16 +79,17 @@ public final class DeviationBuilder extends AbstractBuilder { @Override public String toString() { - return "deviation " + targetPathStr; + return "deviation " + targetPath; } private static final class DeviationImpl implements Deviation { - private SchemaPath targetPath; + private final SchemaPath targetPath; private Deviate deviate; private String reference; private ImmutableList unknownNodes; - private DeviationImpl() { + private DeviationImpl(final SchemaPath targetPath) { + this.targetPath = targetPath; } @Override @@ -121,14 +116,14 @@ public final class DeviationBuilder extends AbstractBuilder { public int hashCode() { final int prime = 31; int result = 1; - result = prime * result + ((targetPath == null) ? 0 : targetPath.hashCode()); - result = prime * result + ((deviate == null) ? 0 : deviate.hashCode()); - result = prime * result + ((reference == null) ? 0 : reference.hashCode()); + result = prime * result + Objects.hashCode(targetPath); + result = prime * result + Objects.hashCode(deviate); + result = prime * result + Objects.hashCode(reference); return result; } @Override - public boolean equals(Object obj) { + public boolean equals(final Object obj) { if (this == obj) { return true; } @@ -167,9 +162,9 @@ public final class DeviationBuilder extends AbstractBuilder { public String toString() { StringBuilder sb = new StringBuilder(DeviationImpl.class.getSimpleName()); sb.append("["); - sb.append("targetPath=" + targetPath); - sb.append(", deviate=" + deviate); - sb.append(", reference=" + reference); + sb.append("targetPath=").append(targetPath); + sb.append(", deviate=").append(deviate); + sb.append(", reference=").append(reference); sb.append("]"); return sb.toString(); }