#include "initial_comic_info_extractor.h" #include #include "pdf_comic.h" #include "comic.h" #include "compressed_archive.h" #include "qnaturalsorting.h" #include "cover_utils.h" using namespace YACReader; bool InitialComicInfoExtractor::crash = false; InitialComicInfoExtractor::InitialComicInfoExtractor(QString fileSource, QString target, int coverPage, bool getXMLMetadata) : _fileSource(fileSource), _target(target), _numPages(0), _coverPage(coverPage), getXMLMetadata(getXMLMetadata), _xmlInfoData() { if (coverPage <= 0) { _coverPage = 1; } } void InitialComicInfoExtractor::extract() { QFileInfo fi(_fileSource); if (!fi.exists()) // TODO: error file not found. { _cover.load(":/images/notCover.png"); QLOG_WARN() << "Extracting cover: file not found " << _fileSource; return; } #ifndef NO_PDF if (fi.suffix().compare("pdf", Qt::CaseInsensitive) == 0) { #if defined Q_OS_MACOS && defined USE_PDFKIT auto pdfComic = std::make_unique(); if (!pdfComic->openComic(_fileSource)) { return; } #elif defined USE_PDFIUM auto pdfComic = std::make_unique(); if (!pdfComic->openComic(_fileSource)) { return; } #else #if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0) auto pdfComic = Poppler::Document::load(_fileSource); #else auto _pdfComic = Poppler::Document::load(_fileSource); auto pdfComic = std::unique_ptr(_pdfComic); #endif #endif if (!pdfComic) { QLOG_WARN() << "Extracting cover: unable to open PDF file " << _fileSource; return; } #if !defined USE_PDFKIT && !defined USE_PDFIUM // poppler only, not mac if (pdfComic->isLocked()) { QLOG_WARN() << "Extracting cover: unable to open PDF file " << _fileSource; return; } #endif _numPages = pdfComic->numPages(); if (_numPages >= _coverPage) { #if defined Q_OS_MACOS || defined USE_PDFIUM QImage p = pdfComic->getPage(_coverPage - 1); // TODO check if the page is valid #else QImage p = pdfComic->page(_coverPage - 1)->renderToImage(72, 72); #endif // _cover = p; _coverSize = QPair(p.width(), p.height()); if (_target != "") { saveCover(_target, p); } else if (_target != "") { QLOG_WARN() << "Extracting cover: requested cover index greater than numPages " << _fileSource; } } return; } #endif // NO_PDF if (crash) { return; } CompressedArchive archive(_fileSource); if (!archive.toolsLoaded()) { QLOG_WARN() << "Extracting cover: 7z lib not loaded"; crash = true; return; } if (!archive.isValid()) { QLOG_WARN() << "Extracting cover: file format not supported " << _fileSource; } QList order = archive.getFileNames(); if (getXMLMetadata) { // Try to find embeded XML info (ComicRack or ComicTagger) auto infoIndex = 0; for (auto &fileName : order) { if (fileName.endsWith(".xml", Qt::CaseInsensitive)) { _xmlInfoData = archive.getRawDataAtIndex(infoIndex); break; } infoIndex++; } } //-------------------------- if (_target == "None") { return; } // se filtran para obtener sólo los formatos soportados QList fileNames = FileComic::filter(order); _numPages = fileNames.size(); if (_numPages == 0) { QLOG_WARN() << "Extracting cover: empty comic " << _fileSource; _cover.load(":/images/notCover.png"); if (_target != "") { _cover.save(_target); } } else { if (_coverPage > _numPages) { _coverPage = 1; } std::sort(fileNames.begin(), fileNames.end(), naturalSortLessThanCI); int index = order.indexOf(fileNames.at(_coverPage - 1)); if (_target == "") { if (!_cover.loadFromData(archive.getRawDataAtIndex(index))) { QLOG_WARN() << "Extracting cover: unable to load image from extracted cover " << _fileSource; _cover.load(":/images/notCover.png"); } } else { QImage p; if (p.loadFromData(archive.getRawDataAtIndex(index))) { _coverSize = QPair(p.width(), p.height()); saveCover(_target, p); } else { QLOG_WARN() << "Extracting cover: unable to load image from extracted cover " << _fileSource; // p.load(":/images/notCover.png"); // p.save(_target); } } } } QByteArray InitialComicInfoExtractor::getXMLInfoRawData() { return _xmlInfoData; } void InitialComicInfoExtractor::saveCover(const QString &path, const QImage &cover) { YACReader::saveCover(path, cover); }