X-Git-Url: http://www2.svjatoslav.eu/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Feu%2Fsvjatoslav%2Fmeviz%2Fencoder%2FCommandlineHandler.java;h=41d30e69d7ccdb5336e3e89825bedc6fe4918290;hb=567410640f4e0428caf9de9fc83df4c73f0e5067;hp=870d4769578644a5fedef315b6636678cd106b40;hpb=0a7c6bdea0eb481cab530d6168c5c1a8d942c012;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 870d476..41d30e6 100755
--- a/src/main/java/eu/svjatoslav/meviz/encoder/CommandlineHandler.java
+++ b/src/main/java/eu/svjatoslav/meviz/encoder/CommandlineHandler.java
@@ -1,99 +1,90 @@
/*
* Meviz - Various tools collection to work with multimedia.
- * Copyright (C) 2012, Svjatoslav Agejenko, svjatoslav@svjatoslav.eu
- *
+ * Copyright (C) 2012 -- 2019, 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.
- */
+ * modify it under the terms of version 3 of the GNU Lesser General Public License
+ * or later as published by the Free Software Foundation.
+*/
package eu.svjatoslav.meviz.encoder;
import eu.svjatoslav.commons.commandline.parameterparser.Parser;
import eu.svjatoslav.commons.commandline.parameterparser.parameter.DirectoryParameter;
+import eu.svjatoslav.commons.commandline.parameterparser.parameter.IntegerParameter;
import eu.svjatoslav.commons.commandline.parameterparser.parameter.NullParameter;
-import eu.svjatoslav.commons.commandline.parameterparser.parameter.StringParameter;
+import eu.svjatoslav.commons.commandline.parameterparser.parameter.StringParameters;
-public class CommandlineHandler {
+class CommandlineHandler {
- Parser parser = new Parser();
+ final Parser parser = new Parser();
- StringParameter outputFormatParameter = parser
- .createStringParameter("Encoding output format.")
- .addAliases("-o", "--output-format").setMandatory();
+ private final StringParameters outputFormatParameter = parser.add(new StringParameters("Encoding output format."))
+ .addAliases("-o", "--output-format").setMandatory();
- NullParameter terminalParameter = parser.createNullParameter(
- "Enable popup terminal.").addAliases("--terminal");
+ private final IntegerParameter targetFramerate = parser
+ .add(new IntegerParameter("Target framerate.").addAliases("-f", "--target-framerate"));
- NullParameter deinterlaceParameter = parser.createNullParameter(
- "Deinterlace video.").addAliases("--deinterlace", "-d");
+ private final NullParameter deinterlaceParameter = parser.add(new NullParameter("Deinterlace video.")).addAliases("-d",
+ "--deinterlace");
- NullParameter testParameter = parser.createNullParameter(
- "Simulate file encoding.").addAliases("-t", "--test");
+ private final NullParameter testParameter = parser.add(new NullParameter("Simulate file encoding.")).addAliases("-t", "--test");
- NullParameter recursiveParameter = parser.createNullParameter(
- "Enable recursive mode.").addAliases("-r", "--recursive");
+ private final NullParameter recursiveParameter = parser.add(new NullParameter("Enable recursive mode.")).addAliases("-r",
+ "--recursive");
- StringParameter inputPatternParameter = parser
- .createStringParameter("File input pattern.")
- .addAliases("-i", "--input-pattern").setMandatory();
+ private final NullParameter forPortableParameter = parser.add(new NullParameter("Encode for portable player.")).addAliases("-p",
+ "--portable");
- DirectoryParameter workingDirectoryParameter = parser
- .createDirectoryParameter("Working directory.")
- .addAliases("-w", "--working-directory").mustExist();
+ private final StringParameters inputPatternParameter = parser.add(new StringParameters("File input pattern."))
+ .addAliases("-i", "--input-pattern").setMandatory();
- BitrateParameter videoBitrateParameter = new BitrateParameter(
- "Video bitrate");
+ private final DirectoryParameter workingDirectoryParameter = parser.add(new DirectoryParameter("Working directory."))
+ .addAliases("-w", "--working-directory").mustExist();
- public CommandlineHandler() {
- videoBitrateParameter.addAliases("-v", "--video-bitrate");
- parser.addParameter(videoBitrateParameter);
- }
+ private final BitrateParameter videoBitrateParameter = parser.add(new BitrateParameter("Video bitrate")).addAliases("-v",
+ "--video-bitrate");
- /**
- * @return {@link EncodingOptions} if commandline arguments were
- * successfully parsed, or null
if parsing error
- * occurred.
- */
- public EncodingOptions parseCommandlineArguments(final String[] args) {
+ private final BitrateParameter audioBitrateParameter = parser.add(new BitrateParameter("Audio bitrate")).addAliases("-a",
+ "--audio-bitrate");
- final EncodingOptions options = new EncodingOptions();
+ /**
+ * @return {@link EncodingOptions} if commandline arguments were
+ * successfully parsed, or null
if parsing error
+ * occurred.
+ */
+ public EncodingOptions parseCommandlineArguments(final String[] args) {
- parser.parse(args);
+ final EncodingOptions options = new EncodingOptions();
- if (recursiveParameter.isParameterSpecified())
- options.recursive = true;
+ parser.parse(args);
- if (deinterlaceParameter.isParameterSpecified())
- options.deinterlace = true;
+ options.setRecursive(recursiveParameter.isSpecified());
- if (terminalParameter.isParameterSpecified())
- options.terminal = true;
+ options.setDeinterlace(deinterlaceParameter.isSpecified());
- if (testParameter.isParameterSpecified())
- options.testOnly = true;
+ options.setTestOnly(testParameter.isSpecified());
- if (outputFormatParameter.isParameterSpecified())
- options.outputFormats.addAll(outputFormatParameter
- .getArgumentsAsStrings());
+ if (outputFormatParameter.isSpecified())
+ options.getOutputFormats().addAll(outputFormatParameter.getValue());
- if (workingDirectoryParameter.isParameterSpecified())
- options.workingDirectory = workingDirectoryParameter
- .getArgumentsAsFiles().get(0);
+ if (targetFramerate.isSpecified())
+ options.setTargetFps(targetFramerate.getValue());
- if (inputPatternParameter.isParameterSpecified())
- options.inputPatterns.addAll(inputPatternParameter
- .getArgumentsAsStrings());
+ if (workingDirectoryParameter.isSpecified())
+ options.setWorkingDirectory(workingDirectoryParameter.getValue());
- if (videoBitrateParameter.isParameterSpecified())
- try {
- options.videoBitrate = videoBitrateParameter.getValue();
- } catch (final Exception e) {
- System.out
- .println("Invalid video bitrate. Valid values are: LOW, MEDIUM, HIGH.");
- return null;
- }
+ if (inputPatternParameter.isSpecified())
+ options.getInputPatterns().addAll(inputPatternParameter.getValue());
- return options;
- }
+ options.setForPortablePlayer(forPortableParameter.isSpecified());
+
+ if (videoBitrateParameter.isSpecified())
+ options.setVideoBitrate(videoBitrateParameter.getValue());
+
+ if (audioBitrateParameter.isSpecified())
+ options.setAudioBitrate(audioBitrateParameter.getValue());
+
+ return options;
+ }
}