X-Git-Url: http://www2.svjatoslav.eu/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fmain%2Fjava%2Feu%2Fsvjatoslav%2Fmeviz%2Fencoder%2FCommandlineHandler.java;h=ff4b8ec2dae5aca0b3bbd4a17dded6c5ba05ef6d;hb=115456739edd5ae7dc67ac9e9f90d628aa65b4a3;hp=fd9d9e94780d22227a374bfd58538f3b6cc88792;hpb=50cb7085d553fdd82cd06806cd27b1675299f719;p=meviz.git
diff --git a/src/main/java/eu/svjatoslav/meviz/encoder/CommandlineHandler.java b/src/main/java/eu/svjatoslav/meviz/encoder/CommandlineHandler.java
index fd9d9e9..ff4b8ec 100755
--- a/src/main/java/eu/svjatoslav/meviz/encoder/CommandlineHandler.java
+++ b/src/main/java/eu/svjatoslav/meviz/encoder/CommandlineHandler.java
@@ -1,7 +1,7 @@
/*
* Meviz - Various tools collection to work with multimedia.
* Copyright (C) 2012, Svjatoslav Agejenko, svjatoslav@svjatoslav.eu
- *
+ *
* This program is free software; you can redistribute it and/or
* modify it under the terms of version 2 of the GNU General Public License
* as published by the Free Software Foundation.
@@ -9,96 +9,85 @@
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.parameter.DirectoryParameter;
+import eu.svjatoslav.commons.commandline.parameterparser.parameter.NullParameter;
+import eu.svjatoslav.commons.commandline.parameterparser.parameter.StringParameters;
public class CommandlineHandler {
- Parameter outputFormatParameter = new Parameter(true, true, true,
- new eu.svjatoslav.commons.commandline.parameterparser.arguments.String(), "Encoding output format.", "-o",
- "--output-format");
+ Parser parser = new Parser();
- Parameter terminalParameter = new Parameter("Enable popup terminal.", "--terminal");
+ StringParameters outputFormatParameter = parser
+ .add(new StringParameters("Encoding output format."))
+ .addAliases("-o", "--output-format").setMandatory();
- Parameter testParameter = new Parameter("Simulate file encoding.", "-t", "--test");
+ NullParameter deinterlaceParameter = parser.add(
+ new NullParameter("Deinterlace video.")).addAliases(
+ "--deinterlace", "-d");
- Parameter recursiveParameter = new Parameter("Enable recursive mode.", "-r", "--recursive");
+ NullParameter testParameter = parser.add(
+ new NullParameter("Simulate file encoding.")).addAliases("-t",
+ "--test");
- Parameter inputPatternParameter = new Parameter(true, true, true,
- new eu.svjatoslav.commons.commandline.parameterparser.arguments.String(), "File input pattern.", "-i",
- "--input-pattern");
+ NullParameter recursiveParameter = parser.add(
+ new NullParameter("Enable recursive mode.")).addAliases("-r",
+ "--recursive");
- Parameter workingDirectoryParameter = new Parameter(false, true, true,
- new eu.svjatoslav.commons.commandline.parameterparser.arguments.ExistingDirectory(), "Working directory.",
- "-w", "--working-directory");
+ NullParameter forPortableParameter = parser.add(
+ new NullParameter("Encode for portable player.")).addAliases("-p",
+ "--portable");
- Parameter videoBitrateParameter = new Parameter(false, true, false, new Bitrate(), "Video bitrate.", "-v",
- "--video-bitrate");
+ StringParameters inputPatternParameter = parser
+ .add(new StringParameters("File input pattern."))
+ .addAliases("-i", "--input-pattern").setMandatory();
- public Parser initParser() {
- final Parser parser = new Parser();
+ DirectoryParameter workingDirectoryParameter = parser
+ .add(new DirectoryParameter("Working directory."))
+ .addAliases("-w", "--working-directory").mustExist();
- parser.addParameter(recursiveParameter);
+ BitrateParameter videoBitrateParameter = parser.add(
+ new BitrateParameter("Video bitrate")).addAliases("-v",
+ "--video-bitrate");
- parser.addParameter(testParameter);
+ BitrateParameter audioBitrateParameter = parser.add(
+ new BitrateParameter("Audio bitrate")).addAliases("-a",
+ "--audio-bitrate");
- parser.addParameter(terminalParameter);
+ /**
+ * @return {@link EncodingOptions} if commandline arguments were
+ * successfully parsed, or null
if parsing error
+ * occurred.
+ */
+ public EncodingOptions parseCommandlineArguments(final String[] args) {
- parser.addParameter(outputFormatParameter);
+ final EncodingOptions options = new EncodingOptions();
- parser.addParameter(inputPatternParameter);
+ parser.parse(args);
- parser.addParameter(workingDirectoryParameter);
+ options.recursive = recursiveParameter.isParameterSpecified();
- parser.addParameter(videoBitrateParameter);
+ options.deinterlace = deinterlaceParameter.isParameterSpecified();
- return parser;
- }
+ options.testOnly = testParameter.isParameterSpecified();
- /**
- * @return {@link EncodingOptions} if commandline arguments were
- * successfully parsed, or null
if parsing error
- * occurred.
- */
- public EncodingOptions parseCommandlineArguments(final String[] args) {
+ if (outputFormatParameter.isParameterSpecified())
+ options.outputFormats.addAll(outputFormatParameter.getValue());
- final EncodingOptions options = new EncodingOptions();
+ if (workingDirectoryParameter.isParameterSpecified())
+ options.workingDirectory = workingDirectoryParameter.getValue();
- final Parser parser = initParser();
- parser.parse(args);
+ if (inputPatternParameter.isParameterSpecified())
+ options.inputPatterns.addAll(inputPatternParameter.getValue());
- if (recursiveParameter.isParameterSpecified())
- options.recursive = true;
+ options.forPortablePlayer = forPortableParameter.isParameterSpecified();
- if (terminalParameter.isParameterSpecified())
- options.terminal = true;
+ if (videoBitrateParameter.isParameterSpecified())
+ options.setVideoBitrate(videoBitrateParameter.getValue());
- if (testParameter.isParameterSpecified())
- options.testOnly = true;
+ if (audioBitrateParameter.isParameterSpecified())
+ options.setAudioBitrate(audioBitrateParameter.getValue());
- if (outputFormatParameter.isParameterSpecified()) {
- options.outputFormats.addAll(outputFormatParameter.getArgumentsAsStrings());
- }
-
- if (workingDirectoryParameter.isParameterSpecified()) {
- options.workingDirectory = workingDirectoryParameter.getArgumentsAsFiles().get(0);
- }
-
- if (inputPatternParameter.isParameterSpecified()) {
- options.inputPatterns.addAll(inputPatternParameter.getArgumentsAsStrings());
- }
-
- if (videoBitrateParameter.isParameterSpecified()) {
-
- try {
- options.videoBitrate = Bitrate.bitrate.valueOf(videoBitrateParameter.getArgumentAsString()
- .toUpperCase());
- } catch (final Exception e) {
- System.out.println("Invalid video bitrate. Valid values are: LOW, MEDIUM, HIGH.");
- return null;
- }
- }
-
- return options;
- }
+ return options;
+ }
}