mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-12 02:28:11 +02:00
Try to fix failure to copy file on Android
This commit is contained in:
parent
0a30e86f10
commit
a7000d7849
@ -72,10 +72,15 @@ bool ChroniclesExtractor::extractGogInstaller(QString file)
|
|||||||
|
|
||||||
if(!errorText.isEmpty())
|
if(!errorText.isEmpty())
|
||||||
{
|
{
|
||||||
|
logGlobal->error("Gog installer extractio failure! Reason: %s", errorText.toStdString());
|
||||||
|
|
||||||
QString hashError = Innoextract::getHashError(file, {}, {}, {});
|
QString hashError = Innoextract::getHashError(file, {}, {}, {});
|
||||||
QMessageBox::critical(parent, tr("Extracting error!"), errorText);
|
QMessageBox::critical(parent, tr("Extracting error!"), errorText);
|
||||||
if(!hashError.isEmpty())
|
if(!hashError.isEmpty())
|
||||||
|
{
|
||||||
|
logGlobal->error("Hash error: %s", hashError.toStdString());
|
||||||
QMessageBox::critical(parent, tr("Hash error!"), hashError, QMessageBox::Ok, QMessageBox::Ok);
|
QMessageBox::critical(parent, tr("Hash error!"), hashError, QMessageBox::Ok, QMessageBox::Ok);
|
||||||
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -226,15 +231,30 @@ void ChroniclesExtractor::installChronicles(QStringList exe)
|
|||||||
if(!createTempDir())
|
if(!createTempDir())
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
logGlobal->info("Copying offline installer");
|
|
||||||
// FIXME: this is required at the moment for Android (and possibly iOS)
|
// FIXME: this is required at the moment for Android (and possibly iOS)
|
||||||
// Incoming file names are in content URI form, e.g. content://media/internal/chronicles.exe
|
// Incoming file names are in content URI form, e.g. content://media/internal/chronicles.exe
|
||||||
// Qt can handle those like it does regular files
|
// Qt can handle those like it does regular files
|
||||||
// however, innoextract fails to open such files
|
// however, innoextract fails to open such files
|
||||||
// so make a copy in directory to which vcmi always has full access and operate on it
|
// so make a copy in directory to which vcmi always has full access and operate on it
|
||||||
QString filepath = tempDir.filePath("chr.exe");
|
QString filepath = tempDir.filePath("chr.exe");
|
||||||
QFile(f).copy(filepath);
|
logGlobal->info("Copying offline installer from '%s' to '%s'", f.toStdString(), filepath.toStdString());
|
||||||
QFile file(filepath);
|
{
|
||||||
|
QFile sourceFile(f);
|
||||||
|
QFile targetFile(filepath);
|
||||||
|
|
||||||
|
sourceFile.open(QFile::ReadOnly);
|
||||||
|
targetFile.open(QFile::ReadWrite);
|
||||||
|
QByteArray data = sourceFile.readAll();
|
||||||
|
uint64_t written = targetFile.write(data);
|
||||||
|
|
||||||
|
logGlobal->info("Read %d bytes, written %d bytes", data.size(), written);
|
||||||
|
|
||||||
|
if (written == 0 || written != data.size())
|
||||||
|
{
|
||||||
|
QMessageBox::critical(parent, tr("File copy failure"), tr("Failed to copy gog installer to internal folder! %1 out of %2 bytes copied").arg(data.size()).arg(written));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
logGlobal->info("Extracting offline installer");
|
logGlobal->info("Extracting offline installer");
|
||||||
if(!extractGogInstaller(filepath))
|
if(!extractGogInstaller(filepath))
|
||||||
|
Loading…
Reference in New Issue
Block a user