package eu.svjatoslav.meviz.encoder;
-import eu.svjatoslav.commons.commandline.parameterparser.Parameter;
import eu.svjatoslav.commons.commandline.parameterparser.Parser;
-import eu.svjatoslav.commons.commandline.parameterparser.arguments.StringArgument;
+import eu.svjatoslav.commons.commandline.parameterparser.parameter.DirectoryParameter;
+import eu.svjatoslav.commons.commandline.parameterparser.parameter.NullParameter;
+import eu.svjatoslav.commons.commandline.parameterparser.parameter.StringParameter;
public class CommandlineHandler {
- Parameter outputFormatParameter = new Parameter(true, true, true,
- new StringArgument(), "Encoding output format.", "-o",
- "--output-format");
+ Parser parser = new Parser();
- Parameter terminalParameter = new Parameter("Enable popup terminal.",
- "--terminal");
+ StringParameter outputFormatParameter = parser
+ .createStringParameter("Encoding output format.")
+ .addAliases("-o", "--output-format").setMandatory();
- Parameter deinterlaceParameter = new Parameter("Deinterlace video.",
- "--deinterlace", "-d");
+ NullParameter deinterlaceParameter = parser.createNullParameter(
+ "Deinterlace video.").addAliases("--deinterlace", "-d");
- Parameter testParameter = new Parameter("Simulate file encoding.", "-t",
- "--test");
+ NullParameter testParameter = parser.createNullParameter(
+ "Simulate file encoding.").addAliases("-t", "--test");
- Parameter recursiveParameter = new Parameter("Enable recursive mode.",
- "-r", "--recursive");
+ NullParameter recursiveParameter = parser.createNullParameter(
+ "Enable recursive mode.").addAliases("-r", "--recursive");
- Parameter inputPatternParameter = new Parameter(true, true, true,
- new StringArgument(), "File input pattern.", "-i",
- "--input-pattern");
+ StringParameter inputPatternParameter = parser
+ .createStringParameter("File input pattern.")
+ .addAliases("-i", "--input-pattern").setMandatory();
- Parameter workingDirectoryParameter = new Parameter(
- false,
- true,
- true,
- new eu.svjatoslav.commons.commandline.parameterparser.arguments.ExistingDirectory(),
- "Working directory.", "-w", "--working-directory");
+ DirectoryParameter workingDirectoryParameter = parser
+ .createDirectoryParameter("Working directory.")
+ .addAliases("-w", "--working-directory").mustExist();
- Parameter videoBitrateParameter = new Parameter(false, true, false,
- new Bitrate(), "Video bitrate.", "-v", "--video-bitrate");
-
- public Parser initParser() {
- final Parser parser = new Parser();
-
- parser.addParameter(recursiveParameter);
-
- parser.addParameter(deinterlaceParameter);
-
- parser.addParameter(testParameter);
-
- parser.addParameter(terminalParameter);
-
- parser.addParameter(outputFormatParameter);
-
- parser.addParameter(inputPatternParameter);
-
- parser.addParameter(workingDirectoryParameter);
+ BitrateParameter videoBitrateParameter = new BitrateParameter(
+ "Video bitrate");
+ public CommandlineHandler() {
+ videoBitrateParameter.addAliases("-v", "--video-bitrate");
parser.addParameter(videoBitrateParameter);
-
- return parser;
}
/**
final EncodingOptions options = new EncodingOptions();
- final Parser parser = initParser();
parser.parse(args);
if (recursiveParameter.isParameterSpecified())
if (deinterlaceParameter.isParameterSpecified())
options.deinterlace = true;
- if (terminalParameter.isParameterSpecified())
- options.terminal = true;
-
if (testParameter.isParameterSpecified())
options.testOnly = true;
if (videoBitrateParameter.isParameterSpecified())
try {
- options.videoBitrate = Bitrate.bitrate
- .valueOf(videoBitrateParameter.getArgumentAsString()
- .toUpperCase());
+ options.videoBitrate = videoBitrateParameter.getValue();
} catch (final Exception e) {
System.out
.println("Invalid video bitrate. Valid values are: LOW, MEDIUM, HIGH.");