mirror of
https://github.com/Laupetin/OpenAssetTools.git
synced 2026-03-05 12:33:02 +00:00
chore: add more details to common techset infos in t5,t6
This commit is contained in:
@@ -1,15 +1,22 @@
|
||||
#include "CommonTechnique.h"
|
||||
|
||||
#include <algorithm>
|
||||
#include <cassert>
|
||||
|
||||
namespace techset
|
||||
{
|
||||
CommonCodeSourceInfos::CommonCodeSourceInfos(const CommonCodeConstSourceInfo* codeConstSourceInfos,
|
||||
const size_t codeConstCount,
|
||||
const CommonCodeSamplerSourceInfo* codeSamplerSourceInfos,
|
||||
const size_t codeSamplerCount)
|
||||
const size_t codeSamplerCount,
|
||||
const char** ignoreArgAccessors,
|
||||
const size_t ignoredArgAccessorCount,
|
||||
const CommonShaderArgumentType* argumentTypes,
|
||||
const size_t argumentTypeCount)
|
||||
: m_code_const_source_infos(codeConstCount),
|
||||
m_code_sampler_source_infos(codeSamplerCount)
|
||||
m_code_sampler_source_infos(codeSamplerCount),
|
||||
m_ignored_arg_accessors(ignoredArgAccessorCount),
|
||||
m_argument_types(argumentTypeCount)
|
||||
{
|
||||
std::copy(codeConstSourceInfos, &codeConstSourceInfos[codeConstCount], m_code_const_source_infos.data());
|
||||
std::ranges::sort(m_code_const_source_infos,
|
||||
@@ -24,6 +31,21 @@ namespace techset
|
||||
{
|
||||
return a.value < b.value;
|
||||
});
|
||||
|
||||
for (size_t i = 0; i < ignoredArgAccessorCount; i++)
|
||||
m_ignored_arg_accessors.emplace(ignoreArgAccessors[i]);
|
||||
|
||||
std::copy(argumentTypes, &argumentTypes[argumentTypeCount], m_argument_types.data());
|
||||
|
||||
for (const auto& codeConstInfo : m_code_const_source_infos)
|
||||
{
|
||||
m_code_const_lookup.emplace(codeConstInfo.accessor, codeConstInfo.value);
|
||||
}
|
||||
|
||||
for (const auto& codeSamplerInfo : m_code_sampler_source_infos)
|
||||
{
|
||||
m_code_sampler_lookup.emplace(codeSamplerInfo.accessor, codeSamplerInfo.value);
|
||||
}
|
||||
}
|
||||
|
||||
std::optional<CommonCodeConstSourceInfo> CommonCodeSourceInfos::GetInfoForCodeConstSource(const CommonCodeConstSource codeConstSource) const
|
||||
@@ -55,6 +77,38 @@ namespace techset
|
||||
return std::nullopt;
|
||||
}
|
||||
|
||||
bool CommonCodeSourceInfos::IsArgAccessorIgnored(const std::string& accessor) const
|
||||
{
|
||||
return m_ignored_arg_accessors.contains(accessor);
|
||||
}
|
||||
|
||||
std::optional<CommonCodeConstSource> CommonCodeSourceInfos::GetCodeConstSourceForAccessor(const std::string& accessor) const
|
||||
{
|
||||
const auto foundEntry = m_code_const_lookup.find(accessor);
|
||||
if (foundEntry == m_code_const_lookup.end())
|
||||
return std::nullopt;
|
||||
|
||||
return foundEntry->second;
|
||||
}
|
||||
|
||||
std::optional<CommonCodeSamplerSource> CommonCodeSourceInfos::GetCodeSamplerSourceForAccessor(const std::string& accessor) const
|
||||
{
|
||||
const auto foundEntry = m_code_sampler_lookup.find(accessor);
|
||||
if (foundEntry == m_code_sampler_lookup.end())
|
||||
return std::nullopt;
|
||||
|
||||
return foundEntry->second;
|
||||
}
|
||||
|
||||
std::optional<size_t> CommonCodeSourceInfos::GetArgumentTypeNumericValue(const CommonShaderArgumentType& argumentType) const
|
||||
{
|
||||
const auto foundValue = std::ranges::find(m_argument_types, argumentType);
|
||||
if (foundValue == m_argument_types.end())
|
||||
return std::nullopt;
|
||||
|
||||
return static_cast<size_t>(foundValue - m_argument_types.begin());
|
||||
}
|
||||
|
||||
CommonStreamRoutingInfos::CommonStreamRoutingInfos(const CommonStreamRoutingSourceInfo* sourceInfos,
|
||||
const size_t sourceCount,
|
||||
const CommonStreamRoutingDestinationInfo* destinationNames,
|
||||
@@ -64,6 +118,18 @@ namespace techset
|
||||
{
|
||||
std::copy(sourceInfos, &sourceInfos[sourceCount], m_sources.data());
|
||||
std::copy(destinationNames, &destinationNames[destinationCount], m_destinations.data());
|
||||
|
||||
for (size_t i = 0; i < sourceCount; i++)
|
||||
{
|
||||
m_source_name_lookup[sourceInfos[i].name] = static_cast<CommonStreamSource>(i);
|
||||
m_source_abbreviation_lookup[sourceInfos[i].abbreviation] = static_cast<CommonStreamSource>(i);
|
||||
}
|
||||
|
||||
for (size_t i = 0; i < destinationCount; i++)
|
||||
{
|
||||
m_destination_name_lookup[destinationNames[i].name] = static_cast<CommonStreamDestination>(i);
|
||||
m_destination_abbreviation_lookup[destinationNames[i].abbreviation] = static_cast<CommonStreamDestination>(i);
|
||||
}
|
||||
}
|
||||
|
||||
const char* CommonStreamRoutingInfos::GetSourceName(const CommonStreamSource source) const
|
||||
@@ -105,4 +171,40 @@ namespace techset
|
||||
|
||||
return m_destinations[destination].abbreviation;
|
||||
}
|
||||
|
||||
std::optional<CommonStreamSource> CommonStreamRoutingInfos::GetSourceByName(const std::string& name) const
|
||||
{
|
||||
const auto foundSource = m_source_name_lookup.find(name);
|
||||
if (foundSource != m_source_name_lookup.end())
|
||||
return foundSource->second;
|
||||
|
||||
return std::nullopt;
|
||||
}
|
||||
|
||||
std::optional<CommonStreamSource> CommonStreamRoutingInfos::GetSourceByAbbreviation(const std::string& abbreviation) const
|
||||
{
|
||||
const auto foundSource = m_source_abbreviation_lookup.find(abbreviation);
|
||||
if (foundSource != m_source_abbreviation_lookup.end())
|
||||
return foundSource->second;
|
||||
|
||||
return std::nullopt;
|
||||
}
|
||||
|
||||
std::optional<CommonStreamDestination> CommonStreamRoutingInfos::GetDestinationByName(const std::string& name) const
|
||||
{
|
||||
const auto foundDestination = m_destination_name_lookup.find(name);
|
||||
if (foundDestination != m_destination_name_lookup.end())
|
||||
return foundDestination->second;
|
||||
|
||||
return std::nullopt;
|
||||
}
|
||||
|
||||
std::optional<CommonStreamDestination> CommonStreamRoutingInfos::GetDestinationByAbbreviation(const std::string& abbreviation) const
|
||||
{
|
||||
const auto foundDestination = m_destination_abbreviation_lookup.find(abbreviation);
|
||||
if (foundDestination != m_destination_abbreviation_lookup.end())
|
||||
return foundDestination->second;
|
||||
|
||||
return std::nullopt;
|
||||
}
|
||||
} // namespace techset
|
||||
|
||||
Reference in New Issue
Block a user