Replace global static map with an array of pairs (#2691)

* Replace global static map with an array of pairs

\#2687 introduced a global static map, which isn't allowed by
the style guide and caused an issue in DXC.

This change replaces it with an array of pairs.

Signed-off-by: Kévin Petit <kpet@free.fr>

* Replace constexpr with const

Signed-off-by: Kévin Petit <kpet@free.fr>
This commit is contained in:
Kévin Petit 2019-06-21 13:47:27 +01:00 committed by David Neto
parent 7c294608ca
commit df86bb44fe

View File

@ -15,7 +15,6 @@
#include "source/spirv_target_env.h" #include "source/spirv_target_env.h"
#include <cstring> #include <cstring>
#include <map>
#include <string> #include <string>
#include "source/spirv_constant.h" #include "source/spirv_constant.h"
@ -104,7 +103,7 @@ uint32_t spvVersionForTargetEnv(spv_target_env env) {
return SPV_SPIRV_VERSION_WORD(0, 0); return SPV_SPIRV_VERSION_WORD(0, 0);
} }
static const std::map<std::string, spv_target_env> spvTargetEnvNameMap = { static const std::pair<const char*, spv_target_env> spvTargetEnvNameMap[] = {
{"vulkan1.1spv1.4", SPV_ENV_VULKAN_1_1_SPIRV_1_4}, {"vulkan1.1spv1.4", SPV_ENV_VULKAN_1_1_SPIRV_1_4},
{"vulkan1.0", SPV_ENV_VULKAN_1_0}, {"vulkan1.0", SPV_ENV_VULKAN_1_0},
{"vulkan1.1", SPV_ENV_VULKAN_1_1}, {"vulkan1.1", SPV_ENV_VULKAN_1_1},
@ -130,15 +129,16 @@ static const std::map<std::string, spv_target_env> spvTargetEnvNameMap = {
}; };
bool spvParseTargetEnv(const char* s, spv_target_env* env) { bool spvParseTargetEnv(const char* s, spv_target_env* env) {
std::string envstr; auto match = [s](const char* b) {
if (s != nullptr) { return s && (0 == strncmp(s, b, strlen(b)));
envstr = s; };
} for (auto& name_env : spvTargetEnvNameMap) {
if (spvTargetEnvNameMap.count(envstr) != 0) { if (match(name_env.first)) {
if (env) { if (env) {
*env = spvTargetEnvNameMap.at(envstr); *env = name_env.second;
}
return true;
} }
return true;
} }
if (env) *env = SPV_ENV_UNIVERSAL_1_0; if (env) *env = SPV_ENV_UNIVERSAL_1_0;
return false; return false;
@ -282,8 +282,8 @@ std::string spvTargetEnvList(const int pad, const int wrap) {
std::string line; std::string line;
std::string sep = ""; std::string sep = "";
for (auto& env_name : spvTargetEnvNameMap) { for (auto& name_env : spvTargetEnvNameMap) {
std::string word = sep + env_name.first; std::string word = sep + name_env.first;
if (line.length() + word.length() > max_line_len) { if (line.length() + word.length() > max_line_len) {
// Adding one word wouldn't fit, commit the line in progress and // Adding one word wouldn't fit, commit the line in progress and
// start a new one. // start a new one.