summaryrefslogtreecommitdiffstats
path: root/src/core/file_sys/patch_manager.cpp
diff options
context:
space:
mode:
authorZach Hilman <zachhilman@gmail.com>2018-10-02 14:56:56 +0200
committerZach Hilman <zachhilman@gmail.com>2018-10-04 18:29:20 +0200
commitc1e069c066a609103c6b880585738ecabe48ddd2 (patch)
treebf599fa1e774ae098866d50ca5acbaf3441eb16e /src/core/file_sys/patch_manager.cpp
parentfsmitm_romfsbuild: Add support for stubbing and IPS patches in LFS (diff)
downloadyuzu-c1e069c066a609103c6b880585738ecabe48ddd2.tar
yuzu-c1e069c066a609103c6b880585738ecabe48ddd2.tar.gz
yuzu-c1e069c066a609103c6b880585738ecabe48ddd2.tar.bz2
yuzu-c1e069c066a609103c6b880585738ecabe48ddd2.tar.lz
yuzu-c1e069c066a609103c6b880585738ecabe48ddd2.tar.xz
yuzu-c1e069c066a609103c6b880585738ecabe48ddd2.tar.zst
yuzu-c1e069c066a609103c6b880585738ecabe48ddd2.zip
Diffstat (limited to '')
-rw-r--r--src/core/file_sys/patch_manager.cpp13
1 files changed, 12 insertions, 1 deletions
diff --git a/src/core/file_sys/patch_manager.cpp b/src/core/file_sys/patch_manager.cpp
index 539698f6e..76b51fe56 100644
--- a/src/core/file_sys/patch_manager.cpp
+++ b/src/core/file_sys/patch_manager.cpp
@@ -162,11 +162,17 @@ static void ApplyLayeredFS(VirtualFile& romfs, u64 title_id, ContentRecordType t
[](const VirtualDir& l, const VirtualDir& r) { return l->GetName() < r->GetName(); });
std::vector<VirtualDir> layers;
+ std::vector<VirtualDir> layers_ext;
layers.reserve(patch_dirs.size() + 1);
+ layers_ext.reserve(patch_dirs.size() + 1);
for (const auto& subdir : patch_dirs) {
auto romfs_dir = subdir->GetSubdirectory("romfs");
if (romfs_dir != nullptr)
layers.push_back(std::move(romfs_dir));
+
+ auto ext_dir = subdir->GetSubdirectory("romfs_ext");
+ if (ext_dir != nullptr)
+ layers.push_back(std::move(ext_dir));
}
layers.push_back(std::move(extracted));
@@ -175,7 +181,12 @@ static void ApplyLayeredFS(VirtualFile& romfs, u64 title_id, ContentRecordType t
return;
}
- auto packed = CreateRomFS(std::move(layered));
+ auto layered_ext = LayeredVfsDirectory::MakeLayeredDirectory(std::move(layers_ext));
+ if (layered_ext == nullptr) {
+ return;
+ }
+
+ auto packed = CreateRomFS(std::move(layered), std::move(layered_ext));
if (packed == nullptr) {
return;
}