private PdfCopy pdfWriter = null;
public void execute(AbstractParsedCommand parsedCommand) throws ConsoleException {
if((parsedCommand != null) && (parsedCommand instanceof PageLabelsParsedCommand)){
PageLabelsParsedCommand inputCommand = (PageLabelsParsedCommand) parsedCommand;
setPercentageOfWorkDone(0);
Document currentDocument;
try{
File tmpFile = FileUtility.generateTmpFile(inputCommand.getOutputFile());
LOG.debug("Opening "+inputCommand.getInputFile().getFile().getAbsolutePath());
pdfReader = new PdfReader(new RandomAccessFileOrArray(inputCommand.getInputFile().getFile().getAbsolutePath()),inputCommand.getInputFile().getPasswordBytes());
pdfReader.removeUnusedObjects();
pdfReader.consolidateNamedDestinations();
int n = pdfReader.getNumberOfPages();
currentDocument = new Document(pdfReader.getPageSizeWithRotation(1));
pdfWriter = new PdfCopy(currentDocument, new FileOutputStream(tmpFile));
//set compressed
setCompressionSettingOnWriter(inputCommand, pdfWriter);
//set pdf version
setPdfVersionSettingOnWriter(inputCommand, pdfWriter, Character.valueOf(pdfReader.getPdfVersion()));
//set creator
currentDocument.addCreator(ConsoleServicesFacade.CREATOR);
currentDocument.open();
for (int count = 1; count <= n; count++) {
pdfWriter.addPage(pdfWriter.getImportedPage(pdfReader, count));
}
pdfReader.close();
pdfWriter.freeReader(pdfReader);
//set labels
PdfPageLabels pageLabels = new PdfPageLabels();
PageLabel[] labels = inputCommand.getLabels();
//last step is creating the file
int stepsNumber = labels.length + 1;
for(int i=0; i<labels.length; i++){
if(labels[i].getPageNumber()<=n){
pageLabels.addPageLabel(labels[i].getPageNumber(), getPageLabelStyle(labels[i].getStyle()), labels[i].getPrefix(), labels[i].getLogicalPageNumber());
}else{
LOG.warn("Page number out of range, label starting at page "+labels[i].getPageNumber()+" will be ignored");
}
setPercentageOfWorkDone((i*WorkDoneDataModel.MAX_PERGENTAGE)/stepsNumber);
}
pdfWriter.setPageLabels(pageLabels);
currentDocument.close();
pdfWriter.close();
FileUtility.renameTemporaryFile(tmpFile, inputCommand.getOutputFile(), inputCommand.isOverwrite());
LOG.debug("Page labels set on file "+inputCommand.getOutputFile());
}catch(Exception e){
throw new PageLabelsException(e);
}finally{
setWorkCompleted();
}