org.helenus.commons.cli.RunnableOption Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of helenus-commons Show documentation
Show all versions of helenus-commons Show documentation
JPA-like syntax for annotating POJO classes for persistence via Cassandra's Java driver - Common Utilities
/*
* Copyright (C) 2015-2015 The Helenus Driver Project Authors.
*
* 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 org.helenus.commons.cli;
import org.apache.commons.cli.CommandLine;
import org.apache.commons.cli.Option;
/**
* The RunnableOption
class extends Apache's {#link Option} class
* in order to provide the option to embed the running logic inside the option
* itself.
*
* @copyright 2015-2015 The Helenus Driver Project Authors
*
* @author The Helenus Driver Project Authors
* @version 1 - Jan 15, 2015 - paouelle - Creation
*
* @since 1.0
*/
public abstract class RunnableOption extends Option {
/**
* Holds the serialVersionUID.
*
* @author paouelle
*/
private static final long serialVersionUID = 434750648754856694L;
/**
* Instantiates a new RunnableOption
object.
*
* @author paouelle
*
* @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
* @throws IllegalArgumentException if there are any non valid
* Option characters in opt
.
*/
public RunnableOption(String opt, boolean hasArg, String description)
throws IllegalArgumentException {
super(opt, hasArg, description);
}
/**
* Instantiates a new RunnableOption
object.
*
* @author paouelle
*
* @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
* @throws IllegalArgumentException if there are any non valid
* Option characters in opt
.
*/
public RunnableOption(
String opt,
String longOpt,
boolean hasArg,
String description
) throws IllegalArgumentException {
super(opt, longOpt, hasArg, description);
}
/**
* Instantiates a new RunnableOption
object.
*
* @author paouelle
*
* @param opt short representation of the option
* @param longOpt the long representation of the option
* @param numArgs specifies the number of arguments the Option takes
* @param description describes the function of the option
* @throws IllegalArgumentException if there are any non valid
* Option characters in opt
.
*/
public RunnableOption(
String opt,
String longOpt,
int numArgs,
String description
) throws IllegalArgumentException {
super(opt, longOpt, true, description);
setArgs(numArgs);
}
/**
* Instantiates a new RunnableOption
object.
*
* @author paouelle
*
* @param opt short representation of the option
* @param description describes the function of the option
* @throws IllegalArgumentException if there are any non valid
* Option characters in opt
.
*/
public RunnableOption(String opt, String description)
throws IllegalArgumentException {
super(opt, description);
}
/**
* Runs this particular option based on the provided command line.
*
* @author paouelle
*
* @param line the command line for which to run this option
* @throws Exception if an error occurred while running the command option
*/
public abstract void run(CommandLine line) throws Exception;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy