mirror of
				https://github.com/YACReader/yacreader
				synced 2025-11-04 01:05:06 -05:00 
			
		
		
		
	Unify 7zip CompressedArchive interface for Windows and Unix.
This works on macos.
This commit is contained in:
		@ -20,6 +20,10 @@ extern "C" {
 | 
				
			|||||||
#include "lib7zip/CPP/7zip/IPassword.h"
 | 
					#include "lib7zip/CPP/7zip/IPassword.h"
 | 
				
			||||||
#include "lib7zip/CPP/7zip/MyVersion.h"
 | 
					#include "lib7zip/CPP/7zip/MyVersion.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "lib7zip/CPP/Windows/FileDir.h"
 | 
				
			||||||
 | 
					#include "lib7zip/CPP/Windows/FileFind.h"
 | 
				
			||||||
 | 
					#include "lib7zip/CPP/Windows/FileName.h"
 | 
				
			||||||
 | 
					#include "lib7zip/CPP/Windows/NtCheck.h"
 | 
				
			||||||
#include "lib7zip/CPP/Windows/PropVariant.h"
 | 
					#include "lib7zip/CPP/Windows/PropVariant.h"
 | 
				
			||||||
#include "lib7zip/CPP/Windows/PropVariantConv.h"
 | 
					#include "lib7zip/CPP/Windows/PropVariantConv.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -1,10 +0,0 @@
 | 
				
			|||||||
#ifndef _7Z_PRECOMPILED_HEADER_H
 | 
					 | 
				
			||||||
#define _7Z_PRECOMPILED_HEADER_H
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#if defined __cplusplus
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#include "libp7zip/CPP/myWindows/StdAfx.h"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif // 7Z_PRECOMPILED_HEADER_H
 | 
					 | 
				
			||||||
@ -1,7 +1,4 @@
 | 
				
			|||||||
#include <QtCore>
 | 
					#include <QtCore>
 | 
				
			||||||
#ifndef Q_OS_WIN
 | 
					 | 
				
			||||||
#include "libp7zip/CPP/Common/MyInitGuid.h"
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include "compressed_archive.h"
 | 
					#include "compressed_archive.h"
 | 
				
			||||||
#include "extract_delegate.h"
 | 
					#include "extract_delegate.h"
 | 
				
			||||||
@ -15,12 +12,9 @@
 | 
				
			|||||||
#include "extract_callbacks.h"
 | 
					#include "extract_callbacks.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include "7z_includes.h"
 | 
					#include "7z_includes.h"
 | 
				
			||||||
 | 
					#include "lib7zip/CPP/Common/MyInitGuid.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef Q_OS_WIN
 | 
					 | 
				
			||||||
#define _MY_WINAPI WINAPI
 | 
					#define _MY_WINAPI WINAPI
 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
#define _MY_WINAPI
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
typedef quint32(_MY_WINAPI *CreateObjectFunc)(const GUID *clsID, const GUID *interfaceID, void **outObject);
 | 
					typedef quint32(_MY_WINAPI *CreateObjectFunc)(const GUID *clsID, const GUID *interfaceID, void **outObject);
 | 
				
			||||||
typedef quint32(_MY_WINAPI *GetMethodPropertyFunc)(quint32 index, PROPID propID, PROPVARIANT *value);
 | 
					typedef quint32(_MY_WINAPI *GetMethodPropertyFunc)(quint32 index, PROPID propID, PROPVARIANT *value);
 | 
				
			||||||
@ -57,22 +51,18 @@ DEFINE_GUID(CLSID_CFormatSplit,   0x23170f69, 0x40c1, 0x278a, 0x10, 0x00, 0x00,
 | 
				
			|||||||
DEFINE_GUID(CLSID_CFormatWim,     0x23170f69, 0x40c1, 0x278a, 0x10, 0x00, 0x00, 0x01, 0x10, 0xe6, 0x00, 0x00);
 | 
					DEFINE_GUID(CLSID_CFormatWim,     0x23170f69, 0x40c1, 0x278a, 0x10, 0x00, 0x00, 0x01, 0x10, 0xe6, 0x00, 0x00);
 | 
				
			||||||
DEFINE_GUID(CLSID_CFormatZ,       0x23170f69, 0x40c1, 0x278a, 0x10, 0x00, 0x00, 0x01, 0x10, 0x05, 0x00, 0x00);*/
 | 
					DEFINE_GUID(CLSID_CFormatZ,       0x23170f69, 0x40c1, 0x278a, 0x10, 0x00, 0x00, 0x01, 0x10, 0x05, 0x00, 0x00);*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef Q_OS_WIN
 | 
					 | 
				
			||||||
GUID _supportedFileFormats[] = { CLSID_CFormatRar, CLSID_CFormatZip, CLSID_CFormatTar, CLSID_CFormat7z, CLSID_CFormatArj, CLSID_CFormatRar5 };
 | 
					GUID _supportedFileFormats[] = { CLSID_CFormatRar, CLSID_CFormatZip, CLSID_CFormatTar, CLSID_CFormat7z, CLSID_CFormatArj, CLSID_CFormatRar5 };
 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
GUID _supportedFileFormats[] = { CLSID_CFormatZip, CLSID_CFormatTar, CLSID_CFormat7z, CLSID_CFormatArj };
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
std::vector<GUID> supportedFileFormats(_supportedFileFormats, _supportedFileFormats + sizeof(_supportedFileFormats) / sizeof(_supportedFileFormats[0]));
 | 
					std::vector<GUID> supportedFileFormats(_supportedFileFormats, _supportedFileFormats + sizeof(_supportedFileFormats) / sizeof(_supportedFileFormats[0]));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
DEFINE_GUID(IID_InArchive, 0x23170F69, 0x40C1, 0x278A, 0x00, 0x00, 0x00, 0x06, 0x00, 0x60, 0x00, 0x00);
 | 
					DEFINE_GUID(IID_InArchive, 0x23170F69, 0x40C1, 0x278A, 0x00, 0x00, 0x00, 0x06, 0x00, 0x60, 0x00, 0x00);
 | 
				
			||||||
DEFINE_GUID(IID_ISetCompressCodecsInfoX, 0x23170F69, 0x40C1, 0x278A, 0x00, 0x00, 0x00, 0x04, 0x00, 0x61, 0x00, 0x00);
 | 
					DEFINE_GUID(IID_ISetCompressCodecsInfoX, 0x23170F69, 0x40C1, 0x278A, 0x00, 0x00, 0x00, 0x04, 0x00, 0x61, 0x00, 0x00);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*#ifdef Q_OS_UNIX
 | 
					//#ifdef Q_OS_UNIX
 | 
				
			||||||
DEFINE_GUID(IID_IOutStream,   0x23170F69, 0x40C1, 0x278A, 0x00, 0x00, 0x00, 0x03, 0x00, 0x04, 0x00, 0x00);
 | 
					// Z7_DEFINE_GUID(IID_IOutStream, 0x23170F69, 0x40C1, 0x278A, 0x00, 0x00, 0x00, 0x03, 0x00, 0x04, 0x00, 0x00);
 | 
				
			||||||
DEFINE_GUID(IID_IInStream,   0x23170F69, 0x40C1, 0x278A, 0x00, 0x00, 0x00, 0x03, 0x00, 0x03, 0x00, 0x00);
 | 
					// Z7_DEFINE_GUID(IID_IInStream, 0x23170F69, 0x40C1, 0x278A, 0x00, 0x00, 0x00, 0x03, 0x00, 0x03, 0x00, 0x00);
 | 
				
			||||||
DEFINE_GUID(IID_IStreamGetSize,   0x23170F69, 0x40C1, 0x278A, 0x00, 0x00, 0x00, 0x03, 0x00, 0x06, 0x00, 0x00);
 | 
					// Z7_DEFINE_GUID(IID_IStreamGetSize, 0x23170F69, 0x40C1, 0x278A, 0x00, 0x00, 0x00, 0x03, 0x00, 0x06, 0x00, 0x00);
 | 
				
			||||||
DEFINE_GUID(IID_ISequentialInStream,   0x23170F69, 0x40C1, 0x278A, 0x00, 0x00, 0x00, 0x03, 0x00, 0x01, 0x00, 0x00);
 | 
					// Z7_DEFINE_GUID(IID_ISequentialInStream, 0x23170F69, 0x40C1, 0x278A, 0x00, 0x00, 0x00, 0x03, 0x00, 0x01, 0x00, 0x00);
 | 
				
			||||||
#endif*/
 | 
					//#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
struct SevenZipInterface {
 | 
					struct SevenZipInterface {
 | 
				
			||||||
    CreateObjectFunc createObjectFunc;
 | 
					    CreateObjectFunc createObjectFunc;
 | 
				
			||||||
@ -82,13 +72,6 @@ struct SevenZipInterface {
 | 
				
			|||||||
    GetHandlerPropertyFunc getHandlerPropertyFunc;
 | 
					    GetHandlerPropertyFunc getHandlerPropertyFunc;
 | 
				
			||||||
    GetHandlerPropertyFunc2 getHandlerPropertyFunc2;
 | 
					    GetHandlerPropertyFunc2 getHandlerPropertyFunc2;
 | 
				
			||||||
    SetLargePageModeFunc setLargePageModeFunc;
 | 
					    SetLargePageModeFunc setLargePageModeFunc;
 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef Q_OS_UNIX
 | 
					 | 
				
			||||||
    CreateObjectFunc createObjectFuncRar;
 | 
					 | 
				
			||||||
    GetMethodPropertyFunc getMethodPropertyFuncRar;
 | 
					 | 
				
			||||||
    GetNumberOfMethodsFunc getNumberOfMethodsFuncRar;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    CMyComPtr<IInArchive> archive;
 | 
					    CMyComPtr<IInArchive> archive;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -103,10 +86,6 @@ const unsigned char arj[2] = { static_cast<unsigned char>(0x60), static_cast<uns
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
CompressedArchive::CompressedArchive(const QString &filePath, QObject *parent)
 | 
					CompressedArchive::CompressedArchive(const QString &filePath, QObject *parent)
 | 
				
			||||||
    : QObject(parent), sevenzLib(0), valid(false), tools(false)
 | 
					    : QObject(parent), sevenzLib(0), valid(false), tools(false)
 | 
				
			||||||
#ifdef Q_OS_UNIX
 | 
					 | 
				
			||||||
      ,
 | 
					 | 
				
			||||||
      isRar(false)
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    szInterface = new SevenZipInterface;
 | 
					    szInterface = new SevenZipInterface;
 | 
				
			||||||
    // load functions
 | 
					    // load functions
 | 
				
			||||||
@ -133,32 +112,6 @@ CompressedArchive::CompressedArchive(const QString &filePath, QObject *parent)
 | 
				
			|||||||
        if (!filex.open(QIODevice::ReadOnly))
 | 
					        if (!filex.open(QIODevice::ReadOnly))
 | 
				
			||||||
            return;
 | 
					            return;
 | 
				
			||||||
        QByteArray magicNumber = filex.read(8); // read first 8 bytes
 | 
					        QByteArray magicNumber = filex.read(8); // read first 8 bytes
 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef Q_OS_UNIX
 | 
					 | 
				
			||||||
        if (memcmp(magicNumber, rar, 6) != 0) {
 | 
					 | 
				
			||||||
            // match suffix to GUID list
 | 
					 | 
				
			||||||
            if (memcmp(magicNumber, zip, 2) == 0)
 | 
					 | 
				
			||||||
                i = 0;
 | 
					 | 
				
			||||||
            else if (memcmp(magicNumber, sevenz, 6) == 0)
 | 
					 | 
				
			||||||
                i = 2;
 | 
					 | 
				
			||||||
            else if (memcmp(magicNumber, arj, 2) == 0)
 | 
					 | 
				
			||||||
                i = 3;
 | 
					 | 
				
			||||||
            else {
 | 
					 | 
				
			||||||
                filex.seek(257);
 | 
					 | 
				
			||||||
                magicNumber = filex.read(8);
 | 
					 | 
				
			||||||
                if (memcmp(magicNumber, tar, 5) == 0)
 | 
					 | 
				
			||||||
                    i = 1;
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            if (i == -1) // fallback code
 | 
					 | 
				
			||||||
            {
 | 
					 | 
				
			||||||
                QFileInfo fileinfo(filePath);
 | 
					 | 
				
			||||||
                if (fileinfo.suffix() == "zip" || fileinfo.suffix() == "cbz") {
 | 
					 | 
				
			||||||
                    i = 0;
 | 
					 | 
				
			||||||
                } else {
 | 
					 | 
				
			||||||
                    return;
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
        if (memcmp(magicNumber, rar, 6) == 0)
 | 
					        if (memcmp(magicNumber, rar, 6) == 0)
 | 
				
			||||||
            if (memcmp(magicNumber, rar5, 7) == 0)
 | 
					            if (memcmp(magicNumber, rar5, 7) == 0)
 | 
				
			||||||
                i = 5;
 | 
					                i = 5;
 | 
				
			||||||
@ -185,314 +138,188 @@ CompressedArchive::CompressedArchive(const QString &filePath, QObject *parent)
 | 
				
			|||||||
                return;
 | 
					                return;
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef UNICODE
 | 
					#ifdef USE_UNICODE_FSTRING
 | 
				
			||||||
            if (!fileSpec->Open((LPCTSTR)filePath.toStdWString().c_str()))
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
        if (!fileSpec->Open((LPCTSTR)filePath.toStdString().c_str()))
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
            {
 | 
					 | 
				
			||||||
                qDebug() << "unable to load" + filePath;
 | 
					 | 
				
			||||||
                return;
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            // GUID uuid = supportedFileFormats[i];
 | 
					 | 
				
			||||||
            // qDebug() << "trying : " << uuid << endl;
 | 
					 | 
				
			||||||
            if (szInterface->createObjectFunc(&supportedFileFormats[i], &IID_InArchive, (void **)&szInterface->archive) == S_OK) {
 | 
					 | 
				
			||||||
                // qDebug() << "Can not open archive file : " + filePath << Qt::endl;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
                if (szInterface->archive->Open(file, 0, openCallback) == S_OK) {
 | 
					 | 
				
			||||||
                    valid = formatFound = true;
 | 
					 | 
				
			||||||
                    qDebug() << "Opened archive file : " + filePath << Qt::endl;
 | 
					 | 
				
			||||||
                    setupFilesNames();
 | 
					 | 
				
			||||||
                    return;
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef Q_OS_WIN
 | 
					 | 
				
			||||||
            if (!formatFound) {
 | 
					 | 
				
			||||||
                qDebug() << "Can not open archive" << Qt::endl;
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
    } else {
 | 
					 | 
				
			||||||
        // RAR in macos and unix
 | 
					 | 
				
			||||||
        GUID clsidRar;
 | 
					 | 
				
			||||||
        if (memcmp(magicNumber, rar5, 7) == 0) {
 | 
					 | 
				
			||||||
            clsidRar = CLSID_CFormatRar5;
 | 
					 | 
				
			||||||
        } else {
 | 
					 | 
				
			||||||
            clsidRar = CLSID_CFormatRar;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        isRar = true; // tell the destructor we *tried* to open a rar file!
 | 
					 | 
				
			||||||
        if (szInterface->createObjectFunc(&clsidRar, &IID_InArchive, (void **)&szInterface->archive) != S_OK) {
 | 
					 | 
				
			||||||
            qDebug() << "Error creating rar archive :" + filePath;
 | 
					 | 
				
			||||||
            return;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        CMyComPtr<ISetCompressCodecsInfo> codecsInfo;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if (szInterface->archive->QueryInterface(IID_ISetCompressCodecsInfoX, (void **)&codecsInfo) != S_OK) {
 | 
					 | 
				
			||||||
            qDebug() << "Error getting rar codec :" + filePath;
 | 
					 | 
				
			||||||
            return;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (codecsInfo->SetCompressCodecsInfo(this) != S_OK) {
 | 
					 | 
				
			||||||
            qDebug() << "Error setting rar codec";
 | 
					 | 
				
			||||||
            return;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef UNICODE
 | 
					 | 
				
			||||||
        if (!fileSpec->Open((LPCTSTR)filePath.toStdWString().c_str()))
 | 
					        if (!fileSpec->Open((LPCTSTR)filePath.toStdWString().c_str()))
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
        if (!fileSpec->Open((LPCTSTR)filePath.toStdString().c_str()))
 | 
					        if (!fileSpec->Open((LPCTSTR)filePath.toStdString().c_str()))
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
            qDebug() << "Error opening rar file :" + filePath;
 | 
					            qDebug() << "unable to load" + filePath;
 | 
				
			||||||
            return;
 | 
					            return;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        // qDebug() << "Can not open archive file : " + filePath << Qt::endl;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if (szInterface->archive->Open(file, 0, openCallback) == S_OK) {
 | 
					        // GUID uuid = supportedFileFormats[i];
 | 
				
			||||||
            valid = formatFound = true;
 | 
					        // qDebug() << "trying : " << uuid << endl;
 | 
				
			||||||
            setupFilesNames();
 | 
					        if (szInterface->createObjectFunc(&supportedFileFormats[i], &IID_InArchive, (void **)&szInterface->archive) == S_OK) {
 | 
				
			||||||
            // isRar = true;
 | 
					            // qDebug() << "Can not open archive file : " + filePath << Qt::endl;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            if (szInterface->archive->Open(file, 0, openCallback) == S_OK) {
 | 
				
			||||||
 | 
					                valid = formatFound = true;
 | 
				
			||||||
 | 
					                qDebug() << "Opened archive file : " + filePath << Qt::endl;
 | 
				
			||||||
 | 
					                setupFilesNames();
 | 
				
			||||||
 | 
					                return;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (!formatFound) {
 | 
				
			||||||
 | 
					            qDebug() << "Can not open archive" << Qt::endl;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    CompressedArchive::~CompressedArchive()
 | 
					CompressedArchive::~CompressedArchive()
 | 
				
			||||||
    {
 | 
					{
 | 
				
			||||||
        // always close the archive!
 | 
					    // always close the archive!
 | 
				
			||||||
        if (szInterface->archive) {
 | 
					    if (szInterface->archive) {
 | 
				
			||||||
            szInterface->archive->Close();
 | 
					        szInterface->archive->Close();
 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef Q_OS_UNIX
 | 
					 | 
				
			||||||
        if (isRar) // TODO: Memory leak!!!! If AddRef is not used, a crash occurs in "delete szInterface"
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
            szInterface->archive->AddRef();
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
        delete szInterface;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef Q_OS_UNIX
 | 
					 | 
				
			||||||
        delete rarLib;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
        delete sevenzLib;
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    bool CompressedArchive::loadFunctions()
 | 
					    delete szInterface;
 | 
				
			||||||
    {
 | 
					    delete sevenzLib;
 | 
				
			||||||
        // LOAD library
 | 
					}
 | 
				
			||||||
        // TODO check if this works in OSX (7z.so instead of 7z.dylib)
 | 
					
 | 
				
			||||||
        //  fix1: try to load "7z.so"
 | 
					bool CompressedArchive::loadFunctions()
 | 
				
			||||||
        //  fix2: rename 7z.so to 7z.dylib
 | 
					{
 | 
				
			||||||
        if (sevenzLib == 0) {
 | 
					    // LOAD library
 | 
				
			||||||
#if defined Q_OS_UNIX
 | 
					    if (sevenzLib == 0) {
 | 
				
			||||||
#if defined Q_OS_MACOS
 | 
					 | 
				
			||||||
            rarLib = new QLibrary(QCoreApplication::applicationDirPath() + "/utils/Codecs/Rar");
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
            // check if a yacreader specific version of p7zip exists on the system
 | 
					 | 
				
			||||||
            QFileInfo rarCodec(QString(LIBDIR) + "/yacreader/Codecs/Rar.so");
 | 
					 | 
				
			||||||
            if (rarCodec.exists()) {
 | 
					 | 
				
			||||||
                rarLib = new QLibrary(rarCodec.absoluteFilePath());
 | 
					 | 
				
			||||||
            } else {
 | 
					 | 
				
			||||||
                rarLib = new QLibrary(QString(LIBDIR) + "/p7zip/Codecs/Rar.so");
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
            if (!rarLib->load()) {
 | 
					 | 
				
			||||||
                qDebug() << "Error Loading Rar.so : " + rarLib->errorString() << Qt::endl;
 | 
					 | 
				
			||||||
                QCoreApplication::exit(700); // TODO yacreader_global can't be used here, it is GUI dependant, YACReader::SevenZNotFound
 | 
					 | 
				
			||||||
                return false;
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#if defined Q_OS_UNIX && !defined Q_OS_MACOS
 | 
					 | 
				
			||||||
            QFileInfo sevenzlibrary(QString(LIBDIR) + "/yacreader/7z.so");
 | 
					 | 
				
			||||||
            if (sevenzlibrary.exists()) {
 | 
					 | 
				
			||||||
                sevenzLib = new QLibrary(sevenzlibrary.absoluteFilePath());
 | 
					 | 
				
			||||||
            } else {
 | 
					 | 
				
			||||||
                sevenzLib = new QLibrary(QString(LIBDIR) + "/p7zip/7z.so");
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
        sevenzLib = new QLibrary(QCoreApplication::applicationDirPath() + "/utils/7z");
 | 
					        sevenzLib = new QLibrary(QCoreApplication::applicationDirPath() + "/utils/7z");
 | 
				
			||||||
#endif
 | 
					    }
 | 
				
			||||||
        }
 | 
					    if (!sevenzLib->load()) {
 | 
				
			||||||
        if (!sevenzLib->load()) {
 | 
					        qDebug() << "Error Loading 7z.dll : " + sevenzLib->errorString() << Qt::endl;
 | 
				
			||||||
            qDebug() << "Error Loading 7z.dll : " + sevenzLib->errorString() << Qt::endl;
 | 
					        QCoreApplication::exit(700); // TODO yacreader_global can't be used here, it is GUI dependant, YACReader::SevenZNotFound
 | 
				
			||||||
            QCoreApplication::exit(700); // TODO yacreader_global can't be used here, it is GUI dependant, YACReader::SevenZNotFound
 | 
					        return false;
 | 
				
			||||||
            return false;
 | 
					    } else {
 | 
				
			||||||
        } else {
 | 
					        qDebug() << "Loading functions" << Qt::endl;
 | 
				
			||||||
            qDebug() << "Loading functions" << Qt::endl;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
            if ((szInterface->createObjectFunc = (CreateObjectFunc)sevenzLib->resolve("CreateObject")) == 0)
 | 
					        if ((szInterface->createObjectFunc = (CreateObjectFunc)sevenzLib->resolve("CreateObject")) == 0)
 | 
				
			||||||
                qDebug() << "fail loading function : CreateObject" << Qt::endl;
 | 
					            qDebug() << "fail loading function : CreateObject" << Qt::endl;
 | 
				
			||||||
            if ((szInterface->getMethodPropertyFunc = (GetMethodPropertyFunc)sevenzLib->resolve("GetMethodProperty")) == 0)
 | 
					        if ((szInterface->getMethodPropertyFunc = (GetMethodPropertyFunc)sevenzLib->resolve("GetMethodProperty")) == 0)
 | 
				
			||||||
                qDebug() << "fail loading function : GetMethodProperty" << Qt::endl;
 | 
					            qDebug() << "fail loading function : GetMethodProperty" << Qt::endl;
 | 
				
			||||||
            if ((szInterface->getNumberOfMethodsFunc = (GetNumberOfMethodsFunc)sevenzLib->resolve("GetNumberOfMethods")) == 0)
 | 
					        if ((szInterface->getNumberOfMethodsFunc = (GetNumberOfMethodsFunc)sevenzLib->resolve("GetNumberOfMethods")) == 0)
 | 
				
			||||||
                qDebug() << "fail loading function : GetNumberOfMethods" << Qt::endl;
 | 
					            qDebug() << "fail loading function : GetNumberOfMethods" << Qt::endl;
 | 
				
			||||||
            if ((szInterface->getNumberOfFormatsFunc = (GetNumberOfFormatsFunc)sevenzLib->resolve("GetNumberOfFormats")) == 0)
 | 
					        if ((szInterface->getNumberOfFormatsFunc = (GetNumberOfFormatsFunc)sevenzLib->resolve("GetNumberOfFormats")) == 0)
 | 
				
			||||||
                qDebug() << "fail loading function : GetNumberOfFormats" << Qt::endl;
 | 
					            qDebug() << "fail loading function : GetNumberOfFormats" << Qt::endl;
 | 
				
			||||||
            if ((szInterface->getHandlerPropertyFunc = (GetHandlerPropertyFunc)sevenzLib->resolve("GetHandlerProperty")) == 0)
 | 
					        if ((szInterface->getHandlerPropertyFunc = (GetHandlerPropertyFunc)sevenzLib->resolve("GetHandlerProperty")) == 0)
 | 
				
			||||||
                qDebug() << "fail loading function : GetHandlerProperty" << Qt::endl;
 | 
					            qDebug() << "fail loading function : GetHandlerProperty" << Qt::endl;
 | 
				
			||||||
            if ((szInterface->getHandlerPropertyFunc2 = (GetHandlerPropertyFunc2)sevenzLib->resolve("GetHandlerProperty2")) == 0)
 | 
					        if ((szInterface->getHandlerPropertyFunc2 = (GetHandlerPropertyFunc2)sevenzLib->resolve("GetHandlerProperty2")) == 0)
 | 
				
			||||||
                qDebug() << "fail loading function : GetHandlerProperty2" << Qt::endl;
 | 
					            qDebug() << "fail loading function : GetHandlerProperty2" << Qt::endl;
 | 
				
			||||||
            if ((szInterface->setLargePageModeFunc = (SetLargePageModeFunc)sevenzLib->resolve("SetLargePageMode")) == 0)
 | 
					        if ((szInterface->setLargePageModeFunc = (SetLargePageModeFunc)sevenzLib->resolve("SetLargePageMode")) == 0)
 | 
				
			||||||
                qDebug() << "fail loading function : SetLargePageMode" << Qt::endl;
 | 
					            qDebug() << "fail loading function : SetLargePageMode" << Qt::endl;
 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef Q_OS_UNIX
 | 
					 | 
				
			||||||
            if ((szInterface->createObjectFuncRar = (CreateObjectFunc)rarLib->resolve("CreateObject")) == 0)
 | 
					 | 
				
			||||||
                qDebug() << "fail loading function (rar) : CreateObject" << Qt::endl;
 | 
					 | 
				
			||||||
            if ((szInterface->getMethodPropertyFuncRar = (GetMethodPropertyFunc)rarLib->resolve("GetMethodProperty")) == 0)
 | 
					 | 
				
			||||||
                qDebug() << "fail loading function (rar) : GetMethodProperty" << Qt::endl;
 | 
					 | 
				
			||||||
            if ((szInterface->getNumberOfMethodsFuncRar = (GetNumberOfMethodsFunc)rarLib->resolve("GetNumberOfMethods")) == 0)
 | 
					 | 
				
			||||||
                qDebug() << "fail loading function (rar) : GetNumberOfMethods" << Qt::endl;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        return true;
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    void CompressedArchive::setupFilesNames()
 | 
					    return true;
 | 
				
			||||||
    {
 | 
					}
 | 
				
			||||||
        quint32 numItems = getNumEntries();
 | 
					 | 
				
			||||||
        quint32 p = 0;
 | 
					 | 
				
			||||||
        for (quint32 i = 0; i < numItems; i++) {
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
            // Get name of file
 | 
					void CompressedArchive::setupFilesNames()
 | 
				
			||||||
            NWindows::NCOM::CPropVariant prop;
 | 
					{
 | 
				
			||||||
            szInterface->archive->GetProperty(i, kpidIsDir, &prop);
 | 
					    quint32 numItems = getNumEntries();
 | 
				
			||||||
            bool isDir;
 | 
					    quint32 p = 0;
 | 
				
			||||||
            if (prop.vt == VT_BOOL)
 | 
					    for (quint32 i = 0; i < numItems; i++) {
 | 
				
			||||||
                isDir = VARIANT_BOOLToBool(prop.boolVal);
 | 
					 | 
				
			||||||
            else if (prop.vt == VT_EMPTY)
 | 
					 | 
				
			||||||
                isDir = false;
 | 
					 | 
				
			||||||
            else
 | 
					 | 
				
			||||||
                continue;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
            if (!isDir) {
 | 
					        // Get name of file
 | 
				
			||||||
                szInterface->archive->GetProperty(i, kpidPath, &prop);
 | 
					        NWindows::NCOM::CPropVariant prop;
 | 
				
			||||||
                UString s = prop.bstrVal;
 | 
					        szInterface->archive->GetProperty(i, kpidIsDir, &prop);
 | 
				
			||||||
                const wchar_t *chars = s.operator const wchar_t *();
 | 
					        bool isDir;
 | 
				
			||||||
                files.append(QString::fromWCharArray(chars));
 | 
					        if (prop.vt == VT_BOOL)
 | 
				
			||||||
                offsets.append(i);
 | 
					            isDir = VARIANT_BOOLToBool(prop.boolVal);
 | 
				
			||||||
                indexesToPages.insert(i, p);
 | 
					        else if (prop.vt == VT_EMPTY)
 | 
				
			||||||
                p++;
 | 
					            isDir = false;
 | 
				
			||||||
            }
 | 
					        else
 | 
				
			||||||
 | 
					            continue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (!isDir) {
 | 
				
			||||||
 | 
					            szInterface->archive->GetProperty(i, kpidPath, &prop);
 | 
				
			||||||
 | 
					            UString s = prop.bstrVal;
 | 
				
			||||||
 | 
					            const wchar_t *chars = s.operator const wchar_t *();
 | 
				
			||||||
 | 
					            files.append(QString::fromWCharArray(chars));
 | 
				
			||||||
 | 
					            offsets.append(i);
 | 
				
			||||||
 | 
					            indexesToPages.insert(i, p);
 | 
				
			||||||
 | 
					            p++;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    QVector<quint32> CompressedArchive::translateIndexes(const QVector<quint32> &indexes)
 | 
					QVector<quint32> CompressedArchive::translateIndexes(const QVector<quint32> &indexes)
 | 
				
			||||||
    {
 | 
					{
 | 
				
			||||||
        QVector<quint32> translatedIndexes;
 | 
					    QVector<quint32> translatedIndexes;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        foreach (quint32 i, indexes) {
 | 
					    foreach (quint32 i, indexes) {
 | 
				
			||||||
            if (i < (quint32)offsets.length())
 | 
					        if (i < (quint32)offsets.length())
 | 
				
			||||||
                translatedIndexes.append(offsets.at(i));
 | 
					            translatedIndexes.append(offsets.at(i));
 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        return translatedIndexes;
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    QList<QString> CompressedArchive::getFileNames()
 | 
					    return translatedIndexes;
 | 
				
			||||||
    {
 | 
					}
 | 
				
			||||||
        return files;
 | 
					
 | 
				
			||||||
 | 
					QList<QString> CompressedArchive::getFileNames()
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return files;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					bool CompressedArchive::isValid()
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return valid;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					bool CompressedArchive::toolsLoaded()
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return tools;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int CompressedArchive::getNumFiles()
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return files.length();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int CompressedArchive::getNumEntries()
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    quint32 numItems = 0;
 | 
				
			||||||
 | 
					    szInterface->archive->GetNumberOfItems(&numItems);
 | 
				
			||||||
 | 
					    return numItems;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					QList<QByteArray> CompressedArchive::getAllData(const QVector<quint32> &indexes, ExtractDelegate *delegate)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    YCArchiveExtractCallback *extractCallbackSpec = new YCArchiveExtractCallback(indexesToPages, true, delegate);
 | 
				
			||||||
 | 
					    CMyComPtr<IArchiveExtractCallback> extractCallback(extractCallbackSpec);
 | 
				
			||||||
 | 
					    extractCallbackSpec->Init(szInterface->archive, L""); // second parameter is output folder path
 | 
				
			||||||
 | 
					    extractCallbackSpec->PasswordIsDefined = false;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    QVector<quint32> currentIndexes = translateIndexes(indexes);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    HRESULT result;
 | 
				
			||||||
 | 
					    if (indexes.isEmpty())
 | 
				
			||||||
 | 
					        result = szInterface->archive->Extract(NULL, -1, false, extractCallback);
 | 
				
			||||||
 | 
					    else
 | 
				
			||||||
 | 
					        result = szInterface->archive->Extract(currentIndexes.data(), currentIndexes.count(), false, extractCallback);
 | 
				
			||||||
 | 
					    if (result != S_OK) {
 | 
				
			||||||
 | 
					        qDebug() << "Extract Error" << Qt::endl;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    bool CompressedArchive::isValid()
 | 
					    return extractCallbackSpec->allFiles;
 | 
				
			||||||
    {
 | 
					}
 | 
				
			||||||
        return valid;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    bool CompressedArchive::toolsLoaded()
 | 
					QByteArray CompressedArchive::getRawDataAtIndex(int index)
 | 
				
			||||||
    {
 | 
					{
 | 
				
			||||||
        return tools;
 | 
					    if (index >= 0 && index < getNumFiles()) {
 | 
				
			||||||
    }
 | 
					        YCArchiveExtractCallback *extractCallbackSpec = new YCArchiveExtractCallback(indexesToPages);
 | 
				
			||||||
 | 
					 | 
				
			||||||
    int CompressedArchive::getNumFiles()
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        return files.length();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    int CompressedArchive::getNumEntries()
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        quint32 numItems = 0;
 | 
					 | 
				
			||||||
        szInterface->archive->GetNumberOfItems(&numItems);
 | 
					 | 
				
			||||||
        return numItems;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    QList<QByteArray> CompressedArchive::getAllData(const QVector<quint32> &indexes, ExtractDelegate *delegate)
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        YCArchiveExtractCallback *extractCallbackSpec = new YCArchiveExtractCallback(indexesToPages, true, delegate);
 | 
					 | 
				
			||||||
        CMyComPtr<IArchiveExtractCallback> extractCallback(extractCallbackSpec);
 | 
					        CMyComPtr<IArchiveExtractCallback> extractCallback(extractCallbackSpec);
 | 
				
			||||||
        extractCallbackSpec->Init(szInterface->archive, L""); // second parameter is output folder path
 | 
					        extractCallbackSpec->Init(szInterface->archive, L""); // second parameter is output folder path
 | 
				
			||||||
        extractCallbackSpec->PasswordIsDefined = false;
 | 
					        extractCallbackSpec->PasswordIsDefined = false;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        QVector<quint32> currentIndexes = translateIndexes(indexes);
 | 
					        UInt32 indices[1];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        HRESULT result;
 | 
					        if (index < offsets.length())
 | 
				
			||||||
        if (indexes.isEmpty())
 | 
					            indices[0] = offsets.at(index);
 | 
				
			||||||
            result = szInterface->archive->Extract(NULL, -1, false, extractCallback);
 | 
					 | 
				
			||||||
        else
 | 
					        else
 | 
				
			||||||
            result = szInterface->archive->Extract(currentIndexes.data(), currentIndexes.count(), false, extractCallback);
 | 
					            indices[0] = index;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        HRESULT result = szInterface->archive->Extract(indices, 1, false, extractCallback);
 | 
				
			||||||
        if (result != S_OK) {
 | 
					        if (result != S_OK) {
 | 
				
			||||||
            qDebug() << "Extract Error" << Qt::endl;
 | 
					            qDebug() << "Extract Error" << Qt::endl;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        return extractCallbackSpec->allFiles;
 | 
					        return QByteArray((char *)extractCallbackSpec->data, extractCallbackSpec->newFileSize);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					    return QByteArray();
 | 
				
			||||||
    QByteArray CompressedArchive::getRawDataAtIndex(int index)
 | 
					}
 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        if (index >= 0 && index < getNumFiles()) {
 | 
					 | 
				
			||||||
            YCArchiveExtractCallback *extractCallbackSpec = new YCArchiveExtractCallback(indexesToPages);
 | 
					 | 
				
			||||||
            CMyComPtr<IArchiveExtractCallback> extractCallback(extractCallbackSpec);
 | 
					 | 
				
			||||||
            extractCallbackSpec->Init(szInterface->archive, L""); // second parameter is output folder path
 | 
					 | 
				
			||||||
            extractCallbackSpec->PasswordIsDefined = false;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            UInt32 indices[1];
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            if (index < offsets.length())
 | 
					 | 
				
			||||||
                indices[0] = offsets.at(index);
 | 
					 | 
				
			||||||
            else
 | 
					 | 
				
			||||||
                indices[0] = index;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            HRESULT result = szInterface->archive->Extract(indices, 1, false, extractCallback);
 | 
					 | 
				
			||||||
            if (result != S_OK) {
 | 
					 | 
				
			||||||
                qDebug() << "Extract Error" << Qt::endl;
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            return QByteArray((char *)extractCallbackSpec->data, extractCallbackSpec->newFileSize);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return QByteArray();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef Q_OS_UNIX
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    STDMETHODIMP CompressedArchive::GetNumMethods(UInt32 * numMethods)
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        return szInterface->getNumberOfMethodsFuncRar(numMethods);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    STDMETHODIMP CompressedArchive::GetProperty(UInt32 index, PROPID propID, PROPVARIANT * value)
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        return szInterface->getMethodPropertyFuncRar(index, propID, value);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    int i = 0;
 | 
					 | 
				
			||||||
    STDMETHODIMP CompressedArchive::CreateDecoder(UInt32 index, const GUID *interfaceID, void **coder)
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        NCOM::CPropVariant propVariant;
 | 
					 | 
				
			||||||
        szInterface->getMethodPropertyFuncRar(index, NMethodPropID::kDecoder, &propVariant);
 | 
					 | 
				
			||||||
        return szInterface->createObjectFuncRar((const GUID *)propVariant.bstrVal, interfaceID, coder);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    STDMETHODIMP CompressedArchive::CreateEncoder(UInt32 index, const GUID *interfaceID, void **coder)
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        return S_OK; // szInterface->createObjectFuncRar(&CLSID_CFormatRar,interfaceID,coder);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
				
			|||||||
@ -3,11 +3,6 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#include <QObject>
 | 
					#include <QObject>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef Q_OS_UNIX
 | 
					 | 
				
			||||||
#include "libp7zip/CPP/7zip/ICoder.h"
 | 
					 | 
				
			||||||
#include "libp7zip/CPP/Common/MyCom.h"
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
class ExtractDelegate;
 | 
					class ExtractDelegate;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class QLibrary;
 | 
					class QLibrary;
 | 
				
			||||||
@ -19,32 +14,13 @@ struct SevenZipInterface;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
class MyCodecs;
 | 
					class MyCodecs;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef Q_OS_UNIX
 | 
					 | 
				
			||||||
class CompressedArchive : public QObject, public ICompressCodecsInfo, public CMyUnknownImp
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
class CompressedArchive : public QObject
 | 
					class CompressedArchive : public QObject
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    Q_OBJECT
 | 
					    Q_OBJECT
 | 
				
			||||||
public:
 | 
					public:
 | 
				
			||||||
    explicit CompressedArchive(const QString &filePath, QObject *parent = 0);
 | 
					    explicit CompressedArchive(const QString &filePath, QObject *parent = 0);
 | 
				
			||||||
    ~CompressedArchive();
 | 
					    ~CompressedArchive();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef Q_OS_UNIX
 | 
					 | 
				
			||||||
    MY_UNKNOWN_IMP
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    STDMETHOD(GetNumMethods)
 | 
					 | 
				
			||||||
    (UInt32 *numMethods);
 | 
					 | 
				
			||||||
    STDMETHOD(GetProperty)
 | 
					 | 
				
			||||||
    (UInt32 index, PROPID propID, PROPVARIANT *value);
 | 
					 | 
				
			||||||
    STDMETHOD(CreateDecoder)
 | 
					 | 
				
			||||||
    (UInt32 index, const GUID *iid, void **coder);
 | 
					 | 
				
			||||||
    STDMETHOD(CreateEncoder)
 | 
					 | 
				
			||||||
    (UInt32 index, const GUID *iid, void **coder);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    bool isRar;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
signals:
 | 
					signals:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public slots:
 | 
					public slots:
 | 
				
			||||||
@ -60,9 +36,6 @@ private:
 | 
				
			|||||||
    SevenZipInterface *szInterface;
 | 
					    SevenZipInterface *szInterface;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    QLibrary *sevenzLib;
 | 
					    QLibrary *sevenzLib;
 | 
				
			||||||
#ifdef Q_OS_UNIX
 | 
					 | 
				
			||||||
    QLibrary *rarLib;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
    bool loadFunctions();
 | 
					    bool loadFunctions();
 | 
				
			||||||
    bool tools;
 | 
					    bool tools;
 | 
				
			||||||
    bool valid;
 | 
					    bool valid;
 | 
				
			||||||
 | 
				
			|||||||
@ -1,48 +1,39 @@
 | 
				
			|||||||
INCLUDEPATH += $$PWD
 | 
					INCLUDEPATH += $$PWD
 | 
				
			||||||
DEPENDPATH += $$PWD
 | 
					DEPENDPATH += $$PWD
 | 
				
			||||||
 | 
					
 | 
				
			||||||
win32 {
 | 
					 | 
				
			||||||
exists (../compressed_archive/lib7zip) {
 | 
					exists (../compressed_archive/lib7zip) {
 | 
				
			||||||
    message(Using 7zip)
 | 
					    message(Using 7zip)
 | 
				
			||||||
} else {
 | 
					} else {
 | 
				
			||||||
    error(You\'ll need 7zip source code to compile YACReader. \
 | 
					    error(You\'ll need 7zip source code to compile YACReader. \
 | 
				
			||||||
          Please check the compressed_archive folder for further instructions.)
 | 
					          Please check the compressed_archive folder for further instructions.)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
unix {
 | 
					 | 
				
			||||||
exists (../compressed_archive/libp7zip) {
 | 
					 | 
				
			||||||
    message(Found p7zip source code...)
 | 
					 | 
				
			||||||
    #this is probably only needed in macos
 | 
					 | 
				
			||||||
    system(patch -N -p0 -i libp7zip.patch)
 | 
					 | 
				
			||||||
} else {
 | 
					 | 
				
			||||||
    error(You\'ll need 7zip source code to compile YACReader. \
 | 
					 | 
				
			||||||
          Please check the compressed_archive folder for further instructions.)
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
win32 {
 | 
					 | 
				
			||||||
INCLUDEPATH += \
 | 
					INCLUDEPATH += \
 | 
				
			||||||
    $$PWD/lib7zip/myWindows \
 | 
					 | 
				
			||||||
    $$PWD/lib7zip/CPP \
 | 
					    $$PWD/lib7zip/CPP \
 | 
				
			||||||
    $$PWD/lib7zip/include_windows \
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
DEFINES += _UNICODE _WIN32
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
SOURCES += \
 | 
					SOURCES += \
 | 
				
			||||||
    $$PWD/compressed_archive.cpp \
 | 
					    $$PWD/compressed_archive.cpp \
 | 
				
			||||||
    $$PWD/lib7zip/CPP/Windows/FileIO.cpp \
 | 
					 | 
				
			||||||
    $$PWD/lib7zip/CPP/Windows/PropVariant.cpp \
 | 
					 | 
				
			||||||
    $$PWD/lib7zip/CPP/Windows/PropVariantConv.cpp \
 | 
					 | 
				
			||||||
    $$PWD/lib7zip/CPP/Common/IntToString.cpp \
 | 
					    $$PWD/lib7zip/CPP/Common/IntToString.cpp \
 | 
				
			||||||
 | 
					    $$PWD/lib7zip/CPP/Common/NewHandler.cpp \
 | 
				
			||||||
    $$PWD/lib7zip/CPP/Common/MyString.cpp \
 | 
					    $$PWD/lib7zip/CPP/Common/MyString.cpp \
 | 
				
			||||||
    $$PWD/lib7zip/CPP/Common/MyVector.cpp \
 | 
					    $$PWD/lib7zip/CPP/Common/MyVector.cpp \
 | 
				
			||||||
    $$PWD/lib7zip/CPP/Common/StringConvert.cpp \
 | 
					    $$PWD/lib7zip/CPP/Common/StringConvert.cpp \
 | 
				
			||||||
 | 
					    $$PWD/lib7zip/CPP/Common/StringToInt.cpp \
 | 
				
			||||||
    $$PWD/lib7zip/CPP/Common/Wildcard.cpp \
 | 
					    $$PWD/lib7zip/CPP/Common/Wildcard.cpp \
 | 
				
			||||||
 | 
					    $$PWD/lib7zip/CPP/Windows/DLL.cpp \
 | 
				
			||||||
 | 
					    $$PWD/lib7zip/CPP/Windows/FileDir.cpp \
 | 
				
			||||||
 | 
					    $$PWD/lib7zip/CPP/Windows/FileFind.cpp \
 | 
				
			||||||
 | 
					    $$PWD/lib7zip/CPP/Windows/FileIO.cpp \
 | 
				
			||||||
 | 
					    $$PWD/lib7zip/CPP/Windows/FileName.cpp \
 | 
				
			||||||
 | 
					    $$PWD/lib7zip/CPP/Windows/PropVariant.cpp \
 | 
				
			||||||
 | 
					    $$PWD/lib7zip/CPP/Windows/PropVariantConv.cpp \
 | 
				
			||||||
    $$PWD/lib7zip/CPP/7zip/Common/FileStreams.cpp \
 | 
					    $$PWD/lib7zip/CPP/7zip/Common/FileStreams.cpp \
 | 
				
			||||||
 | 
					    $$PWD/lib7zip/CPP/7zip/Common/StreamObjects.cpp \
 | 
				
			||||||
    $$PWD/lib7zip/CPP/7zip/Common/StreamUtils.cpp \
 | 
					    $$PWD/lib7zip/CPP/7zip/Common/StreamUtils.cpp \
 | 
				
			||||||
    $$PWD/lib7zip/C/Alloc.c \
 | 
					    $$PWD/lib7zip/C/Alloc.c \
 | 
				
			||||||
    $$PWD/lib7zip/CPP/7zip/Common/StreamObjects.cpp
 | 
					    $$PWD/lib7zip/CPP/Windows/TimeUtils.cpp \
 | 
				
			||||||
 | 
					    $$PWD/lib7zip/CPP/Common/UTFConvert.cpp \
 | 
				
			||||||
 | 
					    $$PWD/lib7zip/CPP/Common/MyWindows.cpp \
 | 
				
			||||||
 | 
					
 | 
				
			||||||
HEADERS += \
 | 
					HEADERS += \
 | 
				
			||||||
    $$PWD/lib7zip/CPP/Common/Common.h \
 | 
					    $$PWD/lib7zip/CPP/Common/Common.h \
 | 
				
			||||||
@ -50,13 +41,7 @@ HEADERS += \
 | 
				
			|||||||
    $$PWD/extract_delegate.h \
 | 
					    $$PWD/extract_delegate.h \
 | 
				
			||||||
    $$PWD/7z_includes.h \
 | 
					    $$PWD/7z_includes.h \
 | 
				
			||||||
    $$PWD/open_callbacks.h \
 | 
					    $$PWD/open_callbacks.h \
 | 
				
			||||||
    $$PWD/extract_callbacks.h
 | 
					    $$PWD/extract_callbacks.h \
 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
!win32 {
 | 
					 | 
				
			||||||
CONFIG   += precompile_header
 | 
					 | 
				
			||||||
PRECOMPILED_HEADER = $$PWD/7z_precompiled_header.h
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
macx{
 | 
					macx{
 | 
				
			||||||
LIBS += -framework IOKit -framework CoreFoundation
 | 
					LIBS += -framework IOKit -framework CoreFoundation
 | 
				
			||||||
@ -73,31 +58,3 @@ DEFINES += _FILE_OFFSET_BITS=64 _LARGEFILE_SOURCE \
 | 
				
			|||||||
    _7ZIP_LARGE_PAGES \
 | 
					    _7ZIP_LARGE_PAGES \
 | 
				
			||||||
    UNICODE _UNICODE UNIX_USE_WIN_FILE
 | 
					    UNICODE _UNICODE UNIX_USE_WIN_FILE
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					 | 
				
			||||||
!win32 {
 | 
					 | 
				
			||||||
INCLUDEPATH  += $$PWD/libp7zip/CPP/myWindows/ \
 | 
					 | 
				
			||||||
                $$PWD/libp7zip/CPP/ \
 | 
					 | 
				
			||||||
                $$PWD/libp7zip/CPP/include_windows/
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
SOURCES += \
 | 
					 | 
				
			||||||
    $$PWD/compressed_archive.cpp \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/CPP/Windows/PropVariant.cpp \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/CPP/Windows/PropVariantConv.cpp \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/CPP/Windows/FileIO.cpp \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/CPP/Windows/FileFind.cpp \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/CPP/Common/IntToString.cpp \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/CPP/Common/MyString.cpp \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/CPP/Common/MyVector.cpp \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/CPP/Common/StringConvert.cpp \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/CPP/Common/Wildcard.cpp \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/CPP/7zip/Common/FileStreams.cpp \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/CPP/7zip/Common/StreamUtils.cpp \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/C/Alloc.c \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/CPP/7zip/Common/StreamObjects.cpp \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/CPP/myWindows/wine_date_and_time.cpp \
 | 
					 | 
				
			||||||
    $$PWD/libp7zip/CPP/Common/MyWindows.cpp
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
HEADERS += \
 | 
					 | 
				
			||||||
    $$PWD/compressed_archive.h \
 | 
					 | 
				
			||||||
    $$PWD/7z_includes.h
 | 
					 | 
				
			||||||
}	
 | 
					 | 
				
			||||||
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user