update fastfile logic.
This commit is contained in:
parent
5033bdde20
commit
75bbeaa9d1
@ -4,7 +4,6 @@
|
|||||||
#include "fastfile_cod5.h"
|
#include "fastfile_cod5.h"
|
||||||
#include "fastfile_cod7.h"
|
#include "fastfile_cod7.h"
|
||||||
#include "fastfile_cod9.h"
|
#include "fastfile_cod9.h"
|
||||||
#include "compressor.h"
|
|
||||||
#include "logmanager.h"
|
#include "logmanager.h"
|
||||||
|
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
@ -40,6 +39,77 @@ FastFile::~FastFile() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QString FastFile::GetStem() const {
|
||||||
|
return mStem;
|
||||||
|
}
|
||||||
|
|
||||||
|
FF_FILETYPE FastFile::GetType() const {
|
||||||
|
return mType;
|
||||||
|
}
|
||||||
|
|
||||||
|
FF_COMPANY FastFile::GetCompany() const {
|
||||||
|
return mCompany;
|
||||||
|
}
|
||||||
|
|
||||||
|
FF_SIGNAGE FastFile::GetSignage() const {
|
||||||
|
return mSignage;
|
||||||
|
}
|
||||||
|
|
||||||
|
QString FastFile::GetMagic() const {
|
||||||
|
return mMagic;
|
||||||
|
}
|
||||||
|
|
||||||
|
quint32 FastFile::GetVersion() const {
|
||||||
|
return mVersion;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::shared_ptr<ZoneFile> FastFile::GetZoneFile() const {
|
||||||
|
return mZoneFile;
|
||||||
|
}
|
||||||
|
|
||||||
|
QString FastFile::GetGame() const {
|
||||||
|
return mGame;
|
||||||
|
}
|
||||||
|
|
||||||
|
QString FastFile::GetPlatform() const {
|
||||||
|
return mPlatform;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FastFile::SetStem(const QString aStem) {
|
||||||
|
mStem = aStem;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FastFile::SetType(const FF_FILETYPE aType) {
|
||||||
|
mType = aType;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FastFile::SetCompany(const FF_COMPANY aCompany) {
|
||||||
|
mCompany = aCompany;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FastFile::SetSignage(const FF_SIGNAGE aSignage) {
|
||||||
|
mSignage = aSignage;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FastFile::SetMagic(const QString aMagic) {
|
||||||
|
mMagic = aMagic;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FastFile::SetVersion(const quint32 aVersion) {
|
||||||
|
mVersion = aVersion;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FastFile::SetZoneFile(const std::shared_ptr<ZoneFile> aZoneFile) {
|
||||||
|
mZoneFile = aZoneFile;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FastFile::SetGame(const QString aGame) { mGame = aGame;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FastFile::SetPlatform(const QString aPlatform) {
|
||||||
|
mPlatform = aPlatform;
|
||||||
|
}
|
||||||
|
|
||||||
FF_COMPANY FastFile::pParseFFCompany(QDataStream *afastFileStream, quint32 &aCompanyInt) {
|
FF_COMPANY FastFile::pParseFFCompany(QDataStream *afastFileStream, quint32 &aCompanyInt) {
|
||||||
LogManager::instance().addEntry("Parsing company into reference...");
|
LogManager::instance().addEntry("Parsing company into reference...");
|
||||||
// Check for null datastream ptr
|
// Check for null datastream ptr
|
||||||
@ -50,20 +120,15 @@ FF_COMPANY FastFile::pParseFFCompany(QDataStream *afastFileStream, quint32 &aCom
|
|||||||
aCompanyInt = companyData.toUInt();
|
aCompanyInt = companyData.toUInt();
|
||||||
|
|
||||||
if (companyData == "IW") {
|
if (companyData == "IW") {
|
||||||
LogManager::instance().addEntry("Company found: 'INFINITY_WARD'");
|
|
||||||
return COMPANY_INFINITY_WARD;
|
return COMPANY_INFINITY_WARD;
|
||||||
} else if (companyData == "TA") {
|
} else if (companyData == "TA") {
|
||||||
LogManager::instance().addEntry("Company found: 'TREYARCH'");
|
|
||||||
return COMPANY_TREYARCH;
|
return COMPANY_TREYARCH;
|
||||||
} else if (companyData == "Sl") {
|
} else if (companyData == "Sl") {
|
||||||
LogManager::instance().addEntry("Company found: 'SLEDGEHAMMER'");
|
|
||||||
return COMPANY_SLEDGEHAMMER;
|
return COMPANY_SLEDGEHAMMER;
|
||||||
} else if (companyData == "NX") {
|
} else if (companyData == "NX") {
|
||||||
LogManager::instance().addEntry("Company found: 'NEVERSOFT'");
|
|
||||||
return COMPANY_NEVERSOFT;
|
return COMPANY_NEVERSOFT;
|
||||||
} else {
|
|
||||||
LogManager::instance().addEntry(QString("Failed to find company, found '%1'!").arg(companyData));
|
|
||||||
}
|
}
|
||||||
|
LogManager::instance().addEntry(QString("Failed to find company, found '%1'!").arg(companyData));
|
||||||
return COMPANY_NONE;
|
return COMPANY_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -76,20 +141,14 @@ FF_COMPANY FastFile::pParseFFCompany(QDataStream *afastFileStream) {
|
|||||||
afastFileStream->readRawData(companyData.data(), 2);
|
afastFileStream->readRawData(companyData.data(), 2);
|
||||||
|
|
||||||
if (companyData == "IW") {
|
if (companyData == "IW") {
|
||||||
LogManager::instance().addEntry("Company found: 'INFINITY_WARD'");
|
|
||||||
return COMPANY_INFINITY_WARD;
|
return COMPANY_INFINITY_WARD;
|
||||||
} else if (companyData == "TA") {
|
} else if (companyData == "TA") {
|
||||||
LogManager::instance().addEntry("Company found: 'TREYARCH'");
|
|
||||||
return COMPANY_TREYARCH;
|
return COMPANY_TREYARCH;
|
||||||
} else if (companyData == "Sl") {
|
} else if (companyData == "Sl") {
|
||||||
LogManager::instance().addEntry("Company found: 'SLEDGEHAMMER'");
|
|
||||||
return COMPANY_SLEDGEHAMMER;
|
|
||||||
} else if (companyData == "NX") {
|
} else if (companyData == "NX") {
|
||||||
LogManager::instance().addEntry("Company found: 'NEVERSOFT'");
|
|
||||||
return COMPANY_NEVERSOFT;
|
return COMPANY_NEVERSOFT;
|
||||||
} else {
|
|
||||||
LogManager::instance().addEntry(QString("Failed to find company, found '%1'!").arg(companyData));
|
|
||||||
}
|
}
|
||||||
|
LogManager::instance().addEntry(QString("Failed to find company, found '%1'!").arg(companyData));
|
||||||
return COMPANY_NONE;
|
return COMPANY_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -98,11 +157,9 @@ FF_FILETYPE FastFile::pParseFFFileType(QDataStream *afastFileStream) {
|
|||||||
QByteArray fileTypeData(2, Qt::Uninitialized);
|
QByteArray fileTypeData(2, Qt::Uninitialized);
|
||||||
afastFileStream->readRawData(fileTypeData.data(), 2);
|
afastFileStream->readRawData(fileTypeData.data(), 2);
|
||||||
if (fileTypeData == "ff") {
|
if (fileTypeData == "ff") {
|
||||||
qDebug() << "File type found: 'FAST_FILE'";
|
|
||||||
return FILETYPE_FAST_FILE;
|
return FILETYPE_FAST_FILE;
|
||||||
} else {
|
|
||||||
qDebug() << "Failed to find file type!";
|
|
||||||
}
|
}
|
||||||
|
LogManager::instance().addEntry("Failed to find file type!");
|
||||||
return FILETYPE_NONE;
|
return FILETYPE_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -111,14 +168,11 @@ FF_SIGNAGE FastFile::pParseFFSignage(QDataStream *afastFileStream) {
|
|||||||
QByteArray signedData(1, Qt::Uninitialized);
|
QByteArray signedData(1, Qt::Uninitialized);
|
||||||
afastFileStream->readRawData(signedData.data(), 1);
|
afastFileStream->readRawData(signedData.data(), 1);
|
||||||
if (signedData == "u") {
|
if (signedData == "u") {
|
||||||
qDebug() << "Found valid signage: Unsigned";
|
|
||||||
return SIGNAGE_UNSIGNED;
|
return SIGNAGE_UNSIGNED;
|
||||||
} else if (signedData == "0" || signedData == "x") {
|
} else if (signedData == "0" || signedData == "x") {
|
||||||
qDebug() << "Found valid signage: Signed";
|
|
||||||
return SIGNAGE_SIGNED;
|
return SIGNAGE_SIGNED;
|
||||||
} else {
|
|
||||||
qDebug() << "Failed to determine signage of fastfile!";
|
|
||||||
}
|
}
|
||||||
|
LogManager::instance().addEntry("Failed to determine signage of fastfile!");
|
||||||
return SIGNAGE_NONE;
|
return SIGNAGE_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -127,11 +181,9 @@ QString FastFile::pParseFFMagic(QDataStream *afastFileStream) {
|
|||||||
QByteArray magicData(3, Qt::Uninitialized);
|
QByteArray magicData(3, Qt::Uninitialized);
|
||||||
afastFileStream->readRawData(magicData.data(), 3);
|
afastFileStream->readRawData(magicData.data(), 3);
|
||||||
if (magicData == "100") {
|
if (magicData == "100") {
|
||||||
qDebug() << QString("Found valid magic: '%1'").arg(magicData);
|
|
||||||
return magicData;
|
return magicData;
|
||||||
} else {
|
|
||||||
qDebug() << "Magic invalid!";
|
|
||||||
}
|
}
|
||||||
|
LogManager::instance().addEntry("Magic invalid!");
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -144,21 +196,19 @@ quint32 FastFile::pParseFFVersion(QDataStream *afastFileStream) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
QString FastFile::pCalculateFFPlatform(quint32 aVersion) {
|
QString FastFile::pCalculateFFPlatform(quint32 aVersion) {
|
||||||
QString result = "NONE";
|
|
||||||
switch (aVersion) {
|
switch (aVersion) {
|
||||||
case 387: // PC World at War
|
case 387: // PC World at War
|
||||||
case 473: // PC Black Ops 1
|
case 473: // PC Black Ops 1
|
||||||
case 1: // PC Modern Warfare 3
|
case 1: // PC Modern Warfare 3
|
||||||
case 147: // PC Black Ops 2
|
case 147: // PC Black Ops 2
|
||||||
result = "PC";
|
return "PC";
|
||||||
break;
|
|
||||||
case 3640721408: // Xbox 360 Black Ops 1
|
case 3640721408: // Xbox 360 Black Ops 1
|
||||||
case 2449473536: // Xbox 360 Black Ops 2
|
case 2449473536: // Xbox 360 Black Ops 2
|
||||||
result = "360";
|
return "360";
|
||||||
break;
|
case 3707830272: // Wii Black Ops 1
|
||||||
|
return "Wii";
|
||||||
}
|
}
|
||||||
qDebug() << QString("Found platform: '%1'").arg(result);
|
return "NONE";
|
||||||
return result;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QString FastFile::pCalculateFFGame(quint32 aVersion) {
|
QString FastFile::pCalculateFFGame(quint32 aVersion) {
|
||||||
@ -170,6 +220,7 @@ QString FastFile::pCalculateFFGame(quint32 aVersion) {
|
|||||||
case 473: // PC Black Ops 1
|
case 473: // PC Black Ops 1
|
||||||
break;
|
break;
|
||||||
case 3640721408: // Xbox 360 Black Ops 1
|
case 3640721408: // Xbox 360 Black Ops 1
|
||||||
|
case 3707830272: // Wii Black Ops 1
|
||||||
result = "COD7";
|
result = "COD7";
|
||||||
break;
|
break;
|
||||||
case 1: // PC Modern Warfare 3
|
case 1: // PC Modern Warfare 3
|
||||||
@ -214,6 +265,7 @@ std::shared_ptr<FastFile> FastFile::Open(const QString &aFilePath) {
|
|||||||
|
|
||||||
quint32 companyInt;
|
quint32 companyInt;
|
||||||
FF_COMPANY company = pParseFFCompany(&fastFileStream, companyInt);
|
FF_COMPANY company = pParseFFCompany(&fastFileStream, companyInt);
|
||||||
|
qDebug() << "Company: " << company;
|
||||||
FF_FILETYPE fileType;
|
FF_FILETYPE fileType;
|
||||||
FF_SIGNAGE signage;
|
FF_SIGNAGE signage;
|
||||||
QString magic;
|
QString magic;
|
||||||
@ -272,3 +324,15 @@ std::shared_ptr<FastFile> FastFile::Open(const QString &aFilePath) {
|
|||||||
// Open zone file after decompressing ff and writing
|
// Open zone file after decompressing ff and writing
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
bool FastFile::ExportFastFile(const QString aFastFilePath) {
|
||||||
|
QFile fastFile(aFastFilePath);
|
||||||
|
if (!fastFile.open(QIODevice::WriteOnly)) {
|
||||||
|
LogManager::instance().addEntry("Failed to write fast file! " +
|
||||||
|
fastFile.errorString());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
fastFile.write(GetBinaryData());
|
||||||
|
fastFile.close();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|||||||
@ -3,10 +3,10 @@
|
|||||||
|
|
||||||
#include "enums.h"
|
#include "enums.h"
|
||||||
#include "zonefile.h"
|
#include "zonefile.h"
|
||||||
#include "encryption.h"
|
|
||||||
|
|
||||||
#include <QString>
|
#include <QString>
|
||||||
#include <QCryptographicHash>
|
#include <QCryptographicHash>
|
||||||
|
#include <QFileDialog>
|
||||||
|
|
||||||
class FastFile
|
class FastFile
|
||||||
{
|
{
|
||||||
@ -18,25 +18,29 @@ public:
|
|||||||
virtual bool Load(const QString aFilePath) = 0;
|
virtual bool Load(const QString aFilePath) = 0;
|
||||||
virtual bool Load(const QByteArray aData) = 0;
|
virtual bool Load(const QByteArray aData) = 0;
|
||||||
|
|
||||||
virtual QString GetStem() const { return mStem; }
|
virtual bool ExportFastFile(const QString aFastFilePath);
|
||||||
virtual FF_FILETYPE GetType() const { return mType; }
|
|
||||||
virtual FF_COMPANY GetCompany() const { return mCompany; }
|
|
||||||
virtual FF_SIGNAGE GetSignage() const { return mSignage; }
|
|
||||||
virtual QString GetMagic() const { return mMagic; }
|
|
||||||
virtual quint32 GetVersion() const { return mVersion; }
|
|
||||||
virtual std::shared_ptr<ZoneFile> GetZoneFile() const { return mZoneFile; }
|
|
||||||
virtual QString GetGame() const { return mGame; }
|
|
||||||
virtual QString GetPlatform() const { return mPlatform; }
|
|
||||||
|
|
||||||
virtual void SetStem(const QString aStem) { mStem = aStem; }
|
virtual QByteArray GetBinaryData() = 0;
|
||||||
virtual void SetType(const FF_FILETYPE aType) { mType = aType; }
|
|
||||||
virtual void SetCompany(const FF_COMPANY aCompany) { mCompany = aCompany; }
|
virtual QString GetStem() const;
|
||||||
virtual void SetSignage(const FF_SIGNAGE aSignage) { mSignage = aSignage; }
|
virtual FF_FILETYPE GetType() const;
|
||||||
virtual void SetMagic(const QString aMagic) { mMagic = aMagic; }
|
virtual FF_COMPANY GetCompany() const;
|
||||||
virtual void SetVersion(const quint32 aVersion) { mVersion = aVersion; }
|
virtual FF_SIGNAGE GetSignage() const;
|
||||||
virtual void SetZoneFile(const std::shared_ptr<ZoneFile> aZoneFile) { mZoneFile = aZoneFile; }
|
virtual QString GetMagic() const;
|
||||||
virtual void SetGame(const QString aGame) { mGame = aGame; }
|
virtual quint32 GetVersion() const;
|
||||||
virtual void SetPlatform(const QString aPlatform) { mPlatform = aPlatform; }
|
virtual std::shared_ptr<ZoneFile> GetZoneFile() const;
|
||||||
|
virtual QString GetGame() const;
|
||||||
|
virtual QString GetPlatform() const;
|
||||||
|
|
||||||
|
virtual void SetStem(const QString aStem);
|
||||||
|
virtual void SetType(const FF_FILETYPE aType);
|
||||||
|
virtual void SetCompany(const FF_COMPANY aCompany);
|
||||||
|
virtual void SetSignage(const FF_SIGNAGE aSignage);
|
||||||
|
virtual void SetMagic(const QString aMagic);
|
||||||
|
virtual void SetVersion(const quint32 aVersion);
|
||||||
|
virtual void SetZoneFile(const std::shared_ptr<ZoneFile> aZoneFile);
|
||||||
|
virtual void SetGame(const QString aGame);
|
||||||
|
virtual void SetPlatform(const QString aPlatform);
|
||||||
|
|
||||||
static FF_COMPANY pParseFFCompany(QDataStream *afastFileStream, quint32 &aCompanyInt);
|
static FF_COMPANY pParseFFCompany(QDataStream *afastFileStream, quint32 &aCompanyInt);
|
||||||
static FF_COMPANY pParseFFCompany(QDataStream *afastFileStream);
|
static FF_COMPANY pParseFFCompany(QDataStream *afastFileStream);
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
QT += core widgets
|
QT += core widgets
|
||||||
TEMPLATE = lib
|
TEMPLATE = lib
|
||||||
CONFIG += staticlib c++17 debug
|
CONFIG += staticlib c++17
|
||||||
|
|
||||||
SOURCES += \
|
SOURCES += \
|
||||||
fastfile_cod2.cpp \
|
fastfile_cod2.cpp \
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user