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

com.cedarsolutions.util.commandline.CommandLineArguments Maven / Gradle / Ivy

/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 *
 *              C E D A R
 *          S O L U T I O N S       "Software done right."
 *           S O F T W A R E
 *
 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 *
 * Copyright (c) 2013 Kenneth J. Pronovici.
 * All rights reserved.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the Apache License, Version 2.0.
 * See LICENSE for more information about the licensing terms.
 *
 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 *
 * Author   : Kenneth J. Pronovici 
 * Language : Java 6
 * Project  : Common Java Functionality
 *
 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
package com.cedarsolutions.util.commandline;

import java.util.ArrayList;
import java.util.List;

import com.cedarsolutions.exception.InvalidArgumentsException;


/**
 * Common functionality for representing command-line arguments.
 * @author Kenneth J. Pronovici 
 */
public abstract class CommandLineArguments {

    /** Array of command-line arguments, as from main(). */
    private String[] args;

    /**
     * Constructor in terms of command-line arguments.
     * @param args Array of command-line arguments, as from main()
     * @throws InvalidArgumentsException If the command-line arguments are invalid.
     */
    protected CommandLineArguments(String[] args) {
        this.args = args;
        this.parseArguments(args);
    }

    /** Array of command-line arguments, as from main(). */
    public String[] getArgs() {
        return this.args;
    }

    /**
     * Parse command-line arguments.
     * @param args Array of command-line arguments, as from main()
     * @throws InvalidArgumentsException If the command-line arguments are invalid.
     */
    protected abstract void parseArguments(String[] args) throws InvalidArgumentsException;

    /**
     * Parse a flag from the command-line.
     *
     * @param args    Array of command-line arguments, as from main()
     * @param option  Command-line option, like --flag
     *
     * @return True if the flag exists (even if it exists more than once), false otherwise.
     */
    protected static boolean parseFlag(String[] args, String option) {
        int i = 0;
        if (args != null) {
            while (i < args.length) {
                String item = args[i];

                if (option.equals(item)) {
                    return true;
                }

                i += 1;
            }
        }

        return false;
    }

    /**
     * Parse a required string parameter from the command-line.
     *
     * 

* The parameter is expected to exist exactly once in the argument * list. If it is missing, or if it exists more than once, an exception * will be thrown. *

* * @param args Array of command-line arguments, as from main() * @param option Command-line option, like --param * * @return String parameter value parsed from command line, always non-null. * * @throws InvalidArgumentsException If the parameter was not found * @throws InvalidArgumentsException If the parameter was found more than once */ protected static String parseRequiredParameter(String[] args, String option) throws InvalidArgumentsException { String result = null; int i = 0; if (args != null) { while (i < args.length) { String item = args[i]; if (option.equals(item)) { if ((i + 1) >= args.length) { throw new InvalidArgumentsException("Parameter " + option + " was malformed."); } else { if (result != null) { throw new InvalidArgumentsException("Parameter " + option + " was found more than once."); } else { result = args[++i]; } } } i += 1; } } if (result == null) { throw new InvalidArgumentsException("Parameter " + option + " was not found"); } return result; } /** * Parse an optional string parameter from the command-line. * *

* The parameter is expected to exist either zero times or one time * in the argument list. If it exists more than once, an exception * will be thrown. *

* * @param args Array of command-line arguments, as from main() * @param option Command-line option, like --param * * @return String parameter value parsed from command line, possibly null. * * @throws InvalidArgumentsException If the parameter was found more than once */ protected static String parseOptionalParameter(String[] args, String option) throws InvalidArgumentsException { String result = null; int i = 0; if (args != null) { while (i < args.length) { String item = args[i]; if (option.equals(item)) { if ((i + 1) >= args.length) { throw new InvalidArgumentsException("Parameter " + option + " was malformed."); } else { if (result != null) { throw new InvalidArgumentsException("Parameter " + option + " was found more than once."); } else { result = args[++i]; } } } i += 1; } } return result; } /** * Parse a required string parameter list option from the command-line. * *

* The parameter is expected to exist at least once in the argument * list. If it is missing, an exception will be thrown. *

* * @param args Array of command-line arguments, as from main() * @param option Command-line option, like --param * * @return List of string parameter values parsed from command line, always non-null. * * @throws InvalidArgumentsException If the option was not found */ protected static List parseRequiredParameterList(String[] args, String option) throws InvalidArgumentsException { List result = new ArrayList(); int i = 0; if (args != null) { while (i < args.length) { String item = args[i]; if (option.equals(item)) { if ((i + 1) >= args.length) { throw new InvalidArgumentsException("Parameter " + option + " was malformed."); } else { result.add(args[++i]); } } i += 1; } } if (result.isEmpty()) { throw new InvalidArgumentsException("Parameter " + option + " was not found"); } return result; } /** * Parse an optional string parameter list option from the command-line. * * @param args Array of command-line arguments, as from main() * @param option Command-line option, like --param * * @return List of string parameter values parsed from command line, always non-null. * * @throws InvalidArgumentsException If the option was not found */ protected static List parseOptionalParameterList(String[] args, String option) throws InvalidArgumentsException { List result = new ArrayList(); int i = 0; if (args != null) { while (i < args.length) { String item = args[i]; if (option.equals(item)) { if ((i + 1) >= args.length) { throw new InvalidArgumentsException("Parameter " + option + " was malformed."); } else { result.add(args[++i]); } } i += 1; } } return result; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy