summaryrefslogtreecommitdiff
path: root/src/core
diff options
context:
space:
mode:
authorGravatar Zach Hilman2018-09-19 22:04:51 -0400
committerGravatar Zach Hilman2018-09-21 19:53:33 -0400
commit050547b801ccc7cfea65c142658e8d2a987472d2 (patch)
tree079655ab43528f76d14d06ad747d2c2251ef81f7 /src/core
parentfile_sys: Port Atmosphere-NX fs_mitm implementation (diff)
downloadyuzu-050547b801ccc7cfea65c142658e8d2a987472d2.tar.gz
yuzu-050547b801ccc7cfea65c142658e8d2a987472d2.tar.xz
yuzu-050547b801ccc7cfea65c142658e8d2a987472d2.zip
romfs: Implement CreateRomFS
Diffstat (limited to 'src/core')
-rw-r--r--src/core/file_sys/romfs.cpp20
-rw-r--r--src/core/file_sys/romfs.h9
2 files changed, 25 insertions, 4 deletions
diff --git a/src/core/file_sys/romfs.cpp b/src/core/file_sys/romfs.cpp
index 9f6e41cdf..71e4e0e2f 100644
--- a/src/core/file_sys/romfs.cpp
+++ b/src/core/file_sys/romfs.cpp
@@ -4,8 +4,10 @@
4 4
5#include "common/common_types.h" 5#include "common/common_types.h"
6#include "common/swap.h" 6#include "common/swap.h"
7#include "core/file_sys/fsmitm_romfsbuild.hpp"
7#include "core/file_sys/romfs.h" 8#include "core/file_sys/romfs.h"
8#include "core/file_sys/vfs.h" 9#include "core/file_sys/vfs.h"
10#include "core/file_sys/vfs_concat.h"
9#include "core/file_sys/vfs_offset.h" 11#include "core/file_sys/vfs_offset.h"
10#include "core/file_sys/vfs_vector.h" 12#include "core/file_sys/vfs_vector.h"
11 13
@@ -98,7 +100,7 @@ void ProcessDirectory(VirtualFile file, std::size_t dir_offset, std::size_t file
98 } 100 }
99} 101}
100 102
101VirtualDir ExtractRomFS(VirtualFile file) { 103VirtualDir ExtractRomFS(VirtualFile file, bool traverse_into_data) {
102 RomFSHeader header{}; 104 RomFSHeader header{};
103 if (file->ReadObject(&header) != sizeof(RomFSHeader)) 105 if (file->ReadObject(&header) != sizeof(RomFSHeader))
104 return nullptr; 106 return nullptr;
@@ -117,9 +119,21 @@ VirtualDir ExtractRomFS(VirtualFile file) {
117 119
118 VirtualDir out = std::move(root); 120 VirtualDir out = std::move(root);
119 121
120 while (out->GetSubdirectory("") != nullptr) 122 while (out->GetSubdirectories().size() == 1 && out->GetFiles().size() == 0) {
121 out = out->GetSubdirectory(""); 123 if (out->GetSubdirectories().front()->GetName() == "data" && !traverse_into_data)
124 break;
125 out = out->GetSubdirectories().front();
126 }
122 127
123 return out; 128 return out;
124} 129}
130
131VirtualFile CreateRomFS(VirtualDir dir) {
132 if (dir == nullptr)
133 return nullptr;
134
135 RomFSBuildContext ctx{dir};
136 return ConcatenateFiles<0>(ctx.Build(), dir->GetName());
137}
138
125} // namespace FileSys 139} // namespace FileSys
diff --git a/src/core/file_sys/romfs.h b/src/core/file_sys/romfs.h
index e54a7d7a9..8e82585a0 100644
--- a/src/core/file_sys/romfs.h
+++ b/src/core/file_sys/romfs.h
@@ -5,6 +5,7 @@
5#pragma once 5#pragma once
6 6
7#include <array> 7#include <array>
8#include <map>
8#include "common/common_funcs.h" 9#include "common/common_funcs.h"
9#include "common/common_types.h" 10#include "common/common_types.h"
10#include "common/swap.h" 11#include "common/swap.h"
@@ -12,6 +13,8 @@
12 13
13namespace FileSys { 14namespace FileSys {
14 15
16struct RomFSHeader;
17
15struct IVFCLevel { 18struct IVFCLevel {
16 u64_le offset; 19 u64_le offset;
17 u64_le size; 20 u64_le size;
@@ -31,6 +34,10 @@ static_assert(sizeof(IVFCHeader) == 0xE0, "IVFCHeader has incorrect size.");
31 34
32// Converts a RomFS binary blob to VFS Filesystem 35// Converts a RomFS binary blob to VFS Filesystem
33// Returns nullptr on failure 36// Returns nullptr on failure
34VirtualDir ExtractRomFS(VirtualFile file); 37VirtualDir ExtractRomFS(VirtualFile file, bool traverse_into_data = true);
38
39// Converts a VFS filesystem into a RomFS binary
40// Returns nullptr on failure
41VirtualFile CreateRomFS(VirtualDir dir);
35 42
36} // namespace FileSys 43} // namespace FileSys