mirror of
https://git.suyu.dev/suyu/suyu.git
synced 2024-11-29 23:06:23 -05:00
shared_translation: Finish using int ids
This commit is contained in:
parent
bafd569b47
commit
cfb63c68db
6 changed files with 117 additions and 158 deletions
|
@ -191,7 +191,7 @@ public:
|
||||||
virtual bool IsEnum() const = 0;
|
virtual bool IsEnum() const = 0;
|
||||||
virtual bool RuntimeModfiable() const = 0;
|
virtual bool RuntimeModfiable() const = 0;
|
||||||
virtual void SetGlobal(bool global) {}
|
virtual void SetGlobal(bool global) {}
|
||||||
virtual u32 Id() const = 0;
|
virtual constexpr u32 Id() const = 0;
|
||||||
virtual bool UsingGlobal() const {
|
virtual bool UsingGlobal() const {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -423,7 +423,7 @@ public:
|
||||||
return std::type_index(typeid(Type));
|
return std::type_index(typeid(Type));
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual u32 Id() const override {
|
virtual constexpr u32 Id() const override {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -136,6 +136,7 @@ std::pair<QWidget*, void*> CreateWidget(Settings::BasicSetting* setting,
|
||||||
std::forward_list<std::function<void(bool)>>& apply_funcs,
|
std::forward_list<std::function<void(bool)>>& apply_funcs,
|
||||||
std::list<CheckState>& trackers, RequestType request) {
|
std::list<CheckState>& trackers, RequestType request) {
|
||||||
const auto type = setting->TypeId();
|
const auto type = setting->TypeId();
|
||||||
|
const int id = setting->Id();
|
||||||
QWidget* widget{nullptr};
|
QWidget* widget{nullptr};
|
||||||
void* extra{nullptr};
|
void* extra{nullptr};
|
||||||
|
|
||||||
|
@ -143,9 +144,8 @@ std::pair<QWidget*, void*> CreateWidget(Settings::BasicSetting* setting,
|
||||||
|
|
||||||
const auto [label, tooltip] = [&]() {
|
const auto [label, tooltip] = [&]() {
|
||||||
const auto& setting_label = setting->GetLabel();
|
const auto& setting_label = setting->GetLabel();
|
||||||
if (translations.contains(setting_label)) {
|
if (translations.contains(id)) {
|
||||||
return std::pair{translations.at(setting_label).first,
|
return std::pair{translations.at(id).first, translations.at(id).second};
|
||||||
translations.at(setting_label).second};
|
|
||||||
}
|
}
|
||||||
LOG_ERROR(Frontend, "Translation table lacks entry for \"{}\"", setting_label);
|
LOG_ERROR(Frontend, "Translation table lacks entry for \"{}\"", setting_label);
|
||||||
return std::pair{QString::fromStdString(setting_label), QStringLiteral("")};
|
return std::pair{QString::fromStdString(setting_label), QStringLiteral("")};
|
||||||
|
|
|
@ -214,13 +214,13 @@ void ConfigureGraphics::SetConfiguration() {
|
||||||
QLayout& api_layout = *ui->api_widget->layout();
|
QLayout& api_layout = *ui->api_widget->layout();
|
||||||
QLayout& graphics_layout = *ui->graphics_widget->layout();
|
QLayout& graphics_layout = *ui->graphics_widget->layout();
|
||||||
|
|
||||||
std::map<std::string, QWidget*> hold_graphics;
|
std::map<bool, std::map<std::string, QWidget*>> hold_graphics;
|
||||||
|
|
||||||
for (const auto setting : Settings::values.linkage.by_category[Settings::Category::Renderer]) {
|
for (const auto setting : Settings::values.linkage.by_category[Settings::Category::Renderer]) {
|
||||||
const auto& setting_label = setting->GetLabel();
|
const auto& setting_label = setting->GetLabel();
|
||||||
|
|
||||||
auto [widget, extra] = [&]() {
|
auto [widget, extra] = [&]() {
|
||||||
if (setting_label == "vulkan_device") {
|
if (setting->Id() == Settings::values.vulkan_device.Id()) {
|
||||||
return ConfigurationShared::CreateWidget(
|
return ConfigurationShared::CreateWidget(
|
||||||
setting, translations, this, runtime_lock, apply_funcs, trackers,
|
setting, translations, this, runtime_lock, apply_funcs, trackers,
|
||||||
ConfigurationShared::RequestType::ComboBox);
|
ConfigurationShared::RequestType::ComboBox);
|
||||||
|
@ -233,28 +233,29 @@ void ConfigureGraphics::SetConfiguration() {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (setting_label == "backend") {
|
if (setting->Id() == Settings::values.vulkan_device.Id()) {
|
||||||
api_layout.addWidget(widget);
|
api_layout.addWidget(widget);
|
||||||
api_combobox = reinterpret_cast<QComboBox*>(extra);
|
api_combobox = reinterpret_cast<QComboBox*>(extra);
|
||||||
} else if (setting_label == "vulkan_device") {
|
} else if (setting->Id() == Settings::values.vulkan_device.Id()) {
|
||||||
api_layout.addWidget(widget);
|
api_layout.addWidget(widget);
|
||||||
vulkan_device_combobox = reinterpret_cast<QComboBox*>(extra);
|
vulkan_device_combobox = reinterpret_cast<QComboBox*>(extra);
|
||||||
vulkan_device_widget = widget;
|
vulkan_device_widget = widget;
|
||||||
} else if (setting_label == "shader_backend") {
|
} else if (setting->Id() == Settings::values.shader_backend.Id()) {
|
||||||
api_layout.addWidget(widget);
|
api_layout.addWidget(widget);
|
||||||
shader_backend_combobox = reinterpret_cast<QComboBox*>(extra);
|
shader_backend_combobox = reinterpret_cast<QComboBox*>(extra);
|
||||||
shader_backend_widget = widget;
|
shader_backend_widget = widget;
|
||||||
} else {
|
} else if (setting->Id() == Settings::values.vsync_mode.Id()) {
|
||||||
hold_graphics.insert(std::pair(setting_label, widget));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (setting_label == "use_vsync") {
|
|
||||||
vsync_mode_combobox = reinterpret_cast<QComboBox*>(extra);
|
vsync_mode_combobox = reinterpret_cast<QComboBox*>(extra);
|
||||||
|
hold_graphics[setting->IsEnum()][setting_label] = widget;
|
||||||
|
} else {
|
||||||
|
hold_graphics[setting->IsEnum()][setting_label] = widget;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const auto& [label, widget] : hold_graphics) {
|
for (const auto& [_, settings] : hold_graphics) {
|
||||||
graphics_layout.addWidget(widget);
|
for (const auto& [label, widget] : settings) {
|
||||||
|
graphics_layout.addWidget(widget);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// ui->api_widget->setEnabled(runtime_lock);
|
// ui->api_widget->setEnabled(runtime_lock);
|
||||||
|
|
|
@ -45,7 +45,7 @@ void ConfigureGraphicsAdvanced::SetConfiguration() {
|
||||||
layout.addWidget(widget);
|
layout.addWidget(widget);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (setting->GetLabel() == "enable_compute_pipelines") {
|
if (setting->Id() == Settings::values.enable_compute_pipelines.Id()) {
|
||||||
checkbox_enable_compute_pipelines = widget;
|
checkbox_enable_compute_pipelines = widget;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,196 +18,111 @@ std::unique_ptr<TranslationMap> InitializeTranslations(QWidget* parent) {
|
||||||
std::unique_ptr<TranslationMap> translations = std::make_unique<TranslationMap>();
|
std::unique_ptr<TranslationMap> translations = std::make_unique<TranslationMap>();
|
||||||
const auto& tr = [parent](const char* text) -> QString { return parent->tr(text); };
|
const auto& tr = [parent](const char* text) -> QString { return parent->tr(text); };
|
||||||
|
|
||||||
#define INSERT(LABEL, NAME, TOOLTIP) \
|
#define INSERT(ID, NAME, TOOLTIP) \
|
||||||
translations->insert(std::pair{(LABEL), std::pair{tr((NAME)), tr((TOOLTIP))}})
|
translations->insert(std::pair{Settings::values.ID.Id(), std::pair{tr((NAME)), tr((TOOLTIP))}})
|
||||||
|
|
||||||
// A setting can be ignored by giving it a blank name
|
// A setting can be ignored by giving it a blank name
|
||||||
|
|
||||||
// Audio
|
// Audio
|
||||||
INSERT("output_engine", "Output Engine:", "");
|
INSERT(sink_id, "Output Engine:", "");
|
||||||
INSERT("output_device", "Output Device:", "");
|
INSERT(audio_output_device_id, "Output Device:", "");
|
||||||
INSERT("input_device", "Input Device:", "");
|
INSERT(audio_input_device_id, "Input Device:", "");
|
||||||
INSERT("audio_muted", "Mute audio when in background", "");
|
INSERT(audio_muted, "Mute audio when in background", "");
|
||||||
INSERT("volume", "Volume:", "");
|
INSERT(volume, "Volume:", "");
|
||||||
|
|
||||||
// Core
|
// Core
|
||||||
INSERT("use_multi_core", "Multicore CPU Emulation", "");
|
INSERT(use_multi_core, "Multicore CPU Emulation", "");
|
||||||
INSERT("use_unsafe_extended_memory_layout", "Unsafe extended memory layout (8GB DRAM)", "");
|
INSERT(use_unsafe_extended_memory_layout, "Unsafe extended memory layout (8GB DRAM)", "");
|
||||||
|
|
||||||
// Cpu
|
// Cpu
|
||||||
INSERT("cpu_accuracy", "Accuracy:", "");
|
INSERT(cpu_accuracy, "Accuracy:", "");
|
||||||
INSERT("cpu_accuracy_first_time", "", "");
|
INSERT(cpu_accuracy_first_time, "", "");
|
||||||
|
|
||||||
// Cpu Debug
|
// Cpu Debug
|
||||||
INSERT("cpu_debug_mode", "Enable CPU Debugging", "");
|
|
||||||
INSERT("cpuopt_page_tables", "Enable inline page tables", "");
|
|
||||||
INSERT("cpuopt_block_linking", "Enable block linking", "");
|
|
||||||
INSERT("cpuopt_return_stack_buffer", "Enable return stack buffer", "");
|
|
||||||
INSERT("cpuopt_fast_dispatcher", "Enable fast dispatcher", "");
|
|
||||||
INSERT("cpuopt_context_elimination", "Enable context elimination", "");
|
|
||||||
INSERT("cpuopt_const_prop", "Enable constant propagation", "");
|
|
||||||
INSERT("cpuopt_misc_ir", "Enable miscellaneous optimizations", "");
|
|
||||||
INSERT("cpuopt_reduce_misalign_checks", "Enable misalignment check reduction", "");
|
|
||||||
INSERT("cpuopt_fastmem", "Enable Host MMU Emulation (general memory instructions)", "");
|
|
||||||
INSERT("cpuopt_fastmem_exclusives", "Enable Host MMU Emulation (exclusive memory instructions)",
|
|
||||||
"");
|
|
||||||
INSERT("cpuopt_recompile_exclusives", "Enable recompilation of exlucsive memory instructions",
|
|
||||||
"");
|
|
||||||
INSERT("cpuopt_ignore_memory_aborts", "Enable fallbacks for invalid memory accesses", "");
|
|
||||||
|
|
||||||
// Cpu Unsafe
|
// Cpu Unsafe
|
||||||
INSERT("cpuopt_unsafe_unfuse_fma", "Unfuse FMA (improve performance on CPUs without FMA)", "");
|
INSERT(cpuopt_unsafe_unfuse_fma, "Unfuse FMA (improve performance on CPUs without FMA)", "");
|
||||||
INSERT("cpuopt_unsafe_reduce_fp_error", "Faster FRSQRTE and FRECPE", "");
|
INSERT(cpuopt_unsafe_reduce_fp_error, "Faster FRSQRTE and FRECPE", "");
|
||||||
INSERT("cpuopt_unsafe_ignore_standard_fpcr", "Faster ASIMD instructions (32 bits only)", "");
|
INSERT(cpuopt_unsafe_ignore_standard_fpcr, "Faster ASIMD instructions (32 bits only)", "");
|
||||||
INSERT("cpuopt_unsafe_inaccurate_nan", "Inaccurate NaN handling", "");
|
INSERT(cpuopt_unsafe_inaccurate_nan, "Inaccurate NaN handling", "");
|
||||||
INSERT("cpuopt_unsafe_fastmem_check", "Disable address space checks", "");
|
INSERT(cpuopt_unsafe_fastmem_check, "Disable address space checks", "");
|
||||||
INSERT("cpuopt_unsafe_ignore_global_monitor", "Ignore global monitor", "");
|
INSERT(cpuopt_unsafe_ignore_global_monitor, "Ignore global monitor", "");
|
||||||
|
|
||||||
// Renderer
|
// Renderer
|
||||||
INSERT("backend", "API:", "");
|
INSERT(renderer_backend, "API:", "");
|
||||||
INSERT("vulkan_device", "Device:", "");
|
INSERT(vulkan_device, "Device:", "");
|
||||||
INSERT("shader_backend", "Shader Backend:", "");
|
INSERT(shader_backend, "Shader Backend:", "");
|
||||||
INSERT("resolution_setup", "Resolution:", "");
|
INSERT(resolution_setup, "Resolution:", "");
|
||||||
INSERT("scaling_filter", "Window Adapting Filter:", "");
|
INSERT(scaling_filter, "Window Adapting Filter:", "");
|
||||||
INSERT("fsr_sharpening_slider", "AMD FidelityFX™ Super Resolution Sharpness:", "");
|
INSERT(fsr_sharpening_slider, "AMD FidelityFX™ Super Resolution Sharpness:", "");
|
||||||
INSERT("anti_aliasing", "Anti-Aliasing Method:", "");
|
INSERT(anti_aliasing, "Anti-Aliasing Method:", "");
|
||||||
INSERT("fullscreen_mode", "Fullscreen Mode:", "");
|
INSERT(fullscreen_mode, "Fullscreen Mode:", "");
|
||||||
INSERT("aspect_ratio", "Aspect Ratio:", "");
|
INSERT(aspect_ratio, "Aspect Ratio:", "");
|
||||||
INSERT("use_disk_shader_cache", "Use disk pipeline cache", "");
|
INSERT(use_disk_shader_cache, "Use disk pipeline cache", "");
|
||||||
INSERT("use_asynchronous_gpu_emulation", "Use asynchronous GPU emulation", "");
|
INSERT(use_asynchronous_gpu_emulation, "Use asynchronous GPU emulation", "");
|
||||||
INSERT("nvdec_emulation", "NVDEC emulation:", "");
|
INSERT(nvdec_emulation, "NVDEC emulation:", "");
|
||||||
INSERT("accelerate_astc", "ASTC Decoding Method:", "");
|
INSERT(accelerate_astc, "ASTC Decoding Method:", "");
|
||||||
INSERT(
|
INSERT(
|
||||||
"use_vsync", "VSync Mode:",
|
vsync_mode, "VSync Mode:",
|
||||||
"FIFO (VSync) does not drop frames or exhibit tearing but is limited by the screen refresh "
|
"FIFO (VSync) does not drop frames or exhibit tearing but is limited by the screen refresh "
|
||||||
"rate. FIFO Relaxed is similar to FIFO but allows tearing as it recovers from a slow down. "
|
"rate. FIFO Relaxed is similar to FIFO but allows tearing as it recovers from a slow down. "
|
||||||
"Mailbox can have lower latency than FIFO and does not tear but may drop frames. Immediate "
|
"Mailbox can have lower latency than FIFO and does not tear but may drop frames. Immediate "
|
||||||
"(no synchronization) just presents whatever is available and can exhibit tearing.");
|
"(no synchronization) just presents whatever is available and can exhibit tearing.");
|
||||||
INSERT("bg_red", "", "");
|
INSERT(bg_red, "", "");
|
||||||
INSERT("bg_green", "", "");
|
INSERT(bg_green, "", "");
|
||||||
INSERT("bg_blue", "", "");
|
INSERT(bg_blue, "", "");
|
||||||
|
|
||||||
// Renderer (Advanced Graphics)
|
// Renderer (Advanced Graphics)
|
||||||
INSERT("async_presentation", "Enable asynchronous presentation (Vulkan only)", "");
|
INSERT(async_presentation, "Enable asynchronous presentation (Vulkan only)", "");
|
||||||
INSERT("force_max_clock", "Force maximum clocks (Vulkan only)",
|
INSERT(renderer_force_max_clock, "Force maximum clocks (Vulkan only)",
|
||||||
"Runs work in the background while waiting for graphics commands to keep the GPU from "
|
"Runs work in the background while waiting for graphics commands to keep the GPU from "
|
||||||
"lowering its clock speed.");
|
"lowering its clock speed.");
|
||||||
INSERT("max_anisotropy", "Anisotropic Filtering:", "");
|
INSERT(max_anisotropy, "Anisotropic Filtering:", "");
|
||||||
INSERT("gpu_accuracy", "Accuracy Level:", "");
|
INSERT(gpu_accuracy, "Accuracy Level:", "");
|
||||||
INSERT("use_asynchronous_shaders", "Use asynchronous shader building (Hack)",
|
INSERT(use_asynchronous_shaders, "Use asynchronous shader building (Hack)",
|
||||||
"Enables asynchronous shader compilation, which may reduce shader stutter. This feature "
|
"Enables asynchronous shader compilation, which may reduce shader stutter. This feature "
|
||||||
"is experimental.");
|
"is experimental.");
|
||||||
INSERT("use_fast_gpu_time", "Use Fast GPU Time (Hack)",
|
INSERT(use_fast_gpu_time, "Use Fast GPU Time (Hack)",
|
||||||
"Enables Fast GPU Time. This option will force most games to run at their highest "
|
"Enables Fast GPU Time. This option will force most games to run at their highest "
|
||||||
"native resolution.");
|
"native resolution.");
|
||||||
INSERT("use_vulkan_driver_pipeline_cache", "Use Vulkan pipeline cache",
|
INSERT(use_vulkan_driver_pipeline_cache, "Use Vulkan pipeline cache",
|
||||||
"Enables GPU vendor-specific pipeline cache. This option can improve shader loading "
|
"Enables GPU vendor-specific pipeline cache. This option can improve shader loading "
|
||||||
"time significantly in cases where the Vulkan driver does not store pipeline cache "
|
"time significantly in cases where the Vulkan driver does not store pipeline cache "
|
||||||
"files internally.");
|
"files internally.");
|
||||||
INSERT("enable_compute_pipelines", "Enable Compute Pipelines (Intel Vulkan Only)",
|
INSERT(enable_compute_pipelines, "Enable Compute Pipelines (Intel Vulkan Only)",
|
||||||
"Enable compute pipelines, required by some games.\nThis setting only exists for Intel "
|
"Enable compute pipelines, required by some games.\nThis setting only exists for Intel "
|
||||||
"proprietary drivers, and may crash if enabled.\nCompute pipelines are always enabled "
|
"proprietary drivers, and may crash if enabled.\nCompute pipelines are always enabled "
|
||||||
"on all other drivers.");
|
"on all other drivers.");
|
||||||
|
|
||||||
// Renderer (Debug)
|
// Renderer (Debug)
|
||||||
INSERT("debug", "Enable Graphics Debugging",
|
|
||||||
"When checked, the graphics API enters a slower debugging mode");
|
|
||||||
INSERT("shader_feedback", "Enable Shader Feedback",
|
|
||||||
"When checked, yuzu will log statistics about the compiled pipeline cache");
|
|
||||||
INSERT("nsight_aftermath", "Enable Nsight Aftermath",
|
|
||||||
"When checked, it enables Nsight Aftermath crash dumps");
|
|
||||||
INSERT("disable_shader_loop_safety_checks", "Disable Loop safety checks",
|
|
||||||
"When checked, it executes shaders without loop logic changes");
|
|
||||||
|
|
||||||
// Renderer (General)
|
// Renderer (General)
|
||||||
INSERT("use_speed_limit", "Limit Speed Percent", "");
|
INSERT(use_speed_limit, "Limit Speed Percent", "");
|
||||||
INSERT("speed_limit", "Limit Speed Percent", "");
|
INSERT(speed_limit, "Limit Speed Percent", "");
|
||||||
|
|
||||||
// System
|
// System
|
||||||
INSERT("rng_seed_enabled", "RNG Seed", "");
|
INSERT(rng_seed_enabled, "RNG Seed", "");
|
||||||
INSERT("rng_seed", "RNG Seed", "");
|
INSERT(rng_seed, "RNG Seed", "");
|
||||||
INSERT("device_name", "Device Name", "");
|
INSERT(device_name, "Device Name", "");
|
||||||
INSERT("custom_rtc_enabled", "Custom RTC", "");
|
INSERT(custom_rtc_enabled, "Custom RTC", "");
|
||||||
INSERT("custom_rtc", "Custom RTC", "");
|
INSERT(custom_rtc, "Custom RTC", "");
|
||||||
INSERT("language_index", "Language:", "");
|
INSERT(language_index, "Language:", "");
|
||||||
INSERT("region_index", "Region:", "");
|
INSERT(region_index, "Region:", "");
|
||||||
INSERT("time_zone_index", "Time Zone:", "");
|
INSERT(time_zone_index, "Time Zone:", "");
|
||||||
INSERT("sound_index", "Sound Output Mode:", "");
|
INSERT(sound_index, "Sound Output Mode:", "");
|
||||||
INSERT("use_docked_mode", "", "");
|
INSERT(use_docked_mode, "", "");
|
||||||
|
|
||||||
// Controls
|
// Controls
|
||||||
INSERT("enable_raw_input", "", "");
|
|
||||||
INSERT("controller_navigation", "", "");
|
|
||||||
INSERT("enable_joycon_driver", "", "");
|
|
||||||
INSERT("enable_procon_driver", "", "");
|
|
||||||
INSERT("vibration_enabled", "", "");
|
|
||||||
INSERT("enable_accurate_vibrations", "", "");
|
|
||||||
INSERT("motion_enabled", "", "");
|
|
||||||
INSERT("udp_input_servers", "", "");
|
|
||||||
INSERT("enable_udp_controller", "", "");
|
|
||||||
INSERT("pause_tas_on_load", "", "");
|
|
||||||
INSERT("tas_enable", "", "");
|
|
||||||
INSERT("tas_loop", "", "");
|
|
||||||
INSERT("mouse_panning", "", "");
|
|
||||||
INSERT("mouse_panning_sensitivity", "", "");
|
|
||||||
INSERT("mouse_enabled", "", "");
|
|
||||||
INSERT("emulate_analog_keyboard", "", "");
|
|
||||||
INSERT("keyboard_enabled", "", "");
|
|
||||||
INSERT("debug_pad_enabled", "", "");
|
|
||||||
INSERT("touch_device", "", "");
|
|
||||||
INSERT("touch_from_button_map", "", "");
|
|
||||||
INSERT("enable_ring_controller", "", "");
|
|
||||||
INSERT("enable_ir_sensor", "", "");
|
|
||||||
INSERT("ir_sensor_device", "", "");
|
|
||||||
|
|
||||||
// Data Storage
|
// Data Storage
|
||||||
INSERT("use_virtual_sd", "", "");
|
|
||||||
INSERT("gamecard_inserted", "Inserted", "");
|
|
||||||
INSERT("gamecard_current_game", "Current Game", "");
|
|
||||||
INSERT("gamecard_path", "Path", "");
|
|
||||||
|
|
||||||
// Debugging
|
// Debugging
|
||||||
INSERT("use_gdbstub", "Enable GDB Stub", "");
|
|
||||||
INSERT("gdbstub_port", "Port:", "");
|
|
||||||
INSERT("program_args", "Arguments String", "");
|
|
||||||
INSERT("dump_exefs", "Dump ExeFS", "");
|
|
||||||
INSERT("dump_nso", "Dump Decompressed NSOs", "");
|
|
||||||
INSERT("enable_fs_access_log", "Enable FS Access Log", "");
|
|
||||||
INSERT("reporting_services", "Enable Verbose Repoting Services**", "");
|
|
||||||
INSERT("quest_flag", "Kiosk (Quest) Mode", "");
|
|
||||||
INSERT("extended_logging", "Enable Extended Logging**",
|
|
||||||
"When checked, the max size of the log increases from 100 MB to 1 GB");
|
|
||||||
INSERT("use_debug_asserts", "Enable Debug Asserts", "");
|
|
||||||
INSERT("use_auto_stub", "Enable Auto-Stub**", "");
|
|
||||||
INSERT("enable_all_controllers", "Enable All Controller Types", "");
|
|
||||||
INSERT("create_crash_dumps", "Create Minidump After Crash", "");
|
|
||||||
INSERT("perform_vulkan_check", "Perform Startup Vulkan Check",
|
|
||||||
"Enables yuzu to check for a working Vulkan environment when the program starts up. "
|
|
||||||
"Disable this if this is causing issues with external programs seeing yuzu.");
|
|
||||||
INSERT("log_filter", "Global Log Filter", "");
|
|
||||||
INSERT("use_dev_keys", "", "");
|
|
||||||
|
|
||||||
// Debugging Graphics
|
// Debugging Graphics
|
||||||
INSERT("dump_shaders", "Dump Game Shaders",
|
|
||||||
"When checked, it will dump all the original assembler shaders from the disk shader "
|
|
||||||
"cache or game as found");
|
|
||||||
INSERT("disable_macro_jit", "Disable Macro JIT",
|
|
||||||
"When checked, it disables the macro Just In Time compiler. Enabling this makes games "
|
|
||||||
"run slower");
|
|
||||||
INSERT(
|
|
||||||
"disable_macro_hle", "Disable Macro HLE",
|
|
||||||
"When checked, it disables the macro HLE functions. Enabling this makes games run slower");
|
|
||||||
INSERT("dump_macros", "Dump Maxwell Macros",
|
|
||||||
"When checked, it will dump all the macro programs of the GPU");
|
|
||||||
|
|
||||||
// Network
|
// Network
|
||||||
INSERT("network_interface", "Network Interface", "");
|
|
||||||
|
|
||||||
// Web Service
|
// Web Service
|
||||||
INSERT("enable_telemetry", "Share anonymous usage data with the yuzu team", "");
|
|
||||||
INSERT("web_api_url", "", "");
|
|
||||||
INSERT("yuzu_username", "", "");
|
|
||||||
INSERT("yuzu_token", "Token:", "");
|
|
||||||
|
|
||||||
#undef INSERT
|
#undef INSERT
|
||||||
|
|
||||||
|
@ -241,6 +156,49 @@ std::forward_list<QString> ComboboxEnumeration(std::type_index type, QWidget* pa
|
||||||
tr("High"),
|
tr("High"),
|
||||||
tr("Extreme"),
|
tr("Extreme"),
|
||||||
};
|
};
|
||||||
|
} else if (type == typeid(Settings::CPUAccuracy)) {
|
||||||
|
return {
|
||||||
|
tr("Auto"),
|
||||||
|
tr("Accurate"),
|
||||||
|
tr("Unsafe"),
|
||||||
|
tr("Paranoid (disables most optimizations)"),
|
||||||
|
};
|
||||||
|
} else if (type == typeid(Settings::FullscreenMode)) {
|
||||||
|
return {
|
||||||
|
tr("Borderless Windowed"),
|
||||||
|
tr("Exclusive Fullscreen"),
|
||||||
|
};
|
||||||
|
} else if (type == typeid(Settings::NvdecEmulation)) {
|
||||||
|
return {
|
||||||
|
tr("No Video Output"),
|
||||||
|
tr("CPU Video Decoding"),
|
||||||
|
tr("GPU Video Decoding (Default)"),
|
||||||
|
};
|
||||||
|
} else if (type == typeid(Settings::ResolutionSetup)) {
|
||||||
|
return {
|
||||||
|
tr("0.5X (360p/540p) [EXPERIMENTAL]"),
|
||||||
|
tr("0.75X (540p/810p) [EXPERIMENTAL]"),
|
||||||
|
tr("1X (720p/1080p)"),
|
||||||
|
tr("1.5X (1080p/1620p) [EXPERIMENTAL]"),
|
||||||
|
tr("2X (1440p/2160p)"),
|
||||||
|
tr("3X (2160p/3240p)"),
|
||||||
|
tr("4X (2880p/4320p)"),
|
||||||
|
tr("5X (3600p/5400p)"),
|
||||||
|
tr("6X (4320p/6480p)"),
|
||||||
|
tr("7X (5040p/7560p)"),
|
||||||
|
tr("8X (5760p/8640p)"),
|
||||||
|
};
|
||||||
|
} else if (type == typeid(Settings::ScalingFilter)) {
|
||||||
|
return {
|
||||||
|
tr("Nearest Neighbor"), tr("Bilinear"), tr("Bicubic"),
|
||||||
|
tr("Gaussian"), tr("ScaleForce"), tr("AMD FidelityFX™️ Super Resolution"),
|
||||||
|
};
|
||||||
|
} else if (type == typeid(Settings::AntiAliasing)) {
|
||||||
|
return {
|
||||||
|
tr("None"),
|
||||||
|
tr("FXAA"),
|
||||||
|
tr("SMAA"),
|
||||||
|
};
|
||||||
} else if (type == typeid(Settings::AnisotropyMode)) {
|
} else if (type == typeid(Settings::AnisotropyMode)) {
|
||||||
return {
|
return {
|
||||||
tr("Automatic"), tr("Default"), tr("2x"), tr("4x"), tr("8x"), tr("16x"),
|
tr("Automatic"), tr("Default"), tr("2x"), tr("4x"), tr("8x"), tr("16x"),
|
||||||
|
|
|
@ -12,7 +12,7 @@
|
||||||
class QWidget;
|
class QWidget;
|
||||||
|
|
||||||
namespace ConfigurationShared {
|
namespace ConfigurationShared {
|
||||||
using TranslationMap = std::map<std::string, std::pair<QString, QString>>;
|
using TranslationMap = std::map<u32, std::pair<QString, QString>>;
|
||||||
|
|
||||||
std::unique_ptr<TranslationMap> InitializeTranslations(QWidget* parent);
|
std::unique_ptr<TranslationMap> InitializeTranslations(QWidget* parent);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue