private boolean negated = false;
+ private boolean setByWildcard = false;
+
private int boolIndex = -1;
private List<Integer> argsIndexes;
this.boolValue = arg.getDefaultBoolValue();
}
+ protected boolean setByWildcard()
+ {
+ return setByWildcard;
+ }
+
+ protected void setSetByWildcard(boolean b)
+ {
+ setByWildcard = b;
+ }
+
public Arg arg()
{
return arg;
argCount++;
}
- protected void setNegated(boolean b)
+ protected void setNegated(boolean b, boolean beingSetByWildcard)
{
+ // don't overwrite a wildcard set boolean with a non-wildcard set boolean
+ if (boolIndex >= 0 && !this.setByWildcard && beingSetByWildcard)
+ return;
this.negated = b;
}
return this.negated;
}
- protected void setBoolean(boolean b, int i)
+ protected void setBoolean(boolean b, int i, boolean beingSetByWildcard)
{
+ // don't overwrite a wildcard set boolean with a non-wildcard set boolean
+ if (boolIndex >= 0 && !this.setByWildcard && beingSetByWildcard)
+ return;
this.boolValue = b;
this.boolIndex = i;
+ this.setSetByWildcard(beingSetByWildcard);
}
protected boolean getBoolean()
return sb.toString();
}
- protected void addValue()
- {
- addValue(null, -1);
- }
-
- protected void addValue(String val, int argIndex)
+ protected void addValue(String val, int argIndex, boolean wildcard)
{
- addArgValue(new ArgValue(arg(), val, argIndex));
+ addArgValue(new ArgValue(arg(), val, argIndex), wildcard);
}
- protected void addValue(SubVals sv, String content, int argIndex)
+ protected void addValue(SubVals sv, String content, int argIndex,
+ boolean wildcard)
{
- addArgValue(new ArgValue(arg(), sv, content, argIndex));
+ addArgValue(new ArgValue(arg(), sv, content, argIndex), wildcard);
}
- protected void addArgValue(ArgValue av)
+ protected void addArgValue(ArgValue av, boolean beingSetByWildcard)
{
+ // allow a non-wildcard value to overwrite a wildcard set single value
+ boolean overwrite = !arg.hasOption(Opt.MULTI) && setByWildcard
+ && !beingSetByWildcard;
if ((!arg.hasOption(Opt.MULTI) && argValueList.size() > 0)
- || (arg.hasOption(Opt.NODUPLICATEVALUES)
- && argValueList.contains(av.getValue())))
+ && !overwrite)
return;
- if (argValueList == null)
+ if (arg.hasOption(Opt.NODUPLICATEVALUES)
+ && this.containsValue(av.getValue()))
+ return;
+ // new or overwrite if single valued
+ if (argValueList == null || overwrite)
{
argValueList = new ArrayList<ArgValue>();
}
idMap.put(id, av);
}
argValueList.add(av);
+ this.setSetByWildcard(beingSetByWildcard);
}
protected boolean hasValue(String val)
{
return idMap.get(id);
}
+
+ private boolean containsValue(String v)
+ {
+ if (argValueList == null)
+ return false;
+ for (ArgValue av : argValueList)
+ {
+ String val = av.getValue();
+ if (v == null && val == null)
+ return true;
+ if (v == null)
+ continue;
+ if (v.equals(val))
+ return true;
+ }
+ return false;
+ }
}
\ No newline at end of file