X-Git-Url: http://www2.svjatoslav.eu/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Feu%2Fsvjatoslav%2Fmeviz%2Ftextsplitter%2FCommandlineHandler.java;h=ef2a27ae5b2b72119d180220e2cfa04a530163d5;hb=dd6a4d4e4dd46ca95be11ae91c633d69f085472c;hp=5f7bc0e3aa535e10824c5bebffbdcd6160af5531;hpb=92b09ba436ee986976a4430ebf5c8359916bc2a8;p=meviz.git diff --git a/src/main/java/eu/svjatoslav/meviz/textsplitter/CommandlineHandler.java b/src/main/java/eu/svjatoslav/meviz/textsplitter/CommandlineHandler.java index 5f7bc0e..ef2a27a 100755 --- a/src/main/java/eu/svjatoslav/meviz/textsplitter/CommandlineHandler.java +++ b/src/main/java/eu/svjatoslav/meviz/textsplitter/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. @@ -11,44 +11,34 @@ package eu.svjatoslav.meviz.textsplitter; import java.io.File; -import eu.svjatoslav.commons.commandline.parameterparser.Parameter; import eu.svjatoslav.commons.commandline.parameterparser.Parser; -import eu.svjatoslav.commons.commandline.parameterparser.arguments.ExistingDirectory; -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.StringParameters; public class CommandlineHandler { - Parameter recursiveParameter = new Parameter("Enable recursive mode.", - "-r", "--recursive"); + Parser parser = new Parser(); - Parameter fileInputPatternsParameter = new Parameter(true, true, true, - new StringArgument(), "File input pattern.", "-i", - "--input-pattern"); + NullParameter recursiveParameter = parser.createNullParameter( + "Enable recursive mode.").addAliases("-r", "--recursive"); - Parameter splitPatternsParameter = new Parameter(true, true, true, - new StringArgument(), "File split regular expression.", "-s", - "--split-pattern"); + StringParameters fileInputPatternsParameter = parser + .createStringParameters("File input pattern.") + .addAliases("-i", "--input-pattern").setMandatory(); - Parameter workingDirectoryParameter = new Parameter(false, true, true, - new ExistingDirectory(), "Working directory.", "-w", - "--working-directory"); + StringParameters splitPatternsParameter = parser + .createStringParameters("File split regular expression.") + .addAliases("-s", "--split-pattern").setMandatory(); - public Parser initParser() { - - final Parser parser = new Parser(); - parser.addParameter(recursiveParameter); - parser.addParameter(fileInputPatternsParameter); - parser.addParameter(splitPatternsParameter); - parser.addParameter(workingDirectoryParameter); - - return parser; - } + DirectoryParameter workingDirectoryParameter = parser + .createDirectoryParameter("Working directory.").addAliases("-w", + "--working-directory"); public TextSplittingOptions parseCommandlineArguments(final String[] args) { final TextSplittingOptions options = new TextSplittingOptions(); - final Parser parser = initParser(); if (!parser.parse(args)) return null; @@ -56,18 +46,16 @@ public class CommandlineHandler { options.recursive = true; if (workingDirectoryParameter.isParameterSpecified()) - options.targetDirectory = workingDirectoryParameter - .getArgumentsAsFiles().get(0); + options.targetDirectory = workingDirectoryParameter.getValue(); else options.targetDirectory = new File(System.getProperty("user.dir")); if (fileInputPatternsParameter.isParameterSpecified()) options.fileInputPatterns.addAll(fileInputPatternsParameter - .getArgumentsAsStrings()); + .getValue()); if (splitPatternsParameter.isParameterSpecified()) - options.textSplitPatterns.addAll(splitPatternsParameter - .getArgumentsAsStrings()); + options.textSplitPatterns.addAll(splitPatternsParameter.getValue()); return options; }