mirror of
https://github.com/yuzu-emu/yuzu-android
synced 2025-01-09 15:52:25 -08:00
118 lines
3.6 KiB
C++
118 lines
3.6 KiB
C++
// Copyright 2018 yuzu emulator team
|
|
// Licensed under GPLv2 or any later version
|
|
// Refer to the license.txt file included.
|
|
|
|
#include <chrono>
|
|
#include "common/logging/log.h"
|
|
#include "core/hle/ipc_helpers.h"
|
|
#include "core/hle/kernel/client_port.h"
|
|
#include "core/hle/kernel/client_session.h"
|
|
#include "core/hle/service/set/set.h"
|
|
#include "core/settings.h"
|
|
|
|
namespace Service::Set {
|
|
|
|
constexpr std::array<LanguageCode, 17> available_language_codes = {{
|
|
LanguageCode::JA,
|
|
LanguageCode::EN_US,
|
|
LanguageCode::FR,
|
|
LanguageCode::DE,
|
|
LanguageCode::IT,
|
|
LanguageCode::ES,
|
|
LanguageCode::ZH_CN,
|
|
LanguageCode::KO,
|
|
LanguageCode::NL,
|
|
LanguageCode::PT,
|
|
LanguageCode::RU,
|
|
LanguageCode::ZH_TW,
|
|
LanguageCode::EN_GB,
|
|
LanguageCode::FR_CA,
|
|
LanguageCode::ES_419,
|
|
LanguageCode::ZH_HANS,
|
|
LanguageCode::ZH_HANT,
|
|
}};
|
|
|
|
constexpr std::size_t pre4_0_0_max_entries = 0xF;
|
|
constexpr std::size_t post4_0_0_max_entries = 0x40;
|
|
|
|
LanguageCode GetLanguageCodeFromIndex(std::size_t index) {
|
|
return available_language_codes.at(index);
|
|
}
|
|
|
|
template <std::size_t size>
|
|
static std::array<LanguageCode, size> MakeLanguageCodeSubset() {
|
|
std::array<LanguageCode, size> arr;
|
|
std::copy_n(available_language_codes.begin(), size, arr.begin());
|
|
return arr;
|
|
}
|
|
|
|
static void PushResponseLanguageCode(Kernel::HLERequestContext& ctx, std::size_t max_size) {
|
|
IPC::ResponseBuilder rb{ctx, 3};
|
|
rb.Push(RESULT_SUCCESS);
|
|
if (available_language_codes.size() > max_size)
|
|
rb.Push(static_cast<u32>(max_size));
|
|
else
|
|
rb.Push(static_cast<u32>(available_language_codes.size()));
|
|
}
|
|
|
|
void SET::GetAvailableLanguageCodes(Kernel::HLERequestContext& ctx) {
|
|
if (available_language_codes.size() > pre4_0_0_max_entries)
|
|
ctx.WriteBuffer(MakeLanguageCodeSubset<pre4_0_0_max_entries>());
|
|
else
|
|
ctx.WriteBuffer(available_language_codes);
|
|
|
|
PushResponseLanguageCode(ctx, pre4_0_0_max_entries);
|
|
|
|
LOG_DEBUG(Service_SET, "called");
|
|
}
|
|
|
|
void SET::GetAvailableLanguageCodes2(Kernel::HLERequestContext& ctx) {
|
|
if (available_language_codes.size() > post4_0_0_max_entries)
|
|
ctx.WriteBuffer(MakeLanguageCodeSubset<post4_0_0_max_entries>());
|
|
else
|
|
ctx.WriteBuffer(available_language_codes);
|
|
|
|
PushResponseLanguageCode(ctx, post4_0_0_max_entries);
|
|
|
|
LOG_DEBUG(Service_SET, "called");
|
|
}
|
|
|
|
void SET::GetAvailableLanguageCodeCount(Kernel::HLERequestContext& ctx) {
|
|
PushResponseLanguageCode(ctx, pre4_0_0_max_entries);
|
|
|
|
LOG_DEBUG(Service_SET, "called");
|
|
}
|
|
|
|
void SET::GetAvailableLanguageCodeCount2(Kernel::HLERequestContext& ctx) {
|
|
PushResponseLanguageCode(ctx, post4_0_0_max_entries);
|
|
|
|
LOG_DEBUG(Service_SET, "called");
|
|
}
|
|
|
|
void SET::GetLanguageCode(Kernel::HLERequestContext& ctx) {
|
|
IPC::ResponseBuilder rb{ctx, 4};
|
|
rb.Push(RESULT_SUCCESS);
|
|
rb.Push(static_cast<u64>(available_language_codes[Settings::values.language_index]));
|
|
|
|
LOG_DEBUG(Service_SET, "called {}", Settings::values.language_index);
|
|
}
|
|
|
|
SET::SET() : ServiceFramework("set") {
|
|
static const FunctionInfo functions[] = {
|
|
{0, &SET::GetLanguageCode, "GetLanguageCode"},
|
|
{1, &SET::GetAvailableLanguageCodes, "GetAvailableLanguageCodes"},
|
|
{2, nullptr, "MakeLanguageCode"},
|
|
{3, &SET::GetAvailableLanguageCodeCount, "GetAvailableLanguageCodeCount"},
|
|
{4, nullptr, "GetRegionCode"},
|
|
{5, &SET::GetAvailableLanguageCodes2, "GetAvailableLanguageCodes2"},
|
|
{6, &SET::GetAvailableLanguageCodeCount2, "GetAvailableLanguageCodeCount2"},
|
|
{7, nullptr, "GetKeyCodeMap"},
|
|
{8, nullptr, "GetQuestFlag"},
|
|
};
|
|
RegisterHandlers(functions);
|
|
}
|
|
|
|
SET::~SET() = default;
|
|
|
|
} // namespace Service::Set
|