X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fjalview%2Fbin%2Fargparser%2FArgValue.java;h=3467f61bccd106b048f112ea6413af0a276626f9;hb=bda60947eaabb464920b733509ace12e745f3910;hp=c9e86b85b15368a0b41c65407591cea18d3c527a;hpb=f52d881ba992cf5d4570d487f6319666f13263a9;p=jalview.git diff --git a/src/jalview/bin/argparser/ArgValue.java b/src/jalview/bin/argparser/ArgValue.java index c9e86b8..3467f61 100644 --- a/src/jalview/bin/argparser/ArgValue.java +++ b/src/jalview/bin/argparser/ArgValue.java @@ -1,30 +1,65 @@ 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; private SubVals subVals; - protected ArgValue(SubVals sv, String content, int argIndex) + 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(String value, int argIndex) + protected ArgValue(Arg a, Type type, String value, int argIndex) { + 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() @@ -63,4 +98,10 @@ public class ArgValue { this.subVals.put(key, val); } + + @Override + public final int compareTo(ArgValue o) + { + return this.getArgIndex() - o.getArgIndex(); + } } \ No newline at end of file