Graphics: Add PipelinePassList loader (able to load from a file)
Fix compilation
This commit is contained in:
committed by
Jérôme Leclercq
parent
ef0a34b7b1
commit
886991f86d
@@ -9,29 +9,51 @@ namespace Nz
|
||||
{
|
||||
inline std::unique_ptr<FramePipelinePass> FramePipelinePassRegistry::BuildPass(std::size_t passIndex, FramePipelinePass::PassData& passData, std::string passName, const ParameterList& parameters) const
|
||||
{
|
||||
assert(passIndex < m_passFactories.size());
|
||||
return m_passFactories[passIndex](passData, passName, parameters);
|
||||
assert(passIndex < m_passes.size());
|
||||
return m_passes[passIndex].factory(passData, passName, parameters);
|
||||
}
|
||||
|
||||
inline std::size_t FramePipelinePassRegistry::GetPassIndex(std::string_view passName) const
|
||||
{
|
||||
auto it = m_passIndex.find(passName);
|
||||
if (it == m_passIndex.end())
|
||||
throw std::runtime_error("pass " + std::string(passName) + " must be registered before being used");
|
||||
return InvalidIndex;
|
||||
|
||||
return it->second;
|
||||
}
|
||||
|
||||
template<typename T>
|
||||
std::size_t FramePipelinePassRegistry::RegisterPass(std::string passName)
|
||||
inline std::size_t FramePipelinePassRegistry::GetPassInputIndex(std::size_t passIndex, std::string_view inputName) const
|
||||
{
|
||||
return RegisterPass(std::move(passName), [](FramePipelinePass::PassData& passData, std::string passName, const ParameterList& parameters) -> std::unique_ptr<FramePipelinePass>
|
||||
assert(passIndex < m_passes.size());
|
||||
auto& passData = m_passes[passIndex];
|
||||
auto it = std::find(passData.inputs.begin(), passData.inputs.end(), inputName);
|
||||
if (it == passData.inputs.end())
|
||||
return InvalidIndex;
|
||||
|
||||
return std::distance(passData.inputs.begin(), it);
|
||||
}
|
||||
|
||||
inline std::size_t FramePipelinePassRegistry::GetPassOutputIndex(std::size_t passIndex, std::string_view outputName) const
|
||||
{
|
||||
assert(passIndex < m_passes.size());
|
||||
auto& passData = m_passes[passIndex];
|
||||
auto it = std::find(passData.outputs.begin(), passData.outputs.end(), outputName);
|
||||
if (it == passData.outputs.end())
|
||||
return InvalidIndex;
|
||||
|
||||
return std::distance(passData.outputs.begin(), it);
|
||||
}
|
||||
|
||||
template<typename T>
|
||||
std::size_t FramePipelinePassRegistry::RegisterPass(std::string passName, std::vector<std::string> inputs, std::vector<std::string> outputs)
|
||||
{
|
||||
return RegisterPass(std::move(passName), std::move(inputs), std::move(outputs), [](FramePipelinePass::PassData& passData, std::string passName, const ParameterList& parameters) -> std::unique_ptr<FramePipelinePass>
|
||||
{
|
||||
return std::make_unique<T>(passData, std::move(passName), parameters);
|
||||
});
|
||||
}
|
||||
|
||||
inline std::size_t FramePipelinePassRegistry::RegisterPass(std::string passName, Factory factory)
|
||||
inline std::size_t FramePipelinePassRegistry::RegisterPass(std::string passName, std::vector<std::string> inputs, std::vector<std::string> outputs, Factory factory)
|
||||
{
|
||||
if (m_passIndex.find(passName) != m_passIndex.end())
|
||||
throw std::runtime_error("pass " + passName + " is already registered");
|
||||
@@ -40,7 +62,10 @@ namespace Nz
|
||||
|
||||
std::size_t passIndex = m_passIndex.size();
|
||||
m_passIndex.emplace(m_passNames.back(), passIndex);
|
||||
m_passFactories.emplace_back(std::move(factory));
|
||||
auto& passData = m_passes.emplace_back();
|
||||
passData.factory = std::move(factory);
|
||||
passData.inputs = std::move(inputs);
|
||||
passData.outputs = std::move(outputs);
|
||||
|
||||
return passIndex;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user