From 4d8f068f9cc576c7d1fb19551cb2429282a7c449 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Petr=20Mr=C3=A1zek?= Date: Sun, 12 Apr 2015 22:50:52 +0200 Subject: NOISSUE refactor and rearrange zip file utils --- logic/MMCZip.h | 57 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 57 insertions(+) create mode 100644 logic/MMCZip.h (limited to 'logic/MMCZip.h') diff --git a/logic/MMCZip.h b/logic/MMCZip.h new file mode 100644 index 00000000..e1f2ba3a --- /dev/null +++ b/logic/MMCZip.h @@ -0,0 +1,57 @@ +#pragma once + +#include +#include +#include +#include "minecraft/Mod.h" +#include + +class QuaZip; + +namespace MMCZip +{ + /** + * Compress a subdirectory. + * \param parentZip Opened zip containing the parent directory. + * \param dir The full path to the directory to pack. + * \param parentDir The full path to the directory corresponding to the root of the ZIP. + * \param recursive Whether to pack sub-directories as well or only files. + * \return true if success, false otherwise. + */ + bool compressSubDir(QuaZip* zip, QString dir, QString origDir, QSet& added, QString prefix = QString()); + + /** + * Compress a whole directory. + * \param fileCompressed The name of the archive. + * \param dir The directory to compress. + * \param recursive Whether to pack the subdirectories as well, or just regular files. + * \return true if success, false otherwise. + */ + bool compressDir(QString zipFile, QString dir, QString prefix = QString()); + + /// filter function for @mergeZipFiles - passthrough + bool noFilter(QString key); + + /// filter function for @mergeZipFiles - ignores METAINF + bool metaInfFilter(QString key); + + /** + * Merge two zip files, using a filter function + */ + bool mergeZipFiles(QuaZip *into, QFileInfo from, QSet &contained, std::function filter); + + /** + * take a source jar, add mods to it, resulting in target jar + */ + bool createModdedJar(QString sourceJarPath, QString targetJarPath, const QList& mods); + + /** + * Extract a whole archive. + * + * \param fileCompressed The name of the archive. + * \param dir The directory to extract to, the current directory if + * left empty. + * \return The list of the full paths of the files extracted, empty on failure. + */ + QStringList extractDir(QString fileCompressed, QString dir = QString()); +} \ No newline at end of file -- cgit v1.2.3