Qt: Pay down some VFile technical debt

This commit is contained in:
Vicki Pfau 2022-10-30 02:48:39 -07:00
parent 2a5417e3ce
commit 472660a5d3
3 changed files with 15 additions and 13 deletions

View File

@ -31,6 +31,7 @@ void CoreManager::setMultiplayerController(MultiplayerController* multiplayer) {
CoreController* CoreManager::loadGame(const QString& path) { CoreController* CoreManager::loadGame(const QString& path) {
QFileInfo info(path); QFileInfo info(path);
if (!info.isReadable()) { if (!info.isReadable()) {
// Open specific file in archive
QString fname = info.fileName(); QString fname = info.fileName();
QString base = info.path(); QString base = info.path();
if (base.endsWith("/") || base.endsWith(QDir::separator())) { if (base.endsWith("/") || base.endsWith(QDir::separator())) {
@ -40,13 +41,8 @@ CoreController* CoreManager::loadGame(const QString& path) {
if (dir) { if (dir) {
VFile* vf = dir->openFile(dir, fname.toUtf8().constData(), O_RDONLY); VFile* vf = dir->openFile(dir, fname.toUtf8().constData(), O_RDONLY);
if (vf) { if (vf) {
struct VFile* vfclone = VFileMemChunk(NULL, vf->size(vf)); struct VFile* vfclone = VFileDevice::openMemory(vf->size(vf));
uint8_t buffer[2048]; VFileDevice::copyFile(vf, vfclone);
ssize_t read;
while ((read = vf->read(vf, buffer, sizeof(buffer))) > 0) {
vfclone->write(vfclone, buffer, read);
}
vf->close(vf);
vf = vfclone; vf = vfclone;
} }
dir->close(dir); dir->close(dir);
@ -59,15 +55,16 @@ CoreController* CoreManager::loadGame(const QString& path) {
VFile* vf = nullptr; VFile* vf = nullptr;
VDir* archive = VDirOpenArchive(path.toUtf8().constData()); VDir* archive = VDirOpenArchive(path.toUtf8().constData());
if (archive) { if (archive) {
// Open first file in archive
VFile* vfOriginal = VDirFindFirst(archive, [](VFile* vf) { VFile* vfOriginal = VDirFindFirst(archive, [](VFile* vf) {
return mCoreIsCompatible(vf) != mPLATFORM_NONE; return mCoreIsCompatible(vf) != mPLATFORM_NONE;
}); });
if (vfOriginal) { if (vfOriginal) {
ssize_t size = vfOriginal->size(vfOriginal); ssize_t size = vfOriginal->size(vfOriginal);
if (size > 0) { if (size > 0) {
void* mem = vfOriginal->map(vfOriginal, size, MAP_READ); struct VFile* vfclone = VFileDevice::openMemory(vfOriginal->size(vfOriginal));
vf = VFileMemChunk(mem, size); VFileDevice::copyFile(vfOriginal, vfclone);
vfOriginal->unmap(vfOriginal, mem, size); vf = vfclone;
} }
vfOriginal->close(vfOriginal); vfOriginal->close(vfOriginal);
} }
@ -75,6 +72,7 @@ CoreController* CoreManager::loadGame(const QString& path) {
} }
QDir dir(info.dir()); QDir dir(info.dir());
if (!vf) { if (!vf) {
// Open bare file
vf = VFileOpen(info.canonicalFilePath().toUtf8().constData(), O_RDONLY); vf = VFileOpen(info.canonicalFilePath().toUtf8().constData(), O_RDONLY);
} }
return loadGame(vf, info.fileName(), dir.canonicalPath()); return loadGame(vf, info.fileName(), dir.canonicalPath());

View File

@ -172,8 +172,8 @@ VFile* VFileDevice::open(const QString& path, int mode) {
return VFileOpen(path.toUtf8().constData(), mode); return VFileOpen(path.toUtf8().constData(), mode);
} }
VFile* VFileDevice::openMemory() { VFile* VFileDevice::openMemory(quint64 size) {
return VFileMemChunk(nullptr, 0); return VFileMemChunk(nullptr, size);
} }
VDir* VFileDevice::openDir(const QString& path) { VDir* VFileDevice::openDir(const QString& path) {
@ -186,6 +186,10 @@ VDir* VFileDevice::openArchive(const QString& path) {
bool VFileDevice::copyFile(VFile* input, VFile* output) { bool VFileDevice::copyFile(VFile* input, VFile* output) {
uint8_t buffer[0x800]; uint8_t buffer[0x800];
input->seek(input, 0, SEEK_SET);
output->seek(output, 0, SEEK_SET);
ssize_t size; ssize_t size;
while ((size = input->read(input, buffer, sizeof(buffer))) > 0) { while ((size = input->read(input, buffer, sizeof(buffer))) > 0) {
output->write(output, buffer, size); output->write(output, buffer, size);

View File

@ -38,7 +38,7 @@ public:
static VFile* wrap(QBuffer*, QIODevice::OpenMode); static VFile* wrap(QBuffer*, QIODevice::OpenMode);
static VFile* open(const QString& path, int mode); static VFile* open(const QString& path, int mode);
static VFile* openMemory(); static VFile* openMemory(quint64 size = 0);
static VDir* openDir(const QString& path); static VDir* openDir(const QString& path);
static VDir* openArchive(const QString& path); static VDir* openArchive(const QString& path);