All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.alibaba.antx.util.cli.Option Maven / Gradle / Ivy

/*
 * Copyright (c) 2002-2012 Alibaba Group Holding Limited.
 * All rights reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.alibaba.antx.util.cli;

import java.util.ArrayList;

public class Option implements Cloneable {
    /**
     * constant that specifies the number of argument values has not been
     * specified
     */
    public static final int UNINITIALIZED = -1;

    /** constant that specifies the number of argument values is infinite */
    public static final int UNLIMITED_VALUES = -2;

    /** opt the single character representation of the option */
    private String opt;

    /** longOpt is the long representation of the option */
    private String longOpt;

    /** hasArg specifies whether this option has an associated argument */
    private boolean hasArg;

    /** argName specifies the name of the argument for this option */
    private String argName;

    /** description of the option */
    private String description;

    /** required specifies whether this option is required to be present */
    private boolean required;

    /** specifies whether the argument value of this Option is optional */
    private boolean optionalArg;

    /** numberOfArgs specifies the number of argument values this option can have */
    private int numberOfArgs = UNINITIALIZED;

    /** the type of this Option */
    private Object type;

    /** the list of argument values */
    private ArrayList values = new ArrayList();

    /** option char (only valid for single character options) */
    private char id;

    /** the character that is the value separator */
    private char valuesep;

    private void validateOption(String opt) throws IllegalArgumentException {
        // check that opt is not NULL
        if (opt == null) {
            throw new IllegalArgumentException("opt is null");
        }
        // handle the single character opt
        else if (opt.length() == 1) {
            char ch = opt.charAt(0);

            if (!isValidOpt(ch)) {
                throw new IllegalArgumentException("illegal option value '" + ch + "'");
            }

            id = ch;
        }
        // handle the multi character opt
        else {
            char[] chars = opt.toCharArray();

            for (int i = 0; i < chars.length; i++) {
                if (!isValidChar(chars[i])) {
                    throw new IllegalArgumentException("opt contains illegal character value '" + chars[i] + "'");
                }
            }
        }
    }

    /**
     * 

* Returns whether the specified character is a valid Option. *

* * @param c the option to validate * @return true if c is a letter, ' ', '?' or '', otherwise * false. */ private boolean isValidOpt(char c) { return isValidChar(c) || c == ' ' || c == '?' || c == '@'; } /** *

* Returns whether the specified character is a valid character. *

* * @param c the character to validate * @return true if c is a letter. */ private boolean isValidChar(char c) { return Character.isJavaIdentifierPart(c); } /** *

* Returns the id of this Option. This is only set when the Option shortOpt * is a single character. This is used for switch statements. *

* * @return the id of this Option */ public int getId() { return id; } /** * Creates an Option using the specified parameters. * * @param opt short representation of the option * @param hasArg specifies whether the Option takes an argument or not * @param description describes the function of the option */ public Option(String opt, String description) throws IllegalArgumentException { this(opt, null, false, description); } /** * Creates an Option using the specified parameters. * * @param opt short representation of the option * @param hasArg specifies whether the Option takes an argument or not * @param description describes the function of the option */ public Option(String opt, boolean hasArg, String description) throws IllegalArgumentException { this(opt, null, hasArg, description); } /** *

* Creates an Option using the specified parameters. *

* * @param opt short representation of the option * @param longOpt the long representation of the option * @param hasArg specifies whether the Option takes an argument or not * @param description describes the function of the option */ public Option(String opt, String longOpt, boolean hasArg, String description) throws IllegalArgumentException { // ensure that the option is valid validateOption(opt); this.opt = opt; this.longOpt = longOpt; // if hasArg is set then the number of arguments is 1 if (hasArg) { this.numberOfArgs = 1; } this.hasArg = hasArg; this.description = description; } /** *

* Retrieve the name of this Option. *

*

* It is this String which can be used with * {@link CommandLine#hasOption(String opt)} and * {@link CommandLine#getOptionValue(String opt)} to check for existence and * argument. *

*

*

* * @return The name of this option */ public String getOpt() { return this.opt; } /** *

* Retrieve the type of this Option. *

* * @return The type of this option */ public Object getType() { return this.type; } /** *

* Sets the type of this Option. *

* * @param type the type of this Option */ public void setType(Object type) { this.type = type; } /** *

* Retrieve the long name of this Option. *

* * @return Long name of this option, or null, if there is no long name */ public String getLongOpt() { return this.longOpt; } /** *

* Sets the long name of this Option. *

* * @param longOpt the long name of this Option */ public void setLongOpt(String longOpt) { this.longOpt = longOpt; } /** *

* Sets whether this Option can have an optional argument. *

* * @param optionalArg specifies whether the Option can have an optional * argument. */ public void setOptionalArg(boolean optionalArg) { this.optionalArg = optionalArg; } /** @return whether this Option can have an optional argument */ public boolean hasOptionalArg() { return this.optionalArg; } /** *

* Query to see if this Option has a long name *

* * @return boolean flag indicating existence of a long name */ public boolean hasLongOpt() { return this.longOpt != null; } /** *

* Query to see if this Option requires an argument *

* * @return boolean flag indicating if an argument is required */ public boolean hasArg() { return this.numberOfArgs > 0 || numberOfArgs == UNLIMITED_VALUES; } /** *

* Retrieve the self-documenting description of this Option *

* * @return The string description of this option */ public String getDescription() { return this.description; } /** *

* Query to see if this Option requires an argument *

* * @return boolean flag indicating if an argument is required */ public boolean isRequired() { return this.required; } /** *

* Sets whether this Option is mandatory. *

* * @param required specifies whether this Option is mandatory */ public void setRequired(boolean required) { this.required = required; } /** *

* Sets the display name for the argument value. *

* * @param argName the display name for the argument value. */ public void setArgName(String argName) { this.argName = argName; } /** *

* Gets the display name for the argument value. *

* * @return the display name for the argument value. */ public String getArgName() { return this.argName; } /** *

* Returns whether the display name for the argument value has been set. *

* * @return if the display name for the argument value has been set. */ public boolean hasArgName() { return this.argName != null && this.argName.length() > 0; } /** *

* Query to see if this Option can take many values *

* * @return boolean flag indicating if multiple values are allowed */ public boolean hasArgs() { return this.numberOfArgs > 1 || this.numberOfArgs == UNLIMITED_VALUES; } /** *

* Sets the number of argument values this Option can take. *

* * @param num the number of argument values */ public void setArgs(int num) { this.numberOfArgs = num; } /** *

* Sets the value separator. For example if the argument value was a Java * property, the value separator would be '='. *

* * @param sep The value separator. */ public void setValueSeparator(char sep) { this.valuesep = sep; } /** *

* Returns the value separator character. *

* * @return the value separator character. */ public char getValueSeparator() { return this.valuesep; } /** *

* Returns the number of argument values this Option can take. *

* * @return num the number of argument values */ public int getArgs() { return this.numberOfArgs; } /** *

* Dump state, suitable for debugging. *

* * @return Stringified form of this object */ @Override public String toString() { StringBuffer buf = new StringBuffer().append("[ option: "); buf.append(this.opt); if (this.longOpt != null) { buf.append(" ").append(this.longOpt); } buf.append(" "); if (hasArg) { buf.append("+ARG"); } buf.append(" :: ").append(this.description); if (this.type != null) { buf.append(" :: ").append(this.type); } buf.append(" ]"); return buf.toString(); } /** *

* Adds the specified value to this Option. *

* * @param value is a/the value of this Option */ public boolean addValue(String value) { switch (numberOfArgs) { case UNINITIALIZED: return false; case UNLIMITED_VALUES: if (getValueSeparator() > 0) { int index = 0; while ((index = value.indexOf(getValueSeparator())) != -1) { this.values.add(value.substring(0, index)); value = value.substring(index + 1); } } this.values.add(value); return true; default: if (getValueSeparator() > 0) { int index = 0; while ((index = value.indexOf(getValueSeparator())) != -1) { if (values.size() > numberOfArgs - 1) { return false; } this.values.add(value.substring(0, index)); value = value.substring(index + 1); } } if (values.size() > numberOfArgs - 1) { return false; } this.values.add(value); return true; } } /** * @return the value/first value of this Option or null if * there are no values. */ public String getValue() { return this.values.size() == 0 ? null : (String) this.values.get(0); } /** * @return the specified value of this Option or null if there * are no values. */ public String getValue(int index) throws IndexOutOfBoundsException { return this.values.size() == 0 ? null : (String) this.values.get(index); } /** * @return the value/first value of this Option or the * defaultValue if there are no values. */ public String getValue(String defaultValue) { String value = getValue(); return value != null ? value : defaultValue; } /** * @return the values of this Option as a String array or null if there are * no values */ public String[] getValues() { return this.values.size() == 0 ? null : (String[]) this.values.toArray(new String[] { }); } /** * @return the values of this Option as a List or null if there are no * values */ public java.util.List getValuesList() { return this.values; } /** @return a copy of this Option */ @Override public Object clone() { Option option = new Option(getOpt(), getDescription()); option.setArgs(getArgs()); option.setOptionalArg(hasOptionalArg()); option.setRequired(isRequired()); option.setLongOpt(getLongOpt()); option.setType(getType()); option.setValueSeparator(getValueSeparator()); return option; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy