private static final Logger LOG = Logger.getLogger(AlternateMixCmdExecutor.class.getPackage().getName());
public void execute(AbstractParsedCommand parsedCommand) throws ConsoleException {
if ((parsedCommand != null) && (parsedCommand instanceof MixParsedCommand)) {
MixParsedCommand inputCommand = (MixParsedCommand) parsedCommand;
setWorkIndeterminate();
Document pdfDocument = null;
int[] limits1 = { 1, 1 };
int[] limits2 = { 1, 1 };
try {
File tmpFile = FileUtility.generateTmpFile(inputCommand.getOutputFile());
pdfReader1 = new PdfReader(new RandomAccessFileOrArray(inputCommand.getFirstInputFile().getFile()
.getAbsolutePath()), inputCommand.getFirstInputFile().getPasswordBytes());
pdfReader1.removeUnusedObjects();
pdfReader1.consolidateNamedDestinations();
limits1[1] = pdfReader1.getNumberOfPages();
pdfReader2 = new PdfReader(new RandomAccessFileOrArray(inputCommand.getSecondInputFile().getFile()
.getAbsolutePath()), inputCommand.getSecondInputFile().getPasswordBytes());
pdfReader2.removeUnusedObjects();
pdfReader2.consolidateNamedDestinations();
limits2[1] = pdfReader2.getNumberOfPages();
pdfDocument = new Document(pdfReader1.getPageSizeWithRotation(1));
LOG.debug("Creating a new document.");
pdfWriter = new PdfCopy(pdfDocument, new FileOutputStream(tmpFile));
setPdfVersionSettingOnWriter(inputCommand, pdfWriter);
setCompressionSettingOnWriter(inputCommand, pdfWriter);
pdfDocument.addCreator(ConsoleServicesFacade.CREATOR);
pdfDocument.open();
PdfImportedPage page;
boolean finished1 = false;
boolean finished2 = false;
int current1 = (inputCommand.isReverseFirst()) ? limits1[1] : limits1[0];
int current2 = (inputCommand.isReverseSecond()) ? limits2[1] : limits2[0];
while (!finished1 || !finished2) {
if (!finished1) {
for (int i = 0; (i < inputCommand.getStep() && !finished1); i++) {
if (current1 >= limits1[0] && current1 <= limits1[1]) {
page = pdfWriter.getImportedPage(pdfReader1, current1);
pdfWriter.addPage(page);
current1 = (inputCommand.isReverseFirst()) ? (current1 - 1) : (current1 + 1);
} else {
LOG.info("First file processed.");
pdfReader1.close();
finished1 = true;
}
}
}
if (!finished2) {
for (int i = 0; (i < inputCommand.getSecondStep() && !finished2); i++) {
if (current2 >= limits2[0] && current2 <= limits2[1] && !finished2) {
page = pdfWriter.getImportedPage(pdfReader2, current2);
pdfWriter.addPage(page);
current2 = (inputCommand.isReverseSecond()) ? (current2 - 1) : (current2 + 1);
} else {
LOG.info("Second file processed.");
pdfReader2.close();
finished2 = true;
}
}
}
}
pdfWriter.freeReader(pdfReader1);
pdfWriter.freeReader(pdfReader2);
pdfDocument.close();
FileUtility.renameTemporaryFile(tmpFile, inputCommand.getOutputFile(), inputCommand.isOverwrite());
LOG.debug("File " + inputCommand.getOutputFile().getCanonicalPath() + " created.");
LOG.info("Alternate mix with step first document " + inputCommand.getStep()
+ " and step second document " + inputCommand.getSecondStep() + " completed.");
} catch (Exception e) {
throw new MixException(e);
} finally {
setWorkCompleted();
}