Shader: Add module ID (UUID)
This commit is contained in:
@@ -48,15 +48,10 @@ namespace Nz
|
||||
{
|
||||
if (!stageFlags.Test(stage))
|
||||
{
|
||||
ShaderAst::Module dummyModule;
|
||||
ShaderAst::Module dummyModule(100);
|
||||
dummyModule.rootNode = ShaderBuilder::MultiStatement();
|
||||
dummyModule.rootNode->statements.push_back(ShaderBuilder::DeclareFunction(stage, "main", {}, {}));
|
||||
|
||||
std::shared_ptr<ShaderAst::Module::Metadata> metadata = std::make_shared<ShaderAst::Module::Metadata>();
|
||||
metadata->shaderLangVersion = 100;
|
||||
|
||||
dummyModule.metadata = std::move(metadata);
|
||||
|
||||
OpenGLShaderModule shaderModule(device, stage, dummyModule);
|
||||
stageFlags |= shaderModule.Attach(m_program, pipelineLayout.GetBindingMapping());
|
||||
}
|
||||
|
||||
@@ -737,20 +737,16 @@ namespace Nz::ShaderAst
|
||||
|
||||
ModulePtr AstConstantPropagationVisitor::Process(const Module& shaderModule)
|
||||
{
|
||||
ModulePtr clone = std::make_shared<Module>();
|
||||
clone->metadata = shaderModule.metadata;
|
||||
clone->rootNode = static_unique_pointer_cast<MultiStatement>(Process(*shaderModule.rootNode));
|
||||
auto rootnode = static_unique_pointer_cast<MultiStatement>(Process(*shaderModule.rootNode));
|
||||
|
||||
return clone;
|
||||
return std::make_shared<Module>(shaderModule.metadata, std::move(rootnode));
|
||||
}
|
||||
|
||||
ModulePtr AstConstantPropagationVisitor::Process(const Module& shaderModule, const Options& options)
|
||||
{
|
||||
ModulePtr clone = std::make_shared<Module>();
|
||||
clone->metadata = shaderModule.metadata;
|
||||
clone->rootNode = static_unique_pointer_cast<MultiStatement>(Process(*shaderModule.rootNode, options));
|
||||
auto rootNode = static_unique_pointer_cast<MultiStatement>(Process(*shaderModule.rootNode, options));
|
||||
|
||||
return clone;
|
||||
return std::make_shared<Module>(shaderModule.metadata, std::move(rootNode));
|
||||
}
|
||||
|
||||
ExpressionPtr AstConstantPropagationVisitor::Clone(BinaryExpression& node)
|
||||
|
||||
@@ -346,6 +346,7 @@ namespace Nz::ShaderAst
|
||||
{
|
||||
m_stream << s_magicNumber << s_currentVersion;
|
||||
|
||||
m_stream << module.metadata->moduleId;
|
||||
m_stream << module.metadata->shaderLangVersion;
|
||||
Serialize(*module.rootNode);
|
||||
|
||||
@@ -542,14 +543,12 @@ namespace Nz::ShaderAst
|
||||
if (version > s_currentVersion)
|
||||
throw std::runtime_error("unsupported version");
|
||||
|
||||
ModulePtr module = std::make_shared<Module>();
|
||||
|
||||
std::shared_ptr<Module::Metadata> metadata = std::make_shared<Module::Metadata>();
|
||||
m_stream >> metadata->moduleId;
|
||||
m_stream >> metadata->shaderLangVersion;
|
||||
|
||||
module->metadata = std::move(metadata);
|
||||
ModulePtr module = std::make_shared<Module>(std::move(metadata));
|
||||
|
||||
module->rootNode = ShaderBuilder::MultiStatement();
|
||||
ShaderSerializerVisitor visitor(*this);
|
||||
module->rootNode->Visit(visitor);
|
||||
|
||||
|
||||
@@ -25,11 +25,9 @@ namespace Nz::ShaderAst
|
||||
|
||||
ModulePtr EliminateUnusedPassVisitor::Process(const Module& shaderModule, const DependencyCheckerVisitor::UsageSet& usageSet)
|
||||
{
|
||||
ModulePtr clone = std::make_shared<Module>();
|
||||
clone->metadata = shaderModule.metadata;
|
||||
clone->rootNode = static_unique_pointer_cast<MultiStatement>(Process(*shaderModule.rootNode, usageSet));
|
||||
|
||||
return clone;
|
||||
auto rootNode = static_unique_pointer_cast<MultiStatement>(Process(*shaderModule.rootNode, usageSet));
|
||||
|
||||
return std::make_shared<Module>(shaderModule.metadata, std::move(rootNode));
|
||||
}
|
||||
|
||||
StatementPtr EliminateUnusedPassVisitor::Process(Statement& statement, const DependencyCheckerVisitor::UsageSet& usageSet)
|
||||
|
||||
@@ -141,8 +141,7 @@ namespace Nz::ShaderAst
|
||||
|
||||
ModulePtr SanitizeVisitor::Sanitize(const Module& module, const Options& options, std::string* error)
|
||||
{
|
||||
ModulePtr clone = std::make_shared<Module>();
|
||||
clone->metadata = module.metadata;
|
||||
ModulePtr clone = std::make_shared<Module>(module.metadata);
|
||||
|
||||
Context currentContext;
|
||||
currentContext.options = options;
|
||||
|
||||
@@ -304,13 +304,7 @@ namespace Nz::ShaderLang
|
||||
if (!moduleVersion.has_value())
|
||||
throw AttributeError{ "missing module version" };
|
||||
|
||||
m_context->module = std::make_shared<ShaderAst::Module>();
|
||||
m_context->module->rootNode = ShaderBuilder::MultiStatement();
|
||||
|
||||
std::shared_ptr<ShaderAst::Module::Metadata> moduleMetadata = std::make_shared<ShaderAst::Module::Metadata>();
|
||||
moduleMetadata->shaderLangVersion = *moduleVersion;
|
||||
|
||||
m_context->module->metadata = std::move(moduleMetadata);
|
||||
m_context->module = std::make_shared<ShaderAst::Module>(*moduleVersion);
|
||||
|
||||
Expect(Advance(), TokenType::Semicolon);
|
||||
}
|
||||
|
||||
@@ -459,12 +459,7 @@ QJsonObject ShaderGraph::Save()
|
||||
|
||||
Nz::ShaderAst::ModulePtr ShaderGraph::ToModule() const
|
||||
{
|
||||
Nz::ShaderAst::ModulePtr shaderModule = std::make_shared<Nz::ShaderAst::Module>();
|
||||
|
||||
std::shared_ptr<Nz::ShaderAst::Module::Metadata> moduleMetada = std::make_shared<Nz::ShaderAst::Module::Metadata>();
|
||||
moduleMetada->shaderLangVersion = 100;
|
||||
|
||||
shaderModule->metadata = std::move(moduleMetada);
|
||||
Nz::ShaderAst::ModulePtr shaderModule = std::make_shared<Nz::ShaderAst::Module>(100);
|
||||
|
||||
// Declare all options
|
||||
for (const auto& option : m_options)
|
||||
|
||||
Reference in New Issue
Block a user