X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fbin%2Fargparser%2FArgValue.java;h=f76b7570cc07e65ca453b0aa1f5ae5557284d4bd;hb=1828f012a09cc00f8748fd9ee5b53af0779a8945;hp=be6227dbb68bc741b33ef4155b635de95cc740fc;hpb=2e59bc7938c0f10bde61fd30d1841bedb3d8319e;p=jalview.git diff --git a/src/jalview/bin/argparser/ArgValue.java b/src/jalview/bin/argparser/ArgValue.java index be6227d..f76b757 100644 --- a/src/jalview/bin/argparser/ArgValue.java +++ b/src/jalview/bin/argparser/ArgValue.java @@ -1,20 +1,63 @@ package jalview.bin.argparser; +import jalview.bin.argparser.Arg.Opt; +import jalview.bin.argparser.Arg.Type; + /** * A helper class to keep an index of argument position with argument values */ -public class ArgValue +public class ArgValue implements Comparable { + private Arg arg; + private int argIndex; private String value; + /* + * Type type is only really used by --help-type + */ + private Type type = null; + + // This id is set by a subVal id= to identify the product of this ArgValue + // later. Set but not currently used. private String id; - protected ArgValue(String value, int argIndex) + private SubVals subVals; + + protected ArgValue(Arg a, SubVals sv, Type type, String content, + int argIndex) + { + this.arg = a; + this.value = content; + this.argIndex = argIndex; + this.subVals = sv == null ? new SubVals("") : sv; + this.setType(type); + } + + protected ArgValue(Arg a, Type type, String value, int argIndex) { - this.value = value; + this.arg = a; this.argIndex = argIndex; + this.subVals = new SubVals(value); + this.value = getSubVals().getContent(); + this.setType(type); + } + + protected void setType(Type t) + { + if (this.getArg().hasOption(Opt.HASTYPE)) + this.type = t; + } + + public Type getType() + { + return type; + } + + public Arg getArg() + { + return arg; } public String getValue() @@ -36,4 +79,27 @@ public class ArgValue { return id; } + + public SubVals getSubVals() + { + return subVals; + } + + public String getSubVal(String key) + { + if (subVals == null || !subVals.has(key)) + return null; + return subVals.get(key); + } + + protected void putSubVal(String key, String val) + { + this.subVals.put(key, val); + } + + @Override + public final int compareTo(ArgValue o) + { + return this.getArgIndex() - o.getArgIndex(); + } } \ No newline at end of file