PDF4QT/PdfTool/pdftoolinfojavascript.cpp

157 lines
5.6 KiB
C++
Raw Normal View History

2020-10-05 19:50:04 +02:00
// Copyright (C) 2020 Jakub Melka
//
// This file is part of PdfForQt.
//
// PdfForQt is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// PdfForQt 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 Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with PDFForQt. If not, see <https://www.gnu.org/licenses/>.
#include "pdftoolinfojavascript.h"
#include "pdfjavascriptscanner.h"
namespace pdftool
{
static PDFToolInfoJavaScriptApplication s_infoJavaScriptApplication;
2020-10-07 18:57:34 +02:00
QString PDFToolInfoJavaScriptApplication::getStandardString(StandardString standardString) const
2020-10-05 19:50:04 +02:00
{
switch (standardString)
{
case Command:
return "info-javascript";
case Name:
return PDFToolTranslationContext::tr("Info (JavaScript code)");
case Description:
return PDFToolTranslationContext::tr("Retrieve informations about JavaScript usage in a document.");
default:
Q_ASSERT(false);
break;
}
return QString();
}
int PDFToolInfoJavaScriptApplication::execute(const PDFToolOptions& options)
{
pdf::PDFDocument document;
QByteArray sourceData;
if (!readDocument(options, document, &sourceData))
{
return ErrorDocumentReading;
}
QString parseError;
2020-10-07 18:57:34 +02:00
std::vector<pdf::PDFInteger> pages = options.getPageRange(document.getCatalog()->getPageCount(), parseError, true);
2020-10-05 19:50:04 +02:00
if (!parseError.isEmpty())
{
PDFConsole::writeError(parseError, options.outputCodec);
return ErrorInvalidArguments;
}
pdf::PDFJavaScriptScanner scanner(&document);
2020-10-06 19:21:05 +02:00
pdf::PDFJavaScriptScanner::Entries javascripts = scanner.scan(pages, pdf::PDFJavaScriptScanner::ScanMask | pdf::PDFJavaScriptScanner::Optimize);
QLocale locale;
PDFOutputFormatter formatter(options.outputStyle, options.outputCodec);
formatter.beginDocument("info-javascripts", PDFToolTranslationContext::tr("JavaScript used in document %1").arg(options.document));
formatter.endl();
formatter.beginTable("overview", PDFToolTranslationContext::tr("JavaScript Usage Overview"));
formatter.beginTableHeaderRow("header");
formatter.writeTableHeaderColumn("no", PDFToolTranslationContext::tr("No."), Qt::AlignLeft);
formatter.writeTableHeaderColumn("context", PDFToolTranslationContext::tr("Context"), Qt::AlignLeft);
formatter.writeTableHeaderColumn("page-number", PDFToolTranslationContext::tr("Page Number"), Qt::AlignLeft);
formatter.writeTableHeaderColumn("code-size", PDFToolTranslationContext::tr("Code Size"), Qt::AlignLeft);
formatter.writeTableHeaderColumn("code-snippet", PDFToolTranslationContext::tr("Code Snippet"), Qt::AlignLeft);
formatter.endTableHeaderRow();
int ref = 1;
for (const pdf::PDFJavaScriptEntry& entry : javascripts)
{
formatter.beginTableRow("javascript", ref);
QString contextText;
switch (entry.type)
{
case pdf::PDFJavaScriptEntry::Type::Document:
contextText = PDFToolTranslationContext::tr("Document");
break;
case pdf::PDFJavaScriptEntry::Type::Named:
contextText = PDFToolTranslationContext::tr("Named");
break;
case pdf::PDFJavaScriptEntry::Type::Form:
contextText = PDFToolTranslationContext::tr("Form");
break;
case pdf::PDFJavaScriptEntry::Type::Page:
contextText = PDFToolTranslationContext::tr("Page");
break;
case pdf::PDFJavaScriptEntry::Type::Annotation:
contextText = PDFToolTranslationContext::tr("Annotation");
break;
default:
Q_ASSERT(false);
break;
}
formatter.writeTableColumn("no", locale.toString(ref), Qt::AlignRight);
formatter.writeTableColumn("context", contextText);
2020-10-07 18:57:34 +02:00
formatter.writeTableColumn("page-number", (entry.pageIndex != -1) ? locale.toString(entry.pageIndex + 1) : QString(), Qt::AlignRight);
formatter.writeTableColumn("code-size", locale.toString(entry.javaScript.size()), Qt::AlignRight);
2020-10-06 19:21:05 +02:00
formatter.writeTableColumn("code-snippet", entry.javaScript.left(64));
formatter.endTableRow();
++ref;
}
formatter.endTable();
formatter.endl();
formatter.beginHeader("details", PDFToolTranslationContext::tr("Details"));
ref = 1;
for (const pdf::PDFJavaScriptEntry& entry : javascripts)
{
formatter.endl();
formatter.beginHeader("javascript", PDFToolTranslationContext::tr("JavaScript #%1").arg(ref), ref);
formatter.writeText("code", entry.javaScript);
formatter.endHeader();
++ref;
}
formatter.endHeader();
formatter.endDocument();
PDFConsole::writeText(formatter.getString(), options.outputCodec);
2020-10-05 19:50:04 +02:00
return ExitSuccess;
}
PDFToolAbstractApplication::Options PDFToolInfoJavaScriptApplication::getOptionsFlags() const
{
return ConsoleFormat | OpenDocument | PageSelector;
}
} // namespace pdftool