X-Git-Url: http://www2.svjatoslav.eu/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Feu%2Fsvjatoslav%2Fmeviz%2Ftextsplitter%2FCommandlineHandler.java;h=8060db6090cd211605532d7527bab726f1a73270;hb=76af31ee2b5fe6e26e897019fdb0bad9fbcaa93d;hp=1364a1344a727c09d13987b92d6fc1eaefb9bce8;hpb=50cb7085d553fdd82cd06806cd27b1675299f719;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 1364a13..8060db6 100755 --- a/src/main/java/eu/svjatoslav/meviz/textsplitter/CommandlineHandler.java +++ b/src/main/java/eu/svjatoslav/meviz/textsplitter/CommandlineHandler.java @@ -11,43 +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.parameter.DirectoryParameter; +import eu.svjatoslav.commons.commandline.parameterparser.parameter.NullParameter; +import eu.svjatoslav.commons.commandline.parameterparser.parameter.StringParameter; public class CommandlineHandler { - Parameter recursiveParameter = new Parameter("Enable recursive mode.", - "-r", "--recursive"); + Parser parser = new Parser(); - Parameter inputPatternParameter = new Parameter( - true, - true, - true, - new eu.svjatoslav.commons.commandline.parameterparser.arguments.String(), - "File input pattern.", "-i", "--input-pattern"); + NullParameter recursiveParameter = parser.createNullParameter( + "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"); + StringParameter fileInputPatternsParameter = parser + .createStringParameter("File input pattern.") + .addAliases("-i", "--input-pattern").setMandatory(); - public Parser initParser() { + StringParameter splitPatternsParameter = parser + .createStringParameter("File split regular expression.") + .addAliases("-s", "--split-pattern").setMandatory(); - final Parser parser = new Parser(); - parser.addParameter(recursiveParameter); - parser.addParameter(inputPatternParameter); - 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; @@ -55,13 +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 (inputPatternParameter.isParameterSpecified()) - options.inputPatterns.addAll(inputPatternParameter + if (fileInputPatternsParameter.isParameterSpecified()) + options.fileInputPatterns.addAll(fileInputPatternsParameter + .getArgumentsAsStrings()); + + if (splitPatternsParameter.isParameterSpecified()) + options.textSplitPatterns.addAll(splitPatternsParameter .getArgumentsAsStrings()); return options;