mirror of
https://github.com/KhronosGroup/SPIRV-Tools
synced 2025-01-14 02:10:17 +00:00
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:
parent
7c294608ca
commit
df86bb44fe
@ -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.
|
||||||
|
Loading…
Reference in New Issue
Block a user