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=afc16c5c0b7d3334f7e6066cc41349f720f21b3c;hb=85a9a2f03fba2912e6824d546c7b250c442b201a;hp=8b18ba41b78d7cae18069c5c4736ee06e08a02a3;hpb=93e8c16d8deff8cd2935d09c445d2d7082503cb4;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 8b18ba41b7..afc16c5c0b 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 @@ -19,33 +19,25 @@ import org.opendaylight.yangtools.yang.parser.util.YangParseException; 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 = BuilderUtils.parseXPathString(targetPathStr); + this.targetPath = targetPath; } @Override public Deviation build() { - if (targetPath == null) { - throw new YangParseException(getModuleName(), getLine(), "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; @@ -62,10 +54,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; @@ -86,16 +74,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