mirror of
https://github.com/wiidev/usbloadergx.git
synced 2024-11-19 09:49:21 +01:00
fix shared content installation flow
This commit is contained in:
parent
e25c4e9643
commit
bc177f4998
@ -322,7 +322,7 @@ bool Wad::InstallContents(const char *installpath)
|
|||||||
// Install content
|
// Install content
|
||||||
if(content->type == 0x8001) {
|
if(content->type == 0x8001) {
|
||||||
// shared content
|
// shared content
|
||||||
int result = CheckContentMap(installpath, content, filepath);
|
int result = UpdateContentMap(installpath, content, filepath);
|
||||||
if(result == 1) // exists already, skip file
|
if(result == 1) // exists already, skip file
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
@ -448,6 +448,16 @@ int Wad::CheckContentMap(const char *installpath, tmd_content *content, char *fi
|
|||||||
return 1; // content exists already
|
return 1; // content exists already
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Content does not exists
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int Wad::UpdateContentMap(const char *installpath, tmd_content *content, char *filepath)
|
||||||
|
{
|
||||||
|
int result = CheckContentMap(installpath,content,filepath);
|
||||||
|
if ( result != 0 )
|
||||||
|
return result; // content already exists or error
|
||||||
|
|
||||||
// Content does not exists, append it.
|
// Content does not exists, append it.
|
||||||
u32 next_entry = content_map_size;
|
u32 next_entry = content_map_size;
|
||||||
u8 *tmp = (u8 *) realloc(content_map, (next_entry + 1) * sizeof(map_entry_t));
|
u8 *tmp = (u8 *) realloc(content_map, (next_entry + 1) * sizeof(map_entry_t));
|
||||||
@ -461,7 +471,7 @@ int Wad::CheckContentMap(const char *installpath, tmd_content *content, char *fi
|
|||||||
content_map = tmp;
|
content_map = tmp;
|
||||||
content_map_size++;
|
content_map_size++;
|
||||||
|
|
||||||
map = (map_entry_t *) content_map;
|
map_entry_t *map = (map_entry_t *) content_map;
|
||||||
char name[9];
|
char name[9];
|
||||||
sprintf(name, "%08x", (unsigned int)next_entry);
|
sprintf(name, "%08x", (unsigned int)next_entry);
|
||||||
memcpy(map[next_entry].name, name, 8);
|
memcpy(map[next_entry].name, name, 8);
|
||||||
|
@ -49,6 +49,7 @@ public:
|
|||||||
private:
|
private:
|
||||||
bool InstallContents(const char *installpath);
|
bool InstallContents(const char *installpath);
|
||||||
int CheckContentMap(const char *installpath, tmd_content *content, char *filepath);
|
int CheckContentMap(const char *installpath, tmd_content *content, char *filepath);
|
||||||
|
int UpdateContentMap(const char *installpath, tmd_content *content, char *filepath);
|
||||||
bool WriteFile(const char *filepath, u8 *buffer, u32 len);
|
bool WriteFile(const char *filepath, u8 *buffer, u32 len);
|
||||||
bool SetTitleUID(const char *intallpath, const u64 &tid);
|
bool SetTitleUID(const char *intallpath, const u64 &tid);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user