[Kernel] Use user_language value as the slot to retrieve STFS strings from
This commit is contained in:
parent
e91b9f4ca1
commit
72daead6af
|
@ -20,6 +20,8 @@
|
||||||
#include "xenia/vfs/devices/host_path_device.h"
|
#include "xenia/vfs/devices/host_path_device.h"
|
||||||
#include "xenia/vfs/devices/stfs_container_device.h"
|
#include "xenia/vfs/devices/stfs_container_device.h"
|
||||||
|
|
||||||
|
DECLARE_int32(user_language);
|
||||||
|
|
||||||
namespace xe {
|
namespace xe {
|
||||||
namespace kernel {
|
namespace kernel {
|
||||||
namespace xam {
|
namespace xam {
|
||||||
|
@ -113,7 +115,7 @@ std::vector<XCONTENT_DATA> ContentManager::ListContent(uint32_t device_id,
|
||||||
content_data.content_type =
|
content_data.content_type =
|
||||||
static_cast<uint32_t>(header->metadata.content_type);
|
static_cast<uint32_t>(header->metadata.content_type);
|
||||||
content_data.display_name =
|
content_data.display_name =
|
||||||
header->metadata.get_display_name(XLanguage::kEnglish);
|
header->metadata.get_display_name((XLanguage)cvars::user_language);
|
||||||
// TODO: select localized display name
|
// TODO: select localized display name
|
||||||
// some games may expect different ones depending on language setting.
|
// some games may expect different ones depending on language setting.
|
||||||
map->Close();
|
map->Close();
|
||||||
|
@ -196,7 +198,8 @@ X_RESULT ContentManager::CreateContent(std::string root_name,
|
||||||
vfs::StfsHeader* header = new vfs::StfsHeader();
|
vfs::StfsHeader* header = new vfs::StfsHeader();
|
||||||
// TODO: set title_id, title_name & publisher from XDBF info
|
// TODO: set title_id, title_name & publisher from XDBF info
|
||||||
header->metadata.content_type = (xe::vfs::XContentType)data.content_type;
|
header->metadata.content_type = (xe::vfs::XContentType)data.content_type;
|
||||||
header->metadata.set_display_name(data.display_name, XLanguage::kEnglish);
|
header->metadata.set_display_name(data.display_name,
|
||||||
|
(XLanguage)cvars::user_language);
|
||||||
// TODO: set display name locale that's currently in use
|
// TODO: set display name locale that's currently in use
|
||||||
fwrite(header, sizeof(vfs::StfsHeader), 1, file);
|
fwrite(header, sizeof(vfs::StfsHeader), 1, file);
|
||||||
fclose(file);
|
fclose(file);
|
||||||
|
|
|
@ -206,6 +206,9 @@ struct XContentMetadata {
|
||||||
std::wstring get_display_name(XLanguage lang) {
|
std::wstring get_display_name(XLanguage lang) {
|
||||||
uint32_t lang_id = (uint32_t)lang;
|
uint32_t lang_id = (uint32_t)lang;
|
||||||
lang_id--;
|
lang_id--;
|
||||||
|
if (lang_id >= 12) {
|
||||||
|
lang_id = 0; // no room for this lang, store in english slot..
|
||||||
|
}
|
||||||
|
|
||||||
wchar_t* str = 0;
|
wchar_t* str = 0;
|
||||||
if (lang_id >= 0 && lang_id < 9) {
|
if (lang_id >= 0 && lang_id < 9) {
|
||||||
|
@ -226,6 +229,9 @@ struct XContentMetadata {
|
||||||
std::wstring get_description(XLanguage lang) {
|
std::wstring get_description(XLanguage lang) {
|
||||||
uint32_t lang_id = (uint32_t)lang;
|
uint32_t lang_id = (uint32_t)lang;
|
||||||
lang_id--;
|
lang_id--;
|
||||||
|
if (lang_id >= 12) {
|
||||||
|
lang_id = 0; // no room for this lang, store in english slot..
|
||||||
|
}
|
||||||
|
|
||||||
wchar_t* str = 0;
|
wchar_t* str = 0;
|
||||||
if (lang_id >= 0 && lang_id < 9) {
|
if (lang_id >= 0 && lang_id < 9) {
|
||||||
|
@ -263,6 +269,9 @@ struct XContentMetadata {
|
||||||
bool set_display_name(const std::wstring& value, XLanguage lang) {
|
bool set_display_name(const std::wstring& value, XLanguage lang) {
|
||||||
uint32_t lang_id = (uint32_t)lang;
|
uint32_t lang_id = (uint32_t)lang;
|
||||||
lang_id--;
|
lang_id--;
|
||||||
|
if (lang_id >= 12) {
|
||||||
|
lang_id = 0; // no room for this lang, store in english slot..
|
||||||
|
}
|
||||||
|
|
||||||
wchar_t* str = 0;
|
wchar_t* str = 0;
|
||||||
if (lang_id >= 0 && lang_id < 9) {
|
if (lang_id >= 0 && lang_id < 9) {
|
||||||
|
@ -281,6 +290,9 @@ struct XContentMetadata {
|
||||||
bool set_description(const std::wstring& value, XLanguage lang) {
|
bool set_description(const std::wstring& value, XLanguage lang) {
|
||||||
uint32_t lang_id = (uint32_t)lang;
|
uint32_t lang_id = (uint32_t)lang;
|
||||||
lang_id--;
|
lang_id--;
|
||||||
|
if (lang_id >= 12) {
|
||||||
|
lang_id = 0; // no room for this lang, store in english slot..
|
||||||
|
}
|
||||||
|
|
||||||
wchar_t* str = 0;
|
wchar_t* str = 0;
|
||||||
if (lang_id >= 0 && lang_id < 9) {
|
if (lang_id >= 0 && lang_id < 9) {
|
||||||
|
|
|
@ -367,7 +367,7 @@ enum class XLanguage : uint32_t {
|
||||||
kItalian,
|
kItalian,
|
||||||
kKorean,
|
kKorean,
|
||||||
kTChinese,
|
kTChinese,
|
||||||
kUnknown9, // unused?
|
kPortuguese,
|
||||||
kUnknown10, // unused?
|
kUnknown10, // unused?
|
||||||
kPolish,
|
kPolish,
|
||||||
kRussian,
|
kRussian,
|
||||||
|
|
Loading…
Reference in New Issue