update fastfile logic.

This commit is contained in:
= 2025-04-04 20:40:37 -04:00
parent 5033bdde20
commit 75bbeaa9d1
3 changed files with 119 additions and 51 deletions

View File

@ -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;
}

View File

@ -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);

View File

@ -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 \