/**
* diqube: Distributed Query Base.
*
* Copyright (C) 2015 Bastian Gloeckle
*
* This file is part of diqube.
*
* diqube is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package org.diqube.tool.merge;
import java.io.File;
import java.util.List;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import org.apache.commons.cli.CommandLine;
import org.apache.commons.cli.CommandLineParser;
import org.apache.commons.cli.DefaultParser;
import org.apache.commons.cli.HelpFormatter;
import org.apache.commons.cli.Option;
import org.apache.commons.cli.Options;
import org.apache.commons.cli.ParseException;
import org.diqube.tool.ToolFunction;
import org.diqube.tool.ToolFunctionName;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Merges two .diqube files into a single one, containing all the TableShards of both source files.
*
* @author Bastian Gloeckle
*/
@ToolFunctionName(Merge.FUNCTION_NAME)
public class Merge implements ToolFunction {
private static final Logger logger = LoggerFactory.getLogger(Merge.class);
public static final String FUNCTION_NAME = "merge";
private static final String OPT_HELP = "h";
private static final String OPT_INPUT = "i";
private static final String OPT_OUTPUT = "o";
private static final String OPT_COMMENT = "c";
@Override
public void execute(String[] args) {
Options cliOpt = createCliOptions();
CommandLineParser parser = new DefaultParser();
CommandLine cmd = null;
boolean showHelp = false;
try {
cmd = parser.parse(cliOpt, args);
showHelp |= cmd.hasOption(OPT_HELP);
} catch (ParseException e) {
logger.error(e.getMessage());
showHelp = true;
}
if (showHelp) {
HelpFormatter formatter = new HelpFormatter();
formatter.printHelp(Merge.FUNCTION_NAME + " [options]",
"\nReads two .diqube files and merges the contents into an output .diqube file. All TableShards of the "
+ "input files are simply copied into the output file.\n\n",
cliOpt, "");
return;
}
List<File> inputFiles =
Stream.of(cmd.getOptionValues(OPT_INPUT)).map(f -> new File(f)).collect(Collectors.toList());
File outputFile = new File(cmd.getOptionValue(OPT_OUTPUT));
for (File inputFile : inputFiles) {
if (!inputFile.isFile() || !inputFile.exists()) {
logger.error("{} does not exist or is a directory.", inputFile.getAbsolutePath());
return;
}
}
if (outputFile.exists() && outputFile.isDirectory()) {
logger.error("{} exists and is a directory.", outputFile.getAbsolutePath());
return;
}
String comment = cmd.getOptionValue(OPT_COMMENT);
new MergeImplementation(inputFiles, outputFile, comment).merge();
}
private Options createCliOptions() {
Options res = new Options();
res.addOption(
Option.builder(OPT_INPUT).longOpt("input").numberOfArgs(Option.UNLIMITED_VALUES).argName("file> <file> <...")
.desc("The input file(s) to read from (.diqube format, at least one required).").required().build());
res.addOption(Option.builder(OPT_OUTPUT).longOpt("output").numberOfArgs(1).argName("file")
.desc("Output file name (required).").required().build());
res.addOption(Option.builder(OPT_COMMENT).longOpt("comment").numberOfArgs(1).argName("string")
.desc("Comment to write into the output file.").build());
res.addOption(Option.builder(OPT_HELP).longOpt("help").desc("Show this help.").build());
return res;
}
}