mirror of
https://github.com/skyline-emu/skyline.git
synced 2025-01-11 15:09:08 +01:00
Address CR
This commit is contained in:
parent
0077833667
commit
c6d91c552b
@ -8,7 +8,7 @@
|
|||||||
#include <android/asset_manager_jni.h>
|
#include <android/asset_manager_jni.h>
|
||||||
#include <sys/system_properties.h>
|
#include <sys/system_properties.h>
|
||||||
#include "skyline/common.h"
|
#include "skyline/common.h"
|
||||||
#include "skyline/common/languages.h"
|
#include "skyline/common/language.h"
|
||||||
#include "skyline/common/signal.h"
|
#include "skyline/common/signal.h"
|
||||||
#include "skyline/common/settings.h"
|
#include "skyline/common/settings.h"
|
||||||
#include "skyline/common/trace.h"
|
#include "skyline/common/trace.h"
|
||||||
@ -91,7 +91,7 @@ extern "C" JNIEXPORT void Java_emu_skyline_EmulationActivity_executeApplication(
|
|||||||
settings,
|
settings,
|
||||||
std::string(appFilesPath),
|
std::string(appFilesPath),
|
||||||
GetTimeZoneName(),
|
GetTimeZoneName(),
|
||||||
static_cast<skyline::languages::SystemLanguage>(systemLanguage),
|
static_cast<skyline::language::SystemLanguage>(systemLanguage),
|
||||||
std::make_shared<skyline::vfs::AndroidAssetFileSystem>(AAssetManager_fromJava(env, assetManager))
|
std::make_shared<skyline::vfs::AndroidAssetFileSystem>(AAssetManager_fromJava(env, assetManager))
|
||||||
)};
|
)};
|
||||||
OsWeak = os;
|
OsWeak = os;
|
||||||
|
@ -53,7 +53,7 @@ extern "C" JNIEXPORT jint JNICALL Java_emu_skyline_loader_RomFile_populate(JNIEn
|
|||||||
jfieldID rawIconField{env->GetFieldID(clazz, "rawIcon", "[B")};
|
jfieldID rawIconField{env->GetFieldID(clazz, "rawIcon", "[B")};
|
||||||
|
|
||||||
if (loader->nacp) {
|
if (loader->nacp) {
|
||||||
auto language{skyline::languages::GetApplicationLanguage(static_cast<skyline::languages::SystemLanguage>(systemLanguage))};
|
auto language{skyline::language::GetApplicationLanguage(static_cast<skyline::language::SystemLanguage>(systemLanguage))};
|
||||||
if (((1 << static_cast<skyline::u32>(language)) & loader->nacp->supportedTitleLanguages) == 0)
|
if (((1 << static_cast<skyline::u32>(language)) & loader->nacp->supportedTitleLanguages) == 0)
|
||||||
language = loader->nacp->GetFirstSupportedTitleLanguage();
|
language = loader->nacp->GetFirstSupportedTitleLanguage();
|
||||||
|
|
||||||
|
@ -13,7 +13,7 @@ namespace skyline {
|
|||||||
constexpr size_t NewLanguageCodeListSize{18}; //!< The size of the post 10.1.0 language code list (was 17 between 4.0.0 - 10.1.0)
|
constexpr size_t NewLanguageCodeListSize{18}; //!< The size of the post 10.1.0 language code list (was 17 between 4.0.0 - 10.1.0)
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace languages {
|
namespace language {
|
||||||
/**
|
/**
|
||||||
* @brief The list of all languages. Entries parameters are language, language code, system language index, application language index and map which holds a macro used for filtering some application languages that don't have a direct corresponding system language
|
* @brief The list of all languages. Entries parameters are language, language code, system language index, application language index and map which holds a macro used for filtering some application languages that don't have a direct corresponding system language
|
||||||
* @example #define LANG_ENTRY(lang, code, sysIndex, appIndex, map) func(lang, code, sysIndex, appIndex, map) <br> LANGUAGES <br> #undef LANG_ENTRY
|
* @example #define LANG_ENTRY(lang, code, sysIndex, appIndex, map) func(lang, code, sysIndex, appIndex, map) <br> LANGUAGES <br> #undef LANG_ENTRY
|
@ -87,7 +87,7 @@ namespace skyline::loader {
|
|||||||
|
|
||||||
virtual ~Loader() = default;
|
virtual ~Loader() = default;
|
||||||
|
|
||||||
virtual std::vector<u8> GetIcon(languages::ApplicationLanguage language) {
|
virtual std::vector<u8> GetIcon(language::ApplicationLanguage language) {
|
||||||
return std::vector<u8>();
|
return std::vector<u8>();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@ namespace skyline::loader {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<u8> NroLoader::GetIcon(languages::ApplicationLanguage language) {
|
std::vector<u8> NroLoader::GetIcon(language::ApplicationLanguage language) {
|
||||||
NroAssetSection &segmentHeader{assetHeader.icon};
|
NroAssetSection &segmentHeader{assetHeader.icon};
|
||||||
std::vector<u8> buffer(segmentHeader.size);
|
std::vector<u8> buffer(segmentHeader.size);
|
||||||
|
|
||||||
|
@ -70,7 +70,7 @@ namespace skyline::loader {
|
|||||||
public:
|
public:
|
||||||
NroLoader(std::shared_ptr<vfs::Backing> backing);
|
NroLoader(std::shared_ptr<vfs::Backing> backing);
|
||||||
|
|
||||||
std::vector<u8> GetIcon(languages::ApplicationLanguage language) override;
|
std::vector<u8> GetIcon(language::ApplicationLanguage language) override;
|
||||||
|
|
||||||
void *LoadProcessData(const std::shared_ptr<kernel::type::KProcess> &process, const DeviceState &state) override;
|
void *LoadProcessData(const std::shared_ptr<kernel::type::KProcess> &process, const DeviceState &state) override;
|
||||||
};
|
};
|
||||||
|
@ -57,15 +57,15 @@ namespace skyline::loader {
|
|||||||
return NcaLoader::LoadExeFs(this, programNca->exeFs, process, state);
|
return NcaLoader::LoadExeFs(this, programNca->exeFs, process, state);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<u8> NspLoader::GetIcon(languages::ApplicationLanguage language) {
|
std::vector<u8> NspLoader::GetIcon(language::ApplicationLanguage language) {
|
||||||
if (controlRomFs == nullptr)
|
if (controlRomFs == nullptr)
|
||||||
return std::vector<u8>();
|
return std::vector<u8>();
|
||||||
|
|
||||||
std::shared_ptr<vfs::Backing> icon{};
|
std::shared_ptr<vfs::Backing> icon{};
|
||||||
|
|
||||||
auto iconName{fmt::format("icon_{}.dat", languages::ToString(language))};
|
auto iconName{fmt::format("icon_{}.dat", language::ToString(language))};
|
||||||
if (!(icon = controlRomFs->OpenFileUnchecked(iconName, {true, false, false}))) {
|
if (!(icon = controlRomFs->OpenFileUnchecked(iconName, {true, false, false}))) {
|
||||||
iconName = fmt::format("icon_{}.dat", languages::ToString(nacp->GetFirstSupportedTitleLanguage()));
|
iconName = fmt::format("icon_{}.dat", language::ToString(nacp->GetFirstSupportedTitleLanguage()));
|
||||||
icon = controlRomFs->OpenFileUnchecked(iconName, {true, false, false});
|
icon = controlRomFs->OpenFileUnchecked(iconName, {true, false, false});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -24,7 +24,7 @@ namespace skyline::loader {
|
|||||||
public:
|
public:
|
||||||
NspLoader(const std::shared_ptr<vfs::Backing> &backing, const std::shared_ptr<crypto::KeyStore> &keyStore);
|
NspLoader(const std::shared_ptr<vfs::Backing> &backing, const std::shared_ptr<crypto::KeyStore> &keyStore);
|
||||||
|
|
||||||
std::vector<u8> GetIcon(languages::ApplicationLanguage language) override;
|
std::vector<u8> GetIcon(language::ApplicationLanguage language) override;
|
||||||
|
|
||||||
void *LoadProcessData(const std::shared_ptr<kernel::type::KProcess> &process, const DeviceState &state) override;
|
void *LoadProcessData(const std::shared_ptr<kernel::type::KProcess> &process, const DeviceState &state) override;
|
||||||
};
|
};
|
||||||
|
@ -65,15 +65,15 @@ namespace skyline::loader {
|
|||||||
return NcaLoader::LoadExeFs(this, programNca->exeFs, process, state);
|
return NcaLoader::LoadExeFs(this, programNca->exeFs, process, state);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<u8> XciLoader::GetIcon(languages::ApplicationLanguage language) {
|
std::vector<u8> XciLoader::GetIcon(language::ApplicationLanguage language) {
|
||||||
if (controlRomFs == nullptr)
|
if (controlRomFs == nullptr)
|
||||||
return std::vector<u8>();
|
return std::vector<u8>();
|
||||||
|
|
||||||
std::shared_ptr<vfs::Backing> icon{};
|
std::shared_ptr<vfs::Backing> icon{};
|
||||||
|
|
||||||
auto iconName{fmt::format("icon_{}.dat", languages::ToString(language))};
|
auto iconName{fmt::format("icon_{}.dat", language::ToString(language))};
|
||||||
if (!(icon = controlRomFs->OpenFileUnchecked(iconName, {true, false, false}))) {
|
if (!(icon = controlRomFs->OpenFileUnchecked(iconName, {true, false, false}))) {
|
||||||
iconName = fmt::format("icon_{}.dat", languages::ToString(nacp->GetFirstSupportedTitleLanguage()));
|
iconName = fmt::format("icon_{}.dat", language::ToString(nacp->GetFirstSupportedTitleLanguage()));
|
||||||
icon = controlRomFs->OpenFileUnchecked(iconName, {true, false, false});
|
icon = controlRomFs->OpenFileUnchecked(iconName, {true, false, false});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -117,7 +117,7 @@ namespace skyline::loader {
|
|||||||
public:
|
public:
|
||||||
XciLoader(const std::shared_ptr<vfs::Backing> &backing, const std::shared_ptr<crypto::KeyStore> &keyStore);
|
XciLoader(const std::shared_ptr<vfs::Backing> &backing, const std::shared_ptr<crypto::KeyStore> &keyStore);
|
||||||
|
|
||||||
std::vector<u8> GetIcon(languages::ApplicationLanguage language) override;
|
std::vector<u8> GetIcon(language::ApplicationLanguage language) override;
|
||||||
|
|
||||||
void *LoadProcessData(const std::shared_ptr<kernel::type::KProcess> &process, const DeviceState &state) override;
|
void *LoadProcessData(const std::shared_ptr<kernel::type::KProcess> &process, const DeviceState &state) override;
|
||||||
};
|
};
|
||||||
|
@ -19,7 +19,7 @@ namespace skyline::kernel {
|
|||||||
std::shared_ptr<Settings> &settings,
|
std::shared_ptr<Settings> &settings,
|
||||||
std::string appFilesPath,
|
std::string appFilesPath,
|
||||||
std::string deviceTimeZone,
|
std::string deviceTimeZone,
|
||||||
languages::SystemLanguage systemLanguage,
|
language::SystemLanguage systemLanguage,
|
||||||
std::shared_ptr<vfs::FileSystem> assetFileSystem
|
std::shared_ptr<vfs::FileSystem> assetFileSystem
|
||||||
) : state(this, jvmManager, settings, logger),
|
) : state(this, jvmManager, settings, logger),
|
||||||
appFilesPath(std::move(appFilesPath)),
|
appFilesPath(std::move(appFilesPath)),
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <common/languages.h>
|
#include <common/language.h>
|
||||||
#include "vfs/filesystem.h"
|
#include "vfs/filesystem.h"
|
||||||
#include "loader/loader.h"
|
#include "loader/loader.h"
|
||||||
#include "services/serviceman.h"
|
#include "services/serviceman.h"
|
||||||
@ -19,7 +19,7 @@ namespace skyline::kernel {
|
|||||||
std::string deviceTimeZone; //!< The timezone name (e.g. Europe/London)
|
std::string deviceTimeZone; //!< The timezone name (e.g. Europe/London)
|
||||||
std::shared_ptr<vfs::FileSystem> assetFileSystem; //!< A filesystem to be used for accessing emulator assets (like tzdata)
|
std::shared_ptr<vfs::FileSystem> assetFileSystem; //!< A filesystem to be used for accessing emulator assets (like tzdata)
|
||||||
service::ServiceManager serviceManager;
|
service::ServiceManager serviceManager;
|
||||||
languages::SystemLanguage systemLanguage;
|
language::SystemLanguage systemLanguage;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param logger An instance of the Logger class
|
* @param logger An instance of the Logger class
|
||||||
@ -32,7 +32,7 @@ namespace skyline::kernel {
|
|||||||
std::shared_ptr<Settings> &settings,
|
std::shared_ptr<Settings> &settings,
|
||||||
std::string appFilesPath,
|
std::string appFilesPath,
|
||||||
std::string deviceTimeZone,
|
std::string deviceTimeZone,
|
||||||
languages::SystemLanguage systemLanguage,
|
language::SystemLanguage systemLanguage,
|
||||||
std::shared_ptr<vfs::FileSystem> assetFileSystem
|
std::shared_ptr<vfs::FileSystem> assetFileSystem
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -33,13 +33,13 @@ namespace skyline::service::am {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Result IApplicationFunctions::GetDesiredLanguage(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
Result IApplicationFunctions::GetDesiredLanguage(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
auto desiredLanguage{languages::GetApplicationLanguage(state.os->systemLanguage)};
|
auto desiredLanguage{language::GetApplicationLanguage(state.os->systemLanguage)};
|
||||||
|
|
||||||
// In the future we might want to trigger an UI dialog if the user selected languages is not available, for now it will use the first available
|
// In the future we might want to trigger an UI dialog if the user selected languages is not available, for now it will use the first available
|
||||||
if (((1 << static_cast<u32>(desiredLanguage)) & state.loader->nacp->nacpContents.supportedLanguageFlag) == 0)
|
if (((1 << static_cast<u32>(desiredLanguage)) & state.loader->nacp->nacpContents.supportedLanguageFlag) == 0)
|
||||||
desiredLanguage = state.loader->nacp->GetFirstSupportedLanguage();
|
desiredLanguage = state.loader->nacp->GetFirstSupportedLanguage();
|
||||||
|
|
||||||
response.Push(languages::GetLanguageCode(languages::GetSystemLanguage(desiredLanguage)));
|
response.Push(language::GetLanguageCode(language::GetSystemLanguage(desiredLanguage)));
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,25 +1,25 @@
|
|||||||
// SPDX-License-Identifier: MPL-2.0
|
// SPDX-License-Identifier: MPL-2.0
|
||||||
// Copyright © 2020 Skyline Team and Contributors (https://github.com/skyline-emu/)
|
// Copyright © 2020 Skyline Team and Contributors (https://github.com/skyline-emu/)
|
||||||
|
|
||||||
#include <common/languages.h>
|
#include <common/language.h>
|
||||||
#include "ISettingsServer.h"
|
#include "ISettingsServer.h"
|
||||||
|
|
||||||
namespace skyline::service::settings {
|
namespace skyline::service::settings {
|
||||||
ISettingsServer::ISettingsServer(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager) {}
|
ISettingsServer::ISettingsServer(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager) {}
|
||||||
|
|
||||||
Result ISettingsServer::GetAvailableLanguageCodes(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
Result ISettingsServer::GetAvailableLanguageCodes(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
request.outputBuf.at(0).copy_from(span(languages::LanguageCodeList).first(constant::OldLanguageCodeListSize));
|
request.outputBuf.at(0).copy_from(span(language::LanguageCodeList).first(constant::OldLanguageCodeListSize));
|
||||||
response.Push<i32>(constant::OldLanguageCodeListSize);
|
response.Push<i32>(constant::OldLanguageCodeListSize);
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ISettingsServer::MakeLanguageCode(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
Result ISettingsServer::MakeLanguageCode(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
response.Push<u64>(languages::LanguageCodeList.at(request.Pop<i32>()));
|
response.Push<u64>(language::LanguageCodeList.at(request.Pop<i32>()));
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ISettingsServer::GetAvailableLanguageCodes2(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
Result ISettingsServer::GetAvailableLanguageCodes2(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
request.outputBuf.at(0).copy_from(languages::LanguageCodeList);
|
request.outputBuf.at(0).copy_from(language::LanguageCodeList);
|
||||||
response.Push<i32>(constant::NewLanguageCodeListSize);
|
response.Push<i32>(constant::NewLanguageCodeListSize);
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
@ -8,7 +8,7 @@ namespace skyline::vfs {
|
|||||||
NACP::NACP(const std::shared_ptr<vfs::Backing> &backing) {
|
NACP::NACP(const std::shared_ptr<vfs::Backing> &backing) {
|
||||||
nacpContents = backing->Read<NacpData>();
|
nacpContents = backing->Read<NacpData>();
|
||||||
|
|
||||||
u32 counter{0};
|
u32 counter{};
|
||||||
for (auto &entry : nacpContents.titleEntries) {
|
for (auto &entry : nacpContents.titleEntries) {
|
||||||
if (entry.applicationName.front() != '\0') {
|
if (entry.applicationName.front() != '\0') {
|
||||||
supportedTitleLanguages |= (1 << counter);
|
supportedTitleLanguages |= (1 << counter);
|
||||||
@ -17,20 +17,20 @@ namespace skyline::vfs {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
languages::ApplicationLanguage NACP::GetFirstSupportedTitleLanguage() {
|
language::ApplicationLanguage NACP::GetFirstSupportedTitleLanguage() {
|
||||||
return static_cast<languages::ApplicationLanguage>(std::countr_zero(supportedTitleLanguages));
|
return static_cast<language::ApplicationLanguage>(std::countr_zero(supportedTitleLanguages));
|
||||||
}
|
}
|
||||||
|
|
||||||
languages::ApplicationLanguage NACP::GetFirstSupportedLanguage() {
|
language::ApplicationLanguage NACP::GetFirstSupportedLanguage() {
|
||||||
return static_cast<languages::ApplicationLanguage>(std::countr_zero(nacpContents.supportedLanguageFlag));
|
return static_cast<language::ApplicationLanguage>(std::countr_zero(nacpContents.supportedLanguageFlag));
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string NACP::GetApplicationName(languages::ApplicationLanguage language) {
|
std::string NACP::GetApplicationName(language::ApplicationLanguage language) {
|
||||||
auto applicationName{span(nacpContents.titleEntries.at(static_cast<size_t>(language)).applicationName)};
|
auto applicationName{span(nacpContents.titleEntries.at(static_cast<size_t>(language)).applicationName)};
|
||||||
return std::string(applicationName.as_string(true));
|
return std::string(applicationName.as_string(true));
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string NACP::GetApplicationPublisher(languages::ApplicationLanguage language) {
|
std::string NACP::GetApplicationPublisher(language::ApplicationLanguage language) {
|
||||||
auto applicationPublisher{span(nacpContents.titleEntries.at(static_cast<size_t>(language)).applicationPublisher)};
|
auto applicationPublisher{span(nacpContents.titleEntries.at(static_cast<size_t>(language)).applicationPublisher)};
|
||||||
return std::string(applicationPublisher.as_string(true));
|
return std::string(applicationPublisher.as_string(true));
|
||||||
}
|
}
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <common/languages.h>
|
#include <common/language.h>
|
||||||
#include "backing.h"
|
#include "backing.h"
|
||||||
|
|
||||||
namespace skyline::vfs {
|
namespace skyline::vfs {
|
||||||
@ -35,16 +35,16 @@ namespace skyline::vfs {
|
|||||||
} nacpContents{};
|
} nacpContents{};
|
||||||
static_assert(sizeof(NacpData) == 0x4000);
|
static_assert(sizeof(NacpData) == 0x4000);
|
||||||
|
|
||||||
u32 supportedTitleLanguages{0}; //<! A bitmask containing the available title entry languages and game icons
|
u32 supportedTitleLanguages{}; //<! A bitmask containing the available title entry languages and game icons
|
||||||
|
|
||||||
NACP(const std::shared_ptr<vfs::Backing> &backing);
|
NACP(const std::shared_ptr<vfs::Backing> &backing);
|
||||||
|
|
||||||
languages::ApplicationLanguage GetFirstSupportedTitleLanguage();
|
language::ApplicationLanguage GetFirstSupportedTitleLanguage();
|
||||||
|
|
||||||
languages::ApplicationLanguage GetFirstSupportedLanguage();
|
language::ApplicationLanguage GetFirstSupportedLanguage();
|
||||||
|
|
||||||
std::string GetApplicationName(languages::ApplicationLanguage language);
|
std::string GetApplicationName(language::ApplicationLanguage language);
|
||||||
|
|
||||||
std::string GetApplicationPublisher(languages::ApplicationLanguage language);
|
std::string GetApplicationPublisher(language::ApplicationLanguage language);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user