From e65363f05ff41d10af0d01229f6b1adac44dfc66 Mon Sep 17 00:00:00 2001 From: Lioncash Date: Tue, 24 Aug 2021 07:35:02 -0400 Subject: [PATCH] NetKDRequest: Make use of constexpr arrays containing pairs instead of maps Currently we were using heap allocating maps that last for the entire duration of the emulator running. Given the size N of both of these maps are very small (< 20 elements), we can just make use of an array of pairs and perform linear scans. This is also fine, given this code isn't particularly "hot" either, so this won't be run often. --- .../Core/Core/IOS/Network/KD/NetKDRequest.cpp | 39 +++++++++++++------ 1 file changed, 27 insertions(+), 12 deletions(-) diff --git a/Source/Core/Core/IOS/Network/KD/NetKDRequest.cpp b/Source/Core/Core/IOS/Network/KD/NetKDRequest.cpp index cc98153068..d5980423f5 100644 --- a/Source/Core/Core/IOS/Network/KD/NetKDRequest.cpp +++ b/Source/Core/Core/IOS/Network/KD/NetKDRequest.cpp @@ -3,9 +3,11 @@ #include "Core/IOS/Network/KD/NetKDRequest.h" +#include #include -#include #include +#include +#include #include "Common/CommonPaths.h" #include "Common/CommonTypes.h" @@ -33,31 +35,44 @@ enum class HardwareModel : u8 Unknown = 7 }; -u8 GetAreaCode(const std::string& area) +u8 GetAreaCode(std::string_view area) { - static const std::map regions = { - {"JPN", 0}, {"USA", 1}, {"EUR", 2}, {"AUS", 2}, {"BRA", 1}, {"TWN", 3}, {"ROC", 3}, - {"KOR", 4}, {"HKG", 5}, {"ASI", 5}, {"LTN", 1}, {"SAF", 2}, {"CHN", 6}, - }; + static constexpr std::array, 13> regions{{ + {"JPN", 0}, + {"USA", 1}, + {"EUR", 2}, + {"AUS", 2}, + {"BRA", 1}, + {"TWN", 3}, + {"ROC", 3}, + {"KOR", 4}, + {"HKG", 5}, + {"ASI", 5}, + {"LTN", 1}, + {"SAF", 2}, + {"CHN", 6}, + }}; - const auto entry_pos = regions.find(area); + const auto entry_pos = std::find_if(regions.cbegin(), regions.cend(), + [&area](const auto& entry) { return entry.first == area; }); if (entry_pos != regions.end()) return entry_pos->second; return 7; // Unknown } -HardwareModel GetHardwareModel(const std::string& model) +HardwareModel GetHardwareModel(std::string_view model) { - static const std::map models = { + static constexpr std::array, 4> models{{ {"RVL", HardwareModel::RVL}, {"RVT", HardwareModel::RVT}, {"RVV", HardwareModel::RVV}, {"RVD", HardwareModel::RVD}, - }; + }}; - const auto entry_pos = models.find(model); - if (entry_pos != models.end()) + const auto entry_pos = std::find_if(models.cbegin(), models.cend(), + [&model](const auto& entry) { return entry.first == model; }); + if (entry_pos != models.cend()) return entry_pos->second; return HardwareModel::Unknown;