possibility to change video framerate
[meviz.git] / src / main / java / eu / svjatoslav / meviz / encoder / CommandlineHandler.java
index fd9d9e9..5a6ecbd 100755 (executable)
@@ -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,93 @@
 
 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.IntegerParameter;
+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");
+       IntegerParameter targetFramerate = parser.add(new IntegerParameter(
+                       "Target framerate.").addAliases("-f", "--target-frame"));
 
-    Parameter recursiveParameter = new Parameter("Enable recursive mode.", "-r", "--recursive");
+       NullParameter deinterlaceParameter = parser.add(
+                       new NullParameter("Deinterlace video.")).addAliases("-d",
+                       "--deinterlace");
 
-    Parameter inputPatternParameter = new Parameter(true, true, true,
-            new eu.svjatoslav.commons.commandline.parameterparser.arguments.String(), "File input pattern.", "-i",
-            "--input-pattern");
+       NullParameter testParameter = parser.add(
+                       new NullParameter("Simulate file encoding.")).addAliases("-t",
+                       "--test");
 
-    Parameter workingDirectoryParameter = new Parameter(false, true, true,
-            new eu.svjatoslav.commons.commandline.parameterparser.arguments.ExistingDirectory(), "Working directory.",
-            "-w", "--working-directory");
+       NullParameter recursiveParameter = parser.add(
+                       new NullParameter("Enable recursive mode.")).addAliases("-r",
+                       "--recursive");
 
-    Parameter videoBitrateParameter = new Parameter(false, true, false, new Bitrate(), "Video bitrate.", "-v",
-            "--video-bitrate");
+       NullParameter forPortableParameter = parser.add(
+                       new NullParameter("Encode for portable player.")).addAliases("-p",
+                       "--portable");
 
-    public Parser initParser() {
-        final Parser parser = new Parser();
+       StringParameters inputPatternParameter = parser
+                       .add(new StringParameters("File input pattern."))
+                       .addAliases("-i", "--input-pattern").setMandatory();
 
-        parser.addParameter(recursiveParameter);
+       DirectoryParameter workingDirectoryParameter = parser
+                       .add(new DirectoryParameter("Working directory."))
+                       .addAliases("-w", "--working-directory").mustExist();
 
-        parser.addParameter(testParameter);
+       BitrateParameter videoBitrateParameter = parser.add(
+                       new BitrateParameter("Video bitrate")).addAliases("-v",
+                       "--video-bitrate");
 
-        parser.addParameter(terminalParameter);
+       BitrateParameter audioBitrateParameter = parser.add(
+                       new BitrateParameter("Audio bitrate")).addAliases("-a",
+                       "--audio-bitrate");
 
-        parser.addParameter(outputFormatParameter);
+       /**
+        * @return {@link EncodingOptions} if commandline arguments were
+        *         successfully parsed, or <code>null</code> if parsing error
+        *         occurred.
+        */
+       public EncodingOptions parseCommandlineArguments(final String[] args) {
 
-        parser.addParameter(inputPatternParameter);
+               final EncodingOptions options = new EncodingOptions();
 
-        parser.addParameter(workingDirectoryParameter);
+               parser.parse(args);
 
-        parser.addParameter(videoBitrateParameter);
+               options.setRecursive(recursiveParameter.isParameterSpecified());
 
-        return parser;
-    }
+               options.setDeinterlace(deinterlaceParameter.isParameterSpecified());
 
-    /**
-     * @return {@link EncodingOptions} if commandline arguments were
-     *         successfully parsed, or <code>null</code> if parsing error
-     *         occurred.
-     */
-    public EncodingOptions parseCommandlineArguments(final String[] args) {
+               options.setTestOnly(testParameter.isParameterSpecified());
 
-        final EncodingOptions options = new EncodingOptions();
+               if (outputFormatParameter.isParameterSpecified())
+                       options.getOutputFormats().addAll(outputFormatParameter.getValue());
 
-        final Parser parser = initParser();
-        parser.parse(args);
+               if (targetFramerate.isParameterSpecified())
+                       options.setTargetFps(targetFramerate.getValue());
 
-        if (recursiveParameter.isParameterSpecified())
-            options.recursive = true;
+               if (workingDirectoryParameter.isParameterSpecified())
+                       options.setWorkingDirectory(workingDirectoryParameter.getValue());
 
-        if (terminalParameter.isParameterSpecified())
-            options.terminal = true;
+               if (inputPatternParameter.isParameterSpecified())
+                       options.getInputPatterns().addAll(inputPatternParameter.getValue());
 
-        if (testParameter.isParameterSpecified())
-            options.testOnly = true;
+               options.setForPortablePlayer(forPortableParameter
+                               .isParameterSpecified());
 
-        if (outputFormatParameter.isParameterSpecified()) {
-            options.outputFormats.addAll(outputFormatParameter.getArgumentsAsStrings());
-        }
+               if (videoBitrateParameter.isParameterSpecified())
+                       options.setVideoBitrate(videoBitrateParameter.getValue());
 
-        if (workingDirectoryParameter.isParameterSpecified()) {
-            options.workingDirectory = workingDirectoryParameter.getArgumentsAsFiles().get(0);
-        }
+               if (audioBitrateParameter.isParameterSpecified())
+                       options.setAudioBitrate(audioBitrateParameter.getValue());
 
-        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;
+       }
 }