Fixed problems with cd content autodetection

loadfix
pvdk 11 years ago
parent 2e1248537e
commit 667b0de250

@ -386,7 +386,7 @@ void Wizard::UnshieldWorker::extract()
writeSettings(); writeSettings();
// Remove the temporary directory // Remove the temporary directory
//removeDirectory(getPath() + QDir::separator() + QLatin1String("extract-temp")); removeDirectory(getPath() + QDir::separator() + QLatin1String("extract-temp"));
// Fill the progress bar // Fill the progress bar
int total = 0; int total = 0;
@ -445,26 +445,39 @@ bool Wizard::UnshieldWorker::setupComponent(Component component)
foreach (const QString &file, list) { foreach (const QString &file, list) {
qDebug() << "current archive: " << file;
// Try to open the archive
Unshield *unshield = NULL;
unshield = openCab(file);
if (!unshield)
return false;
if (component == Wizard::Component_Morrowind) if (component == Wizard::Component_Morrowind)
{ {
bool morrowindFound = findInCab(file, QLatin1String("Morrowind.bsa")); bool morrowindFound = findInCab(QLatin1String("Morrowind.bsa"), unshield);
bool tribunalFound = findInCab(file, QLatin1String("Tribunal.bsa")); bool tribunalFound = findInCab(QLatin1String("Tribunal.bsa"), unshield);
bool bloodmoonFound = findInCab(file, QLatin1String("Bloodmoon.bsa")); bool bloodmoonFound = findInCab(QLatin1String("Bloodmoon.bsa"), unshield);
if (morrowindFound) { if (morrowindFound) {
// Check if we have correct archive, other archives have Morrowind.bsa too // Check if we have correct archive, other archives have Morrowind.bsa too
if ((tribunalFound && bloodmoonFound) if ((tribunalFound && bloodmoonFound)
|| (!tribunalFound && !bloodmoonFound)) { || (!tribunalFound && !bloodmoonFound)) {
cabFile = file; cabFile = file;
found = true; // We have a GoTY disk found = true; // We have a GoTY disk or a Morrowind-only disk
} }
} }
} else { } else {
if (findInCab(file, name + QLatin1String(".bsa"))) {
if (findInCab(name + QLatin1String(".bsa"), unshield)) {
cabFile = file; cabFile = file;
found = true; found = true;
} }
} }
// Close the current archive
unshield_close(unshield);
} }
if (!found) { if (!found) {
@ -746,6 +759,39 @@ bool Wizard::UnshieldWorker::extractFile(Unshield *unshield, const QString &dest
return success; return success;
} }
bool Wizard::UnshieldWorker::extractCab(const QString &cabFile, const QString &destination)
{
bool success = false;
QByteArray array(cabFile.toUtf8());
Unshield *unshield;
unshield = unshield_open(array.constData());
if (!unshield) {
emit error(tr("Failed to open InstallShield Cabinet File."), tr("Opening %1 failed.").arg(cabFile));
return false;
}
int counter = 0;
for (int i=0; i<unshield_file_group_count(unshield); ++i)
{
UnshieldFileGroup *group = unshield_file_group_get(unshield, i);
for (size_t j=group->first_file; j<=group->last_file; ++j)
{
if (unshield_file_is_valid(unshield, j)) {
success = extractFile(unshield, destination, group->name, j, counter);
++counter;
}
}
}
unshield_close(unshield);
return success;
}
QString Wizard::UnshieldWorker::findFile(const QString &fileName, const QString &path) QString Wizard::UnshieldWorker::findFile(const QString &fileName, const QString &path)
{ {
return findFiles(fileName, path).first(); return findFiles(fileName, path).first();
@ -764,14 +810,16 @@ QStringList Wizard::UnshieldWorker::findFiles(const QString &fileName, const QSt
QStringList result; QStringList result;
QDir dir(path); QDir dir(path);
// Prevent parsing over the complete filesystem
if (dir == QDir::rootPath())
return QStringList();
if (!dir.exists()) if (!dir.exists())
return QStringList(); return QStringList();
QFileInfoList list(dir.entryInfoList(QDir::NoDotAndDotDot | QFileInfoList list(dir.entryInfoList(QDir::NoDotAndDotDot |
QDir::System | QDir::Hidden |
QDir::AllDirs | QDir::Files, QDir::DirsFirst)); QDir::AllDirs | QDir::Files, QDir::DirsFirst));
foreach(QFileInfo info, list) { foreach(QFileInfo info, list) {
if (info.isSymLink()) if (info.isSymLink())
continue; continue;
@ -813,7 +861,7 @@ QStringList Wizard::UnshieldWorker::findDirectories(const QString &dirName, cons
return findFiles(dirName, path, 0, true, true); return findFiles(dirName, path, 0, true, true);
} }
bool Wizard::UnshieldWorker::findInCab(const QString &cabFile, const QString &fileName) Unshield* Wizard::UnshieldWorker::openCab(const QString &cabFile)
{ {
QByteArray array(cabFile.toUtf8()); QByteArray array(cabFile.toUtf8());
@ -822,43 +870,17 @@ bool Wizard::UnshieldWorker::findInCab(const QString &cabFile, const QString &fi
if (!unshield) { if (!unshield) {
emit error(tr("Failed to open InstallShield Cabinet File."), tr("Opening %1 failed.").arg(cabFile)); emit error(tr("Failed to open InstallShield Cabinet File."), tr("Opening %1 failed.").arg(cabFile));
return false; unshield_close(unshield);
return NULL;
} }
for (int i=0; i<unshield_file_group_count(unshield); ++i) return unshield;
{
UnshieldFileGroup *group = unshield_file_group_get(unshield, i);
for (size_t j=group->first_file; j<=group->last_file; ++j)
{
if (unshield_file_is_valid(unshield, j)) {
QString current(QString::fromUtf8(unshield_file_name(unshield, j)));
if (current.toLower() == fileName.toLower())
return true; // File is found!
}
}
}
unshield_close(unshield);
return false;
} }
bool Wizard::UnshieldWorker::extractCab(const QString &cabFile, const QString &destination) bool Wizard::UnshieldWorker::findInCab(const QString &fileName, Unshield *unshield)
{ {
bool success = false; if (!unshield)
QByteArray array(cabFile.toUtf8());
Unshield *unshield;
unshield = unshield_open(array.constData());
if (!unshield) {
emit error(tr("Failed to open InstallShield Cabinet File."), tr("Opening %1 failed.").arg(cabFile));
return false; return false;
}
int counter = 0;
for (int i=0; i<unshield_file_group_count(unshield); ++i) for (int i=0; i<unshield_file_group_count(unshield); ++i)
{ {
@ -866,13 +888,14 @@ bool Wizard::UnshieldWorker::extractCab(const QString &cabFile, const QString &d
for (size_t j=group->first_file; j<=group->last_file; ++j) for (size_t j=group->first_file; j<=group->last_file; ++j)
{ {
if (unshield_file_is_valid(unshield, j)) { if (unshield_file_is_valid(unshield, j)) {
success = extractFile(unshield, destination, group->name, j, counter); QString current(QString::fromUtf8(unshield_file_name(unshield, j)));
++counter; if (current.toLower() == fileName.toLower())
return true; // File is found!
} }
} }
} }
unshield_close(unshield); return false;
return success;
} }

@ -62,7 +62,9 @@ namespace Wizard
bool extractCab(const QString &cabFile, const QString &destination); bool extractCab(const QString &cabFile, const QString &destination);
bool extractFile(Unshield *unshield, const QString &destination, const QString &prefix, int index, int counter); bool extractFile(Unshield *unshield, const QString &destination, const QString &prefix, int index, int counter);
bool findInCab(const QString &cabFile, const QString &fileName);
Unshield* openCab(const QString &cabFile);
bool findInCab(const QString &fileName, Unshield *unshield);
QString findFile(const QString &fileName, const QString &path); QString findFile(const QString &fileName, const QString &path);

Loading…
Cancel
Save