diff options
author | Petr Mrázek <peterix@gmail.com> | 2015-12-26 03:20:41 +0100 |
---|---|---|
committer | Petr Mrázek <peterix@gmail.com> | 2015-12-26 03:20:41 +0100 |
commit | 7670d72bd9c8bb2adcecd2d04413a2abb9ac174f (patch) | |
tree | f02b7cc15ba8ca54f3c404ba542db2cffc841c4c /logic/minecraft/ModList.cpp | |
parent | c64a7940c1c99f6691d0fdd45910a09808e40d97 (diff) | |
download | MultiMC-7670d72bd9c8bb2adcecd2d04413a2abb9ac174f.tar MultiMC-7670d72bd9c8bb2adcecd2d04413a2abb9ac174f.tar.gz MultiMC-7670d72bd9c8bb2adcecd2d04413a2abb9ac174f.tar.lz MultiMC-7670d72bd9c8bb2adcecd2d04413a2abb9ac174f.tar.xz MultiMC-7670d72bd9c8bb2adcecd2d04413a2abb9ac174f.zip |
GH-1178 sanitize mod paths while installing folder mods
Diffstat (limited to 'logic/minecraft/ModList.cpp')
-rw-r--r-- | logic/minecraft/ModList.cpp | 19 |
1 files changed, 12 insertions, 7 deletions
diff --git a/logic/minecraft/ModList.cpp b/logic/minecraft/ModList.cpp index a1640d2e..d9ed4886 100644 --- a/logic/minecraft/ModList.cpp +++ b/logic/minecraft/ModList.cpp @@ -235,13 +235,18 @@ bool ModList::isValid() return m_dir.exists() && m_dir.isReadable(); } -bool ModList::installMod(const QFileInfo &filename, int index) +bool ModList::installMod(const QString &filename, int index) { - if (!filename.exists() || !filename.isReadable() || index < 0) + // NOTE: fix for GH-1178: remove trailing slash to avoid issues with using the empty result of QFileInfo::fileName + QFileInfo fileinfo(FS::NormalizePath(filename)); + + qDebug() << "installing: " << fileinfo.absoluteFilePath(); + + if (!fileinfo.exists() || !fileinfo.isReadable() || index < 0) { return false; } - Mod m(filename); + Mod m(fileinfo); if (!m.valid()) return false; @@ -270,8 +275,8 @@ bool ModList::installMod(const QFileInfo &filename, int index) return false; if (type == Mod::MOD_SINGLEFILE || type == Mod::MOD_ZIPFILE || type == Mod::MOD_LITEMOD) { - QString newpath = FS::PathCombine(m_dir.path(), filename.fileName()); - if (!QFile::copy(filename.filePath(), newpath)) + QString newpath = FS::PathCombine(m_dir.path(), fileinfo.fileName()); + if (!QFile::copy(fileinfo.filePath(), newpath)) return false; m.repath(newpath); beginInsertRows(QModelIndex(), index, index); @@ -284,8 +289,8 @@ bool ModList::installMod(const QFileInfo &filename, int index) else if (type == Mod::MOD_FOLDER) { - QString from = filename.filePath(); - QString to = FS::PathCombine(m_dir.path(), filename.fileName()); + QString from = fileinfo.filePath(); + QString to = FS::PathCombine(m_dir.path(), fileinfo.fileName()); if (!FS::copy(from, to)()) return false; m.repath(to); |