Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.aspectran.shell.command.option.ParsedOptions Maven / Gradle / Ivy
/*
* Copyright (c) 2008-2025 The Aspectran Project
*
* 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.aspectran.shell.command.option;
import com.aspectran.utils.StringUtils;
import com.aspectran.utils.annotation.jsr305.Nullable;
import java.io.File;
import java.io.Serial;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;
import java.util.Properties;
/**
* Represents list of arguments parsed against a {@link Options} descriptor.
*
* It allows querying of a boolean {@link #hasOption(String name)},
* in addition to retrieving the {@link #getValue(String name)}
* for options requiring arguments.
*
* Additionally, any left-over or unrecognized arguments,
* are available for further processing.
*/
public class ParsedOptions implements Serializable {
@Serial
private static final long serialVersionUID = -875791688751934582L;
/** The processed options */
private final List options = new ArrayList<>();
/** The unrecognized options/arguments */
private final List args = new LinkedList<>();
protected ParsedOptions() {
// Nothing to do
}
/**
* Query to see if an option has been set.
* @param opt the option to check
* @return true if set, false if not
*/
public boolean hasOption(Option opt) {
return options.contains(opt);
}
/**
* Query to see if an option has been set.
* @param name short name of the option
* @return true if set, false if not
*/
public boolean hasOption(String name) {
return hasOption(resolveOption(name));
}
/**
* Query to see if an option has been set.
* @param name character name of the option
* @return true if set, false if not
*/
public boolean hasOption(char name) {
return hasOption(String.valueOf(name));
}
/**
* Checks if options exists.
* @return true if options exists; false otherwise
*/
public boolean hasOptions() {
return !options.isEmpty();
}
/**
* Return a version of this {@code Option} converted to a particular type.
* @param type to attempt to convert to
* @param option the option
* @return the value parsed into a particular object
* @throws OptionParserException if there are problems turning the option value into the desired type
*/
@SuppressWarnings("unchecked")
public T getTypedValue(Option option) throws OptionParserException {
if (option == null) {
return null;
}
String value = getValue(option);
if (value == null) {
return null;
}
OptionValueType valueType = option.getValueType();
if (valueType == OptionValueType.STRING) {
return (T)value;
} else if (valueType == OptionValueType.INT) {
try {
return (T)Integer.valueOf(value);
} catch (NumberFormatException e) {
throw new OptionParserException(e.getMessage());
}
} else if (valueType == OptionValueType.LONG) {
try {
return (T)Long.valueOf(value);
} catch (NumberFormatException e) {
throw new OptionParserException(e.getMessage());
}
} else if (valueType == OptionValueType.FLOAT) {
try {
return (T)Float.valueOf(value);
} catch (NumberFormatException e) {
throw new OptionParserException(e.getMessage());
}
} else if (valueType == OptionValueType.DOUBLE) {
try {
return (T)Double.valueOf(value);
} catch (NumberFormatException e) {
throw new OptionParserException(e.getMessage());
}
} else if (valueType == OptionValueType.BOOLEAN) {
try {
return (T)Boolean.valueOf(value);
} catch (NumberFormatException e) {
throw new OptionParserException(e.getMessage());
}
} else if (valueType == OptionValueType.FILE) {
return (T)new File(value);
} else {
return null;
}
}
/**
* Return a version of this {@code Option} converted to a particular type.
* @param type to attempt to convert to
* @param name the name of the option
* @return the value parsed into a particular object
* @throws OptionParserException if there are problems turning the option value into the desired type
*/
public T getTypedValue(String name) throws OptionParserException {
return getTypedValue(resolveOption(name));
}
/**
* Return a version of this {@code Option} converted to a particular type.
* @param type to attempt to convert to
* @param name the name of the option
* @return the value parsed into a particular object
* @throws OptionParserException if there are problems turning the option value into the desired type
*/
public T getTypedValue(char name) throws OptionParserException {
return getTypedValue(String.valueOf(name));
}
/**
* Retrieve the first argument, if any, of this option.
* @param option the name of the option
* @return the value of the argument if option is set, and has an argument,
* otherwise {@code null}
*/
public String getValue(Option option) {
if (option == null) {
return null;
}
String[] values = getValues(option);
return (values == null ? null : values[0]);
}
/**
* Retrieve the first argument, if any, of this option.
* @param name the name of the option
* @return the value of the argument if option is set, and has an argument,
* otherwise {@code null}
*/
public String getValue(String name) {
return getValue(resolveOption(name));
}
/**
* Retrieve the first argument, if any, of this option.
* @param name the character name of the option
* @return the value of the argument if option is set, and has an argument,
* otherwise {@code null}
*/
public String getValue(char name) {
return getValue(String.valueOf(name));
}
/**
* Retrieves the array of values, if any, of an option.
* @param option string name of the option
* @return the values of the argument if option is set, and has an argument,
* otherwise {@code null}
*/
@Nullable
public String[] getValues(Option option) {
List values = new ArrayList<>();
for (Option processedOption : options) {
if (processedOption.equals(option)) {
values.addAll(processedOption.getValuesList());
}
}
return (values.isEmpty() ? null : values.toArray(new String[0]));
}
/**
* Retrieves the array of values, if any, of an option.
* @param name string name of the option
* @return the values of the argument if option is set, and has an argument,
* otherwise {@code null}
*/
public String[] getValues(String name) {
return getValues(resolveOption(name));
}
/**
* Retrieves the array of values, if any, of an option.
* @param opt character name of the option
* @return Values of the argument if option is set, and has an argument,
* otherwise {@code null}
*/
public String[] getValues(char opt) {
return getValues(String.valueOf(opt));
}
/**
* Retrieve the first argument, if any, of an option.
* @param option the name of the option
* @param defaultValue the default value to be returned if the option
* is not specified
* @return the value of the argument if option is set, and has an argument,
* otherwise {@code defaultValue}
*/
public String getValue(Option option, String defaultValue) {
String answer = getValue(option);
return (answer != null ? answer : defaultValue);
}
/**
* Retrieve the first argument, if any, of an option.
* @param name the name of the option
* @param defaultValue the default value to be returned if the option
* is not specified
* @return the value of the argument if option is set, and has an argument,
* otherwise {@code defaultValue}
*/
public String getValue(String name, String defaultValue) {
return getValue(resolveOption(name), defaultValue);
}
/**
* Retrieve the argument, if any, of an option.
* @param name character name of the option
* @param defaultValue the default value to be returned if the option
* is not specified
* @return the value of the argument if option is set, and has an argument,
* otherwise {@code defaultValue}
*/
public String getValue(char name, String defaultValue) {
return getValue(String.valueOf(name), defaultValue);
}
/**
* Retrieves the option object given the long or short option as a String.
* @param name the short or long name of the option
* @return the canonicalized option
*/
public Option resolveOption(String name) {
name = OptionUtils.stripLeadingHyphens(name);
for (Option option : options) {
if (name.equals(option.getName())) {
return option;
}
if (name.equals(option.getLongName())) {
return option;
}
}
return null;
}
/**
* Retrieve the map of values associated to the option. This is convenient
* for options specifying Java properties like -Dparam1=value1
* -Dparam2=value2
. The first argument of the option is the key, and
* the 2nd argument is the value. If the option has only one argument
* (-Dfoo
) it is considered as a boolean flag and the value is
* "true"
.
* @param option the option to be processed
* @return the Properties mapped by the option, never {@code null}
* even if the option doesn't exists
*/
public Properties getProperties(Option option) {
Properties props = new Properties();
for (Option processedOption : options) {
if (processedOption.equals(option)) {
List values = processedOption.getValuesList();
if (values.size() >= 2) {
// use the first 2 arguments as the key/value pair
props.put(values.get(0), values.get(1));
} else if (values.size() == 1) {
// no explicit value, handle it as a boolean
props.put(values.get(0), "true");
}
}
}
return props;
}
/**
* Retrieve the map of values associated to the option. This is convenient
* for options specifying Java properties like -Dparam1=value1
* -Dparam2=value2
. The first argument of the option is the key, and
* the 2nd argument is the value. If the option has only one argument
* (-Dfoo
) it is considered as a boolean flag and the value is
* "true"
.
* @param name the name of the option
* @return the Properties mapped by the option, never {@code null}
* even if the option doesn't exists
*/
public Properties getProperties(String name) {
Properties props = new Properties();
for (Option option : options) {
if (name.equals(option.getName()) || name.equals(option.getLongName())) {
List values = option.getValuesList();
if (values.size() >= 2) {
// use the first 2 arguments as the key/value pair
props.put(values.get(0), values.get(1));
} else if (values.size() == 1) {
// no explicit value, handle it as a boolean
props.put(values.get(0), "true");
}
}
}
return props;
}
/**
* Add an option.
* The values of the option are stored.
* @param opt the option to be processed
*/
protected void addOption(Option opt) {
options.add(opt);
}
/**
* Returns an iterator over the Option members of ParsedOptions.
* @return an {@code Iterator} over the processed {@link Option}
* members of this {@link ParsedOptions}
*/
public Iterator iterator() {
return options.iterator();
}
/**
* Returns an array of the processed {@link Option}s.
* @return an array of the processed {@link Option}s
*/
public Option[] getOptions() {
return options.toArray(new Option[0]);
}
/**
* Checks if non-recognized options or arguments exists.
* @return true if non-recognized options or arguments exists; false otherwise
*/
public boolean hasArgs() {
return !args.isEmpty();
}
/**
* Retrieve any left-over non-recognized options and arguments.
* @return remaining items passed in but not parsed as an array
*/
public String[] getArgs() {
return args.toArray(new String[0]);
}
public String getFirstArg() {
return (!args.isEmpty() ? args.get(0) : null);
}
/**
* Retrieve any left-over non-recognized options and arguments.
* @return remaining items passed in but not parsed as a {@link List}
*/
public List getArgList() {
return args;
}
/**
* Add left-over unrecognized option/argument.
* @param arg the unrecognized option/argument
*/
protected void addArg(String arg) {
if (StringUtils.hasLength(arg)) {
args.add(arg);
}
}
}