Merge pull request #8362 from GerbilSoft/feature/string-optimizations.2019-09-11

Various string and other optimizations
This commit is contained in:
Pierre Bourdon 2019-12-30 10:59:14 +01:00 committed by GitHub
commit 7a6a4510f6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
24 changed files with 216 additions and 181 deletions

View File

@ -147,7 +147,7 @@ void WaveFileWriter::AddStereoSamplesBE(const short* sample_data, u32 count, int
{ {
Stop(); Stop();
file_index++; file_index++;
std::stringstream filename; std::ostringstream filename;
filename << File::GetUserPath(D_DUMPAUDIO_IDX) << basename << file_index << ".wav"; filename << File::GetUserPath(D_DUMPAUDIO_IDX) << basename << file_index << ".wav";
Start(filename.str(), sample_rate); Start(filename.str(), sample_rate);
current_sample_rate = sample_rate; current_sample_rate = sample_rate;

View File

@ -104,7 +104,7 @@ std::vector<std::string> Watches::SaveToStrings() const
std::vector<std::string> watches; std::vector<std::string> watches;
for (const auto& watch : m_watches) for (const auto& watch : m_watches)
{ {
std::stringstream ss; std::ostringstream ss;
ss << std::hex << watch.address << " " << watch.name; ss << std::hex << watch.address << " " << watch.name;
watches.push_back(ss.str()); watches.push_back(ss.str());
} }

View File

@ -2198,7 +2198,7 @@ static void InitExtensionList(GLContext* context)
default: default:
case 450: case 450:
{ {
std::string gl450exts[] = { static const char* const gl450exts[] = {
"GL_ARB_ES3_1_compatibility", "GL_ARB_ES3_1_compatibility",
"GL_ARB_clip_control", "GL_ARB_clip_control",
"GL_ARB_conditional_render_inverted", "GL_ARB_conditional_render_inverted",
@ -2216,7 +2216,7 @@ static void InitExtensionList(GLContext* context)
} }
case 440: case 440:
{ {
std::string gl440exts[] = { static const char* const gl440exts[] = {
"GL_ARB_buffer_storage", "GL_ARB_buffer_storage",
"GL_ARB_clear_texture", "GL_ARB_clear_texture",
"GL_ARB_enhanced_layouts", "GL_ARB_enhanced_layouts",
@ -2232,7 +2232,7 @@ static void InitExtensionList(GLContext* context)
} }
case 430: case 430:
{ {
std::string gl430exts[] = { static const char* const gl430exts[] = {
"GL_ARB_ES3_compatibility", "GL_ARB_ES3_compatibility",
"GL_ARB_arrays_of_arrays", "GL_ARB_arrays_of_arrays",
"GL_ARB_clear_buffer_object", "GL_ARB_clear_buffer_object",
@ -2260,7 +2260,7 @@ static void InitExtensionList(GLContext* context)
} }
case 420: case 420:
{ {
std::string gl420exts[] = { static const char* const gl420exts[] = {
"GL_ARB_base_instance", "GL_ARB_base_instance",
"GL_ARB_compressed_texture_pixel_storage", "GL_ARB_compressed_texture_pixel_storage",
"GL_ARB_conservative_depth", "GL_ARB_conservative_depth",
@ -2280,7 +2280,7 @@ static void InitExtensionList(GLContext* context)
} }
case 410: case 410:
{ {
std::string gl410exts[] = { static const char* const gl410exts[] = {
"GL_ARB_ES2_compatibility", "GL_ARB_ES2_compatibility",
"GL_ARB_get_program_binary", "GL_ARB_get_program_binary",
"GL_ARB_separate_shader_objects", "GL_ARB_separate_shader_objects",
@ -2294,7 +2294,7 @@ static void InitExtensionList(GLContext* context)
} }
case 400: case 400:
{ {
std::string gl400exts[] = { static const char* const gl400exts[] = {
"GL_ARB_draw_indirect", "GL_ARB_draw_indirect",
"GL_ARB_gpu_shader5", "GL_ARB_gpu_shader5",
"GL_ARB_gpu_shader_fp64", "GL_ARB_gpu_shader_fp64",
@ -2314,7 +2314,7 @@ static void InitExtensionList(GLContext* context)
} }
case 330: case 330:
{ {
std::string gl330exts[] = { static const char* const gl330exts[] = {
"GL_ARB_shader_bit_encoding", "GL_ARB_shader_bit_encoding",
"GL_ARB_blend_func_extended", "GL_ARB_blend_func_extended",
"GL_ARB_explicit_attrib_location", "GL_ARB_explicit_attrib_location",
@ -2332,7 +2332,7 @@ static void InitExtensionList(GLContext* context)
} }
case 320: case 320:
{ {
std::string gl320exts[] = { static const char* const gl320exts[] = {
"GL_ARB_geometry_shader4", "GL_ARB_geometry_shader4",
"GL_ARB_sync", "GL_ARB_sync",
"GL_ARB_vertex_array_bgra", "GL_ARB_vertex_array_bgra",
@ -2350,7 +2350,7 @@ static void InitExtensionList(GLContext* context)
case 310: case 310:
{ {
// Can't add NV_primitive_restart since function name changed // Can't add NV_primitive_restart since function name changed
std::string gl310exts[] = { static const char* const gl310exts[] = {
"GL_ARB_draw_instanced", "GL_ARB_draw_instanced",
"GL_ARB_copy_buffer", "GL_ARB_copy_buffer",
"GL_ARB_texture_buffer_object", "GL_ARB_texture_buffer_object",
@ -2366,7 +2366,7 @@ static void InitExtensionList(GLContext* context)
{ {
// Quite a lot of these had their names changed when merged in to core // Quite a lot of these had their names changed when merged in to core
// Disable the ones that have // Disable the ones that have
std::string gl300exts[] = { static const char* const gl300exts[] = {
"GL_ARB_map_buffer_range", "GL_ARB_map_buffer_range",
"GL_ARB_color_buffer_float", "GL_ARB_color_buffer_float",
"GL_ARB_texture_float", "GL_ARB_texture_float",

View File

@ -398,7 +398,7 @@ std::string JoinStrings(const std::vector<std::string>& strings, const std::stri
if (strings.empty()) if (strings.empty())
return ""; return "";
std::stringstream res; std::ostringstream res;
std::copy(strings.begin(), strings.end(), std::copy(strings.begin(), strings.end(),
std::ostream_iterator<std::string>(res, delimiter.c_str())); std::ostream_iterator<std::string>(res, delimiter.c_str()));

View File

@ -22,134 +22,136 @@ bool IsSettingSaveable(const Config::ConfigLocation& config_location)
if (config_location.system == Config::System::Logger) if (config_location.system == Config::System::Logger)
return true; return true;
if (config_location.system == Config::System::Main && config_location.section == "NetPlay") if (config_location.system == Config::System::Main)
{
if (config_location.section == "NetPlay" || config_location.section == "General")
return true; return true;
}
if (config_location.system == Config::System::Main && config_location.section == "General") static constexpr std::array<const Config::ConfigLocation*, 92> s_setting_saveable = {
return true;
const static std::vector<Config::ConfigLocation> s_setting_saveable{
// Main.Core // Main.Core
Config::MAIN_DEFAULT_ISO.location, &Config::MAIN_DEFAULT_ISO.location,
Config::MAIN_MEMCARD_A_PATH.location, &Config::MAIN_MEMCARD_A_PATH.location,
Config::MAIN_MEMCARD_B_PATH.location, &Config::MAIN_MEMCARD_B_PATH.location,
Config::MAIN_AUTO_DISC_CHANGE.location, &Config::MAIN_AUTO_DISC_CHANGE.location,
Config::MAIN_DPL2_DECODER.location, &Config::MAIN_DPL2_DECODER.location,
Config::MAIN_DPL2_QUALITY.location, &Config::MAIN_DPL2_QUALITY.location,
// Main.Display // Main.Display
Config::MAIN_FULLSCREEN_DISPLAY_RES.location, &Config::MAIN_FULLSCREEN_DISPLAY_RES.location,
Config::MAIN_FULLSCREEN.location, &Config::MAIN_FULLSCREEN.location,
Config::MAIN_RENDER_TO_MAIN.location, &Config::MAIN_RENDER_TO_MAIN.location,
Config::MAIN_RENDER_WINDOW_AUTOSIZE.location, &Config::MAIN_RENDER_WINDOW_AUTOSIZE.location,
Config::MAIN_KEEP_WINDOW_ON_TOP.location, &Config::MAIN_KEEP_WINDOW_ON_TOP.location,
Config::MAIN_DISABLE_SCREENSAVER.location, &Config::MAIN_DISABLE_SCREENSAVER.location,
// Graphics.Hardware // Graphics.Hardware
Config::GFX_VSYNC.location, &Config::GFX_VSYNC.location,
Config::GFX_ADAPTER.location, &Config::GFX_ADAPTER.location,
// Graphics.Settings // Graphics.Settings
Config::GFX_WIDESCREEN_HACK.location, &Config::GFX_WIDESCREEN_HACK.location,
Config::GFX_ASPECT_RATIO.location, &Config::GFX_ASPECT_RATIO.location,
Config::GFX_CROP.location, &Config::GFX_CROP.location,
Config::GFX_SAFE_TEXTURE_CACHE_COLOR_SAMPLES.location, &Config::GFX_SAFE_TEXTURE_CACHE_COLOR_SAMPLES.location,
Config::GFX_SHOW_FPS.location, &Config::GFX_SHOW_FPS.location,
Config::GFX_SHOW_NETPLAY_PING.location, &Config::GFX_SHOW_NETPLAY_PING.location,
Config::GFX_SHOW_NETPLAY_MESSAGES.location, &Config::GFX_SHOW_NETPLAY_MESSAGES.location,
Config::GFX_LOG_RENDER_TIME_TO_FILE.location, &Config::GFX_LOG_RENDER_TIME_TO_FILE.location,
Config::GFX_OVERLAY_STATS.location, &Config::GFX_OVERLAY_STATS.location,
Config::GFX_OVERLAY_PROJ_STATS.location, &Config::GFX_OVERLAY_PROJ_STATS.location,
Config::GFX_DUMP_TEXTURES.location, &Config::GFX_DUMP_TEXTURES.location,
Config::GFX_HIRES_TEXTURES.location, &Config::GFX_HIRES_TEXTURES.location,
Config::GFX_CACHE_HIRES_TEXTURES.location, &Config::GFX_CACHE_HIRES_TEXTURES.location,
Config::GFX_DUMP_EFB_TARGET.location, &Config::GFX_DUMP_EFB_TARGET.location,
Config::GFX_DUMP_FRAMES_AS_IMAGES.location, &Config::GFX_DUMP_FRAMES_AS_IMAGES.location,
Config::GFX_FREE_LOOK.location, &Config::GFX_FREE_LOOK.location,
Config::GFX_USE_FFV1.location, &Config::GFX_USE_FFV1.location,
Config::GFX_DUMP_FORMAT.location, &Config::GFX_DUMP_FORMAT.location,
Config::GFX_DUMP_CODEC.location, &Config::GFX_DUMP_CODEC.location,
Config::GFX_DUMP_ENCODER.location, &Config::GFX_DUMP_ENCODER.location,
Config::GFX_DUMP_PATH.location, &Config::GFX_DUMP_PATH.location,
Config::GFX_BITRATE_KBPS.location, &Config::GFX_BITRATE_KBPS.location,
Config::GFX_INTERNAL_RESOLUTION_FRAME_DUMPS.location, &Config::GFX_INTERNAL_RESOLUTION_FRAME_DUMPS.location,
Config::GFX_ENABLE_GPU_TEXTURE_DECODING.location, &Config::GFX_ENABLE_GPU_TEXTURE_DECODING.location,
Config::GFX_ENABLE_PIXEL_LIGHTING.location, &Config::GFX_ENABLE_PIXEL_LIGHTING.location,
Config::GFX_FAST_DEPTH_CALC.location, &Config::GFX_FAST_DEPTH_CALC.location,
Config::GFX_MSAA.location, &Config::GFX_MSAA.location,
Config::GFX_SSAA.location, &Config::GFX_SSAA.location,
Config::GFX_EFB_SCALE.location, &Config::GFX_EFB_SCALE.location,
Config::GFX_TEXFMT_OVERLAY_ENABLE.location, &Config::GFX_TEXFMT_OVERLAY_ENABLE.location,
Config::GFX_TEXFMT_OVERLAY_CENTER.location, &Config::GFX_TEXFMT_OVERLAY_CENTER.location,
Config::GFX_ENABLE_WIREFRAME.location, &Config::GFX_ENABLE_WIREFRAME.location,
Config::GFX_DISABLE_FOG.location, &Config::GFX_DISABLE_FOG.location,
Config::GFX_BORDERLESS_FULLSCREEN.location, &Config::GFX_BORDERLESS_FULLSCREEN.location,
Config::GFX_ENABLE_VALIDATION_LAYER.location, &Config::GFX_ENABLE_VALIDATION_LAYER.location,
Config::GFX_BACKEND_MULTITHREADING.location, &Config::GFX_BACKEND_MULTITHREADING.location,
Config::GFX_COMMAND_BUFFER_EXECUTE_INTERVAL.location, &Config::GFX_COMMAND_BUFFER_EXECUTE_INTERVAL.location,
Config::GFX_SHADER_CACHE.location, &Config::GFX_SHADER_CACHE.location,
Config::GFX_WAIT_FOR_SHADERS_BEFORE_STARTING.location, &Config::GFX_WAIT_FOR_SHADERS_BEFORE_STARTING.location,
Config::GFX_SHADER_COMPILATION_MODE.location, &Config::GFX_SHADER_COMPILATION_MODE.location,
Config::GFX_SHADER_COMPILER_THREADS.location, &Config::GFX_SHADER_COMPILER_THREADS.location,
Config::GFX_SHADER_PRECOMPILER_THREADS.location, &Config::GFX_SHADER_PRECOMPILER_THREADS.location,
Config::GFX_SAVE_TEXTURE_CACHE_TO_STATE.location, &Config::GFX_SAVE_TEXTURE_CACHE_TO_STATE.location,
Config::GFX_SW_ZCOMPLOC.location, &Config::GFX_SW_ZCOMPLOC.location,
Config::GFX_SW_ZFREEZE.location, &Config::GFX_SW_ZFREEZE.location,
Config::GFX_SW_DUMP_OBJECTS.location, &Config::GFX_SW_DUMP_OBJECTS.location,
Config::GFX_SW_DUMP_TEV_STAGES.location, &Config::GFX_SW_DUMP_TEV_STAGES.location,
Config::GFX_SW_DUMP_TEV_TEX_FETCHES.location, &Config::GFX_SW_DUMP_TEV_TEX_FETCHES.location,
Config::GFX_SW_DRAW_START.location, &Config::GFX_SW_DRAW_START.location,
Config::GFX_SW_DRAW_END.location, &Config::GFX_SW_DRAW_END.location,
// Graphics.Enhancements // Graphics.Enhancements
Config::GFX_ENHANCE_FORCE_FILTERING.location, &Config::GFX_ENHANCE_FORCE_FILTERING.location,
Config::GFX_ENHANCE_MAX_ANISOTROPY.location, &Config::GFX_ENHANCE_MAX_ANISOTROPY.location,
Config::GFX_ENHANCE_POST_SHADER.location, &Config::GFX_ENHANCE_POST_SHADER.location,
Config::GFX_ENHANCE_FORCE_TRUE_COLOR.location, &Config::GFX_ENHANCE_FORCE_TRUE_COLOR.location,
Config::GFX_ENHANCE_DISABLE_COPY_FILTER.location, &Config::GFX_ENHANCE_DISABLE_COPY_FILTER.location,
Config::GFX_ENHANCE_ARBITRARY_MIPMAP_DETECTION.location, &Config::GFX_ENHANCE_ARBITRARY_MIPMAP_DETECTION.location,
// Graphics.Stereoscopy // Graphics.Stereoscopy
Config::GFX_STEREO_MODE.location, &Config::GFX_STEREO_MODE.location,
Config::GFX_STEREO_DEPTH.location, &Config::GFX_STEREO_DEPTH.location,
Config::GFX_STEREO_CONVERGENCE_PERCENTAGE.location, &Config::GFX_STEREO_CONVERGENCE_PERCENTAGE.location,
Config::GFX_STEREO_SWAP_EYES.location, &Config::GFX_STEREO_SWAP_EYES.location,
Config::GFX_STEREO_CONVERGENCE.location, &Config::GFX_STEREO_CONVERGENCE.location,
Config::GFX_STEREO_EFB_MONO_DEPTH.location, &Config::GFX_STEREO_EFB_MONO_DEPTH.location,
Config::GFX_STEREO_DEPTH_PERCENTAGE.location, &Config::GFX_STEREO_DEPTH_PERCENTAGE.location,
// Graphics.Hacks // Graphics.Hacks
Config::GFX_HACK_EFB_ACCESS_ENABLE.location, &Config::GFX_HACK_EFB_ACCESS_ENABLE.location,
Config::GFX_HACK_EFB_DEFER_INVALIDATION.location, &Config::GFX_HACK_EFB_DEFER_INVALIDATION.location,
Config::GFX_HACK_EFB_ACCESS_TILE_SIZE.location, &Config::GFX_HACK_EFB_ACCESS_TILE_SIZE.location,
Config::GFX_HACK_BBOX_ENABLE.location, &Config::GFX_HACK_BBOX_ENABLE.location,
Config::GFX_HACK_FORCE_PROGRESSIVE.location, &Config::GFX_HACK_FORCE_PROGRESSIVE.location,
Config::GFX_HACK_SKIP_EFB_COPY_TO_RAM.location, &Config::GFX_HACK_SKIP_EFB_COPY_TO_RAM.location,
Config::GFX_HACK_SKIP_XFB_COPY_TO_RAM.location, &Config::GFX_HACK_SKIP_XFB_COPY_TO_RAM.location,
Config::GFX_HACK_DISABLE_COPY_TO_VRAM.location, &Config::GFX_HACK_DISABLE_COPY_TO_VRAM.location,
Config::GFX_HACK_DEFER_EFB_COPIES.location, &Config::GFX_HACK_DEFER_EFB_COPIES.location,
Config::GFX_HACK_IMMEDIATE_XFB.location, &Config::GFX_HACK_IMMEDIATE_XFB.location,
Config::GFX_HACK_COPY_EFB_SCALED.location, &Config::GFX_HACK_COPY_EFB_SCALED.location,
Config::GFX_HACK_EFB_EMULATE_FORMAT_CHANGES.location, &Config::GFX_HACK_EFB_EMULATE_FORMAT_CHANGES.location,
Config::GFX_HACK_VERTEX_ROUDING.location, &Config::GFX_HACK_VERTEX_ROUDING.location,
// Graphics.GameSpecific // Graphics.GameSpecific
Config::GFX_PERF_QUERIES_ENABLE.location, &Config::GFX_PERF_QUERIES_ENABLE.location,
// UI.General // UI.General
Config::MAIN_USE_DISCORD_PRESENCE.location, &Config::MAIN_USE_DISCORD_PRESENCE.location,
}; };
return std::find(s_setting_saveable.begin(), s_setting_saveable.end(), config_location) != return std::any_of(s_setting_saveable.cbegin(), s_setting_saveable.cend(),
s_setting_saveable.end(); [&config_location](const Config::ConfigLocation* location) {
return *location == config_location;
});
} }
} // namespace ConfigLoaders } // namespace ConfigLoaders

View File

@ -307,7 +307,7 @@ static void RunSIBuffer(u64 user_data, s64 cycles_late)
s_com_csr.CHANNEL, request_length, expected_response_length, actual_response_length); s_com_csr.CHANNEL, request_length, expected_response_length, actual_response_length);
if (expected_response_length != actual_response_length) if (expected_response_length != actual_response_length)
{ {
std::stringstream ss; std::ostringstream ss;
for (u8 b : request_copy) for (u8 b : request_copy)
{ {
ss << std::hex << std::setw(2) << std::setfill('0') << (int)b << ' '; ss << std::hex << std::setw(2) << std::setfill('0') << (int)b << ' ';

View File

@ -512,7 +512,7 @@ void BluetoothReal::LoadLinkKeys()
for (size_t i = 0; i < key_string.length(); i = i + 2) for (size_t i = 0; i < key_string.length(); i = i + 2)
{ {
int value; int value;
std::stringstream(key_string.substr(i, 2)) >> std::hex >> value; std::istringstream(key_string.substr(i, 2)) >> std::hex >> value;
key[pos++] = value; key[pos++] = value;
} }

View File

@ -18,7 +18,7 @@ namespace IOS::HLE::Device
{ {
static void GetVidPidFromDevicePath(const std::string& device_path, u16& vid, u16& pid) static void GetVidPidFromDevicePath(const std::string& device_path, u16& vid, u16& pid)
{ {
std::stringstream stream{device_path}; std::istringstream stream{device_path};
std::string segment; std::string segment;
std::vector<std::string> list; std::vector<std::string> list;
while (std::getline(stream, segment, '/')) while (std::getline(stream, segment, '/'))

View File

@ -50,7 +50,7 @@ void MemoryWatcher::ParseLine(const std::string& line)
m_values[line] = 0; m_values[line] = 0;
m_addresses[line] = std::vector<u32>(); m_addresses[line] = std::vector<u32>();
std::stringstream offsets(line); std::istringstream offsets(line);
offsets >> std::hex; offsets >> std::hex;
u32 offset; u32 offset;
while (offsets >> offset) while (offsets >> offset)
@ -76,7 +76,7 @@ u32 MemoryWatcher::ChasePointer(const std::string& line)
std::string MemoryWatcher::ComposeMessages() std::string MemoryWatcher::ComposeMessages()
{ {
std::stringstream message_stream; std::ostringstream message_stream;
message_stream << std::hex; message_stream << std::hex;
for (auto& entry : m_values) for (auto& entry : m_values)

View File

@ -185,7 +185,7 @@ std::string GetRTCDisplay()
const time_t current_time = CEXIIPL::GetEmulatedTime(CEXIIPL::UNIX_EPOCH); const time_t current_time = CEXIIPL::GetEmulatedTime(CEXIIPL::UNIX_EPOCH);
const tm* const gm_time = gmtime(&current_time); const tm* const gm_time = gmtime(&current_time);
std::stringstream format_time; std::ostringstream format_time;
format_time << std::put_time(gm_time, "Date/Time: %c\n"); format_time << std::put_time(gm_time, "Date/Time: %c\n");
return format_time.str(); return format_time.str();
} }

View File

@ -37,7 +37,7 @@ BreakPoints::TBreakPointsStr BreakPoints::GetStrings() const
{ {
if (!bp.is_temporary) if (!bp.is_temporary)
{ {
std::stringstream ss; std::ostringstream ss;
ss << std::hex << bp.address << " " << (bp.is_enabled ? "n" : ""); ss << std::hex << bp.address << " " << (bp.is_enabled ? "n" : "");
bp_strings.push_back(ss.str()); bp_strings.push_back(ss.str());
} }
@ -130,7 +130,7 @@ MemChecks::TMemChecksStr MemChecks::GetStrings() const
TMemChecksStr mc_strings; TMemChecksStr mc_strings;
for (const TMemCheck& mc : m_mem_checks) for (const TMemCheck& mc : m_mem_checks)
{ {
std::stringstream ss; std::ostringstream ss;
ss << std::hex << mc.start_address; ss << std::hex << mc.start_address;
ss << " " << (mc.is_ranged ? mc.end_address : mc.start_address) << " " ss << " " << (mc.is_ranged ? mc.end_address : mc.start_address) << " "
<< (mc.is_ranged ? "n" : "") << (mc.is_break_on_read ? "r" : "") << (mc.is_ranged ? "n" : "") << (mc.is_break_on_read ? "r" : "")

View File

@ -1193,7 +1193,7 @@ void LogGeneratedX86(size_t size, const PPCAnalyst::CodeBuffer& code_buffer, con
if (b->codeSize <= 250) if (b->codeSize <= 250)
{ {
std::stringstream ss; std::ostringstream ss;
ss << std::hex; ss << std::hex;
for (u8 i = 0; i <= b->codeSize; i++) for (u8 i = 0; i <= b->codeSize; i++)
{ {

View File

@ -32,7 +32,7 @@
namespace PowerPC namespace PowerPC
{ {
// STATE_TO_SAVE // STATE_TO_SAVE
PowerPCState ppcState{}; PowerPCState ppcState;
static CPUCoreBase* s_cpu_core_base = nullptr; static CPUCoreBase* s_cpu_core_base = nullptr;
static bool s_cpu_core_base_is_injected = false; static bool s_cpu_core_base_is_injected = false;

View File

@ -348,21 +348,22 @@ Region GetSysMenuRegion(u16 title_version)
std::string GetSysMenuVersionString(u16 title_version) std::string GetSysMenuVersionString(u16 title_version)
{ {
std::string region_letter; std::string version;
char region_letter = '\0';
switch (GetSysMenuRegion(title_version)) switch (GetSysMenuRegion(title_version))
{ {
case Region::NTSC_J: case Region::NTSC_J:
region_letter = "J"; region_letter = 'J';
break; break;
case Region::NTSC_U: case Region::NTSC_U:
region_letter = "U"; region_letter = 'U';
break; break;
case Region::PAL: case Region::PAL:
region_letter = "E"; region_letter = 'E';
break; break;
case Region::NTSC_K: case Region::NTSC_K:
region_letter = "K"; region_letter = 'K';
break; break;
case Region::Unknown: case Region::Unknown:
WARN_LOG(DISCIO, "Unknown region for Wii Menu version %u", title_version); WARN_LOG(DISCIO, "Unknown region for Wii Menu version %u", title_version);
@ -372,36 +373,55 @@ std::string GetSysMenuVersionString(u16 title_version)
switch (title_version & 0xff0) switch (title_version & 0xff0)
{ {
case 32: case 32:
return "1.0" + region_letter; version = "1.0";
break;
case 96: case 96:
case 128: case 128:
return "2.0" + region_letter; version = "2.0";
break;
case 160: case 160:
return "2.1" + region_letter; version = "2.1";
break;
case 192: case 192:
return "2.2" + region_letter; version = "2.2";
break;
case 224: case 224:
return "3.0" + region_letter; version = "3.0";
break;
case 256: case 256:
return "3.1" + region_letter; version = "3.1";
break;
case 288: case 288:
return "3.2" + region_letter; version = "3.2";
break;
case 320: case 320:
case 352: case 352:
return "3.3" + region_letter; version = "3.3";
break;
case 384: case 384:
return (region_letter != "K" ? "3.4" : "3.5") + region_letter; version = (region_letter != 'K' ? "3.4" : "3.5");
break;
case 416: case 416:
return "4.0" + region_letter; version = "4.0";
break;
case 448: case 448:
return "4.1" + region_letter; version = "4.1";
break;
case 480: case 480:
return "4.2" + region_letter; version = "4.2";
break;
case 512: case 512:
return "4.3" + region_letter; version = "4.3";
break;
default: default:
return "?.?" + region_letter; version = "?.?";
break;
} }
if (region_letter != '\0')
version += region_letter;
return version;
} }
const std::string& GetCompanyFromID(const std::string& company_id) const std::string& GetCompanyFromID(const std::string& company_id)

View File

@ -5,6 +5,7 @@
#include "DiscIO/VolumeVerifier.h" #include "DiscIO/VolumeVerifier.h"
#include <algorithm> #include <algorithm>
#include <cassert>
#include <cinttypes> #include <cinttypes>
#include <future> #include <future>
#include <limits> #include <limits>
@ -678,38 +679,47 @@ bool VolumeVerifier::IsDebugSigned() const
bool VolumeVerifier::ShouldHaveChannelPartition() const bool VolumeVerifier::ShouldHaveChannelPartition() const
{ {
const std::unordered_set<std::string> channel_discs{ static constexpr std::array<std::string_view, 18> channel_discs = {
"RFNE01", "RFNJ01", "RFNK01", "RFNP01", "RFNW01", "RFPE01", "RFPJ01", "RFPK01", "RFPP01", "RFNE01", "RFNJ01", "RFNK01", "RFNP01", "RFNW01", "RFPE01", "RFPJ01", "RFPK01", "RFPP01",
"RFPW01", "RGWE41", "RGWJ41", "RGWP41", "RGWX41", "RMCE01", "RMCJ01", "RMCK01", "RMCP01", "RFPW01", "RGWE41", "RGWJ41", "RGWP41", "RGWX41", "RMCE01", "RMCJ01", "RMCK01", "RMCP01",
}; };
assert(std::is_sorted(channel_discs.cbegin(), channel_discs.cend()));
return channel_discs.find(m_volume.GetGameID()) != channel_discs.end(); return std::binary_search(channel_discs.cbegin(), channel_discs.cend(),
std::string_view(m_volume.GetGameID()));
} }
bool VolumeVerifier::ShouldHaveInstallPartition() const bool VolumeVerifier::ShouldHaveInstallPartition() const
{ {
const std::unordered_set<std::string> dragon_quest_x{"S4MJGD", "S4SJGD", "S6TJGD", "SDQJGD"}; static constexpr std::array<std::string_view, 4> dragon_quest_x = {"S4MJGD", "S4SJGD", "S6TJGD",
return dragon_quest_x.find(m_volume.GetGameID()) != dragon_quest_x.end(); "SDQJGD"};
const std::string& game_id = m_volume.GetGameID();
return std::any_of(dragon_quest_x.cbegin(), dragon_quest_x.cend(),
[&game_id](std::string_view x) { return x == game_id; });
} }
bool VolumeVerifier::ShouldHaveMasterpiecePartitions() const bool VolumeVerifier::ShouldHaveMasterpiecePartitions() const
{ {
const std::unordered_set<std::string> ssbb{"RSBE01", "RSBJ01", "RSBK01", "RSBP01"}; static constexpr std::array<std::string_view, 4> ssbb = {"RSBE01", "RSBJ01", "RSBK01", "RSBP01"};
return ssbb.find(m_volume.GetGameID()) != ssbb.end(); const std::string& game_id = m_volume.GetGameID();
return std::any_of(ssbb.cbegin(), ssbb.cend(),
[&game_id](std::string_view x) { return x == game_id; });
} }
bool VolumeVerifier::ShouldBeDualLayer() const bool VolumeVerifier::ShouldBeDualLayer() const
{ {
// The Japanese versions of Xenoblade and The Last Story are single-layer // The Japanese versions of Xenoblade and The Last Story are single-layer
// (unlike the other versions) and must not be added to this list. // (unlike the other versions) and must not be added to this list.
const std::unordered_set<std::string> dual_layer_discs{ static constexpr std::array<std::string_view, 33> dual_layer_discs = {
"R3ME01", "R3MP01", "R3OE01", "R3OJ01", "R3OP01", "RSBE01", "RSBJ01", "RSBK01", "RSBP01", "R3ME01", "R3MP01", "R3OE01", "R3OJ01", "R3OP01", "RSBE01", "RSBJ01", "RSBK01", "RSBP01",
"RXMJ8P", "S59E01", "S59JC8", "S59P01", "S5QJC8", "SK8X52", "SAKENS", "SAKPNS", "SK8V52", "RXMJ8P", "S59E01", "S59JC8", "S59P01", "S5QJC8", "SAKENS", "SAKPNS", "SK8V52", "SK8X52",
"SK8X52", "SLSEXJ", "SLSP01", "SQIE4Q", "SQIP4Q", "SQIY4Q", "SR5E41", "SR5P41", "SUOE41", "SLSEXJ", "SLSP01", "SQIE4Q", "SQIP4Q", "SQIY4Q", "SR5E41", "SR5P41", "SUOE41", "SUOP41",
"SUOP41", "SVXX52", "SVXY52", "SX4E01", "SX4P01", "SZ3EGT", "SZ3PGT", "SVXX52", "SVXY52", "SX4E01", "SX4P01", "SZ3EGT", "SZ3PGT",
}; };
assert(std::is_sorted(dual_layer_discs.cbegin(), dual_layer_discs.cend()));
return dual_layer_discs.find(m_volume.GetGameID()) != dual_layer_discs.end(); return std::binary_search(dual_layer_discs.cbegin(), dual_layer_discs.cend(),
std::string_view(m_volume.GetGameID()));
} }
void VolumeVerifier::CheckDiscSize() void VolumeVerifier::CheckDiscSize()

View File

@ -30,7 +30,7 @@ bool InputConfig::LoadConfig(bool isGC)
{ {
IniFile inifile; IniFile inifile;
bool useProfile[MAX_BBMOTES] = {false, false, false, false, false}; bool useProfile[MAX_BBMOTES] = {false, false, false, false, false};
std::string num[MAX_BBMOTES] = {"1", "2", "3", "4", "BB"}; static constexpr std::array<std::string_view, MAX_BBMOTES> num = {"1", "2", "3", "4", "BB"};
std::string profile[MAX_BBMOTES]; std::string profile[MAX_BBMOTES];
std::string path; std::string path;
@ -58,10 +58,10 @@ bool InputConfig::LoadConfig(bool isGC)
for (int i = 0; i < 4; i++) for (int i = 0; i < 4; i++)
{ {
if (control_section->Exists(type + "Profile" + num[i])) if (control_section->Exists(type + "Profile" + std::string(num[i])))
{ {
std::string profile_setting; std::string profile_setting;
if (control_section->Get(type + "Profile" + num[i], &profile_setting)) if (control_section->Get(type + "Profile" + std::string(num[i]), &profile_setting))
{ {
auto profiles = InputProfile::GetProfilesFromSetting( auto profiles = InputProfile::GetProfilesFromSetting(
profile_setting, File::GetUserPath(D_CONFIG_IDX) + path); profile_setting, File::GetUserPath(D_CONFIG_IDX) + path);

View File

@ -76,7 +76,7 @@ std::vector<ResourcePack>& GetPacks()
std::vector<ResourcePack*> GetLowerPriorityPacks(ResourcePack& pack) std::vector<ResourcePack*> GetLowerPriorityPacks(ResourcePack& pack)
{ {
std::vector<ResourcePack*> list; std::vector<ResourcePack*> list;
for (auto it = std::find(packs.begin(), packs.end(), pack) + 1; it != packs.end(); it++) for (auto it = std::find(packs.begin(), packs.end(), pack) + 1; it != packs.end(); ++it)
{ {
auto& entry = *it; auto& entry = *it;
if (!IsInstalled(pack)) if (!IsInstalled(pack))
@ -93,7 +93,7 @@ std::vector<ResourcePack*> GetHigherPriorityPacks(ResourcePack& pack)
std::vector<ResourcePack*> list; std::vector<ResourcePack*> list;
auto end = std::find(packs.begin(), packs.end(), pack); auto end = std::find(packs.begin(), packs.end(), pack);
for (auto it = packs.begin(); it != end; it++) for (auto it = packs.begin(); it != end; ++it)
{ {
auto& entry = *it; auto& entry = *it;
if (!IsInstalled(entry)) if (!IsInstalled(entry))

View File

@ -464,7 +464,7 @@ std::string FormatSize(u64 bytes)
// Don't need exact values, only 5 most significant digits // Don't need exact values, only 5 most significant digits
const double unit_size = std::pow(2, unit * 10); const double unit_size = std::pow(2, unit * 10);
std::stringstream ss; std::ostringstream ss;
ss << std::fixed << std::setprecision(2); ss << std::fixed << std::setprecision(2);
ss << bytes / unit_size << ' ' << Common::GetStringT(unit_symbols[unit]); ss << bytes / unit_size << ' ' << Common::GetStringT(unit_symbols[unit]);
return ss.str(); return ss.str();

View File

@ -178,7 +178,7 @@ bool StreamBuffer::WaitForClearSpace(u32 num_bytes)
u32 new_gpu_position = 0; u32 new_gpu_position = 0;
auto iter = m_tracked_fences.begin(); auto iter = m_tracked_fences.begin();
for (; iter != m_tracked_fences.end(); iter++) for (; iter != m_tracked_fences.end(); ++iter)
{ {
// Would this fence bring us in line with the GPU? // Would this fence bring us in line with the GPU?
// This is the "last resort" case, where a command buffer execution has been forced // This is the "last resort" case, where a command buffer execution has been forced

View File

@ -144,28 +144,35 @@ static void APIENTRY ClearDepthf(GLfloat depthval)
static void InitDriverInfo() static void InitDriverInfo()
{ {
std::string svendor = std::string(g_ogl_config.gl_vendor); const std::string_view svendor(g_ogl_config.gl_vendor);
std::string srenderer = std::string(g_ogl_config.gl_renderer); const std::string_view srenderer(g_ogl_config.gl_renderer);
std::string sversion = std::string(g_ogl_config.gl_version); const std::string_view sversion(g_ogl_config.gl_version);
DriverDetails::Vendor vendor = DriverDetails::VENDOR_UNKNOWN; DriverDetails::Vendor vendor = DriverDetails::VENDOR_UNKNOWN;
DriverDetails::Driver driver = DriverDetails::DRIVER_UNKNOWN; DriverDetails::Driver driver = DriverDetails::DRIVER_UNKNOWN;
DriverDetails::Family family = DriverDetails::Family::UNKNOWN; DriverDetails::Family family = DriverDetails::Family::UNKNOWN;
double version = 0.0; double version = 0.0;
// Get the vendor first // Get the vendor first
if (svendor == "NVIDIA Corporation" && srenderer != "NVIDIA Tegra") if (svendor == "NVIDIA Corporation")
{
if (srenderer != "NVIDIA Tegra")
{ {
vendor = DriverDetails::VENDOR_NVIDIA; vendor = DriverDetails::VENDOR_NVIDIA;
} }
else
{
vendor = DriverDetails::VENDOR_TEGRA;
}
}
else if (svendor == "ATI Technologies Inc." || svendor == "Advanced Micro Devices, Inc.") else if (svendor == "ATI Technologies Inc." || svendor == "Advanced Micro Devices, Inc.")
{ {
vendor = DriverDetails::VENDOR_ATI; vendor = DriverDetails::VENDOR_ATI;
} }
else if (std::string::npos != sversion.find("Mesa")) else if (sversion.find("Mesa") != std::string::npos)
{ {
vendor = DriverDetails::VENDOR_MESA; vendor = DriverDetails::VENDOR_MESA;
} }
else if (std::string::npos != svendor.find("Intel")) else if (svendor.find("Intel") != std::string::npos)
{ {
vendor = DriverDetails::VENDOR_INTEL; vendor = DriverDetails::VENDOR_INTEL;
} }
@ -186,10 +193,6 @@ static void InitDriverInfo()
{ {
vendor = DriverDetails::VENDOR_IMGTEC; vendor = DriverDetails::VENDOR_IMGTEC;
} }
else if (svendor == "NVIDIA Corporation" && srenderer == "NVIDIA Tegra")
{
vendor = DriverDetails::VENDOR_TEGRA;
}
else if (svendor == "Vivante Corporation") else if (svendor == "Vivante Corporation")
{ {
vendor = DriverDetails::VENDOR_VIVANTE; vendor = DriverDetails::VENDOR_VIVANTE;
@ -238,8 +241,8 @@ static void InitDriverInfo()
else if (srenderer.find("Ivybridge") != std::string::npos) else if (srenderer.find("Ivybridge") != std::string::npos)
family = DriverDetails::Family::INTEL_IVY; family = DriverDetails::Family::INTEL_IVY;
} }
else if (std::string::npos != srenderer.find("AMD") || else if (srenderer.find("AMD") != std::string::npos ||
std::string::npos != srenderer.find("ATI")) srenderer.find("ATI") != std::string::npos)
{ {
driver = DriverDetails::DRIVER_R600; driver = DriverDetails::DRIVER_R600;
} }

View File

@ -254,7 +254,7 @@ bool StreamBuffer::WaitForClearSpace(u32 num_bytes)
u32 new_gpu_position = 0; u32 new_gpu_position = 0;
auto iter = m_tracked_fences.begin(); auto iter = m_tracked_fences.begin();
for (; iter != m_tracked_fences.end(); iter++) for (; iter != m_tracked_fences.end(); ++iter)
{ {
// Would this fence bring us in line with the GPU? // Would this fence bring us in line with the GPU?
// This is the "last resort" case, where a command buffer execution has been forced // This is the "last resort" case, where a command buffer execution has been forced

View File

@ -434,7 +434,7 @@ void PostProcessing::BlitFromTexture(const MathUtil::Rectangle<int>& dst,
std::string PostProcessing::GetUniformBufferHeader() const std::string PostProcessing::GetUniformBufferHeader() const
{ {
std::stringstream ss; std::ostringstream ss;
u32 unused_counter = 1; u32 unused_counter = 1;
if (g_ActiveConfig.backend_info.api_type == APIType::D3D) if (g_ActiveConfig.backend_info.api_type == APIType::D3D)
ss << "cbuffer PSBlock : register(b0) {\n"; ss << "cbuffer PSBlock : register(b0) {\n";
@ -493,7 +493,7 @@ std::string PostProcessing::GetUniformBufferHeader() const
std::string PostProcessing::GetHeader() const std::string PostProcessing::GetHeader() const
{ {
std::stringstream ss; std::ostringstream ss;
ss << GetUniformBufferHeader(); ss << GetUniformBufferHeader();
if (g_ActiveConfig.backend_info.api_type == APIType::D3D) if (g_ActiveConfig.backend_info.api_type == APIType::D3D)
{ {
@ -602,7 +602,7 @@ void main(in float3 v_tex0_ : TEXCOORD0, out float4 ocol0_ : SV_Target)
bool PostProcessing::CompileVertexShader() bool PostProcessing::CompileVertexShader()
{ {
std::stringstream ss; std::ostringstream ss;
ss << GetUniformBufferHeader(); ss << GetUniformBufferHeader();
if (g_ActiveConfig.backend_info.api_type == APIType::D3D) if (g_ActiveConfig.backend_info.api_type == APIType::D3D)

View File

@ -1392,7 +1392,7 @@ std::string GenerateDecodingShader(TextureFormat format, TLUTFormat palette_form
if (!info) if (!info)
return ""; return "";
std::stringstream ss; std::ostringstream ss;
switch (palette_format) switch (palette_format)
{ {
case TLUTFormat::IA8: case TLUTFormat::IA8:
@ -1414,7 +1414,7 @@ std::string GenerateDecodingShader(TextureFormat format, TLUTFormat palette_form
std::string GeneratePaletteConversionShader(TLUTFormat palette_format, APIType api_type) std::string GeneratePaletteConversionShader(TLUTFormat palette_format, APIType api_type)
{ {
std::stringstream ss; std::ostringstream ss;
ss << R"( ss << R"(
int Convert3To8(int v) int Convert3To8(int v)

View File

@ -768,12 +768,12 @@ void VertexManagerBase::OnEndFrame()
#if 0 #if 0
{ {
std::stringstream ss; std::ostringstream ss;
std::for_each(m_cpu_accesses_this_frame.begin(), m_cpu_accesses_this_frame.end(), [&ss](u32 idx) { ss << idx << ","; }); std::for_each(m_cpu_accesses_this_frame.begin(), m_cpu_accesses_this_frame.end(), [&ss](u32 idx) { ss << idx << ","; });
WARN_LOG(VIDEO, "CPU EFB accesses in last frame: %s", ss.str().c_str()); WARN_LOG(VIDEO, "CPU EFB accesses in last frame: %s", ss.str().c_str());
} }
{ {
std::stringstream ss; std::ostringstream ss;
std::for_each(m_scheduled_command_buffer_kicks.begin(), m_scheduled_command_buffer_kicks.end(), [&ss](u32 idx) { ss << idx << ","; }); std::for_each(m_scheduled_command_buffer_kicks.begin(), m_scheduled_command_buffer_kicks.end(), [&ss](u32 idx) { ss << idx << ","; });
WARN_LOG(VIDEO, "Scheduled command buffer kicks: %s", ss.str().c_str()); WARN_LOG(VIDEO, "Scheduled command buffer kicks: %s", ss.str().c_str());
} }