Merge fix
This commit is contained in:
@@ -17,6 +17,7 @@ namespace Nz::ShaderAst
|
||||
class NAZARA_SHADER_API DependencyCheckerVisitor : public AstRecursiveVisitor
|
||||
{
|
||||
public:
|
||||
struct Config;
|
||||
struct UsageSet;
|
||||
|
||||
DependencyCheckerVisitor() = default;
|
||||
@@ -26,21 +27,18 @@ namespace Nz::ShaderAst
|
||||
|
||||
inline const UsageSet& GetUsage() const;
|
||||
|
||||
void Process(Statement& statement, const Config& config = {});
|
||||
|
||||
inline void Resolve();
|
||||
|
||||
using AstRecursiveVisitor::Visit;
|
||||
|
||||
void Visit(CallFunctionExpression& node) override;
|
||||
void Visit(VariableExpression& node) override;
|
||||
|
||||
void Visit(DeclareExternalStatement& node) override;
|
||||
void Visit(DeclareFunctionStatement& node) override;
|
||||
void Visit(DeclareStructStatement& node) override;
|
||||
void Visit(DeclareVariableStatement& node) override;
|
||||
|
||||
DependencyCheckerVisitor& operator=(const DependencyCheckerVisitor&) = delete;
|
||||
DependencyCheckerVisitor& operator=(DependencyCheckerVisitor&&) = delete;
|
||||
|
||||
struct Config
|
||||
{
|
||||
ShaderStageTypeFlags usedShaderStages = ShaderStageType_All;
|
||||
};
|
||||
|
||||
struct UsageSet
|
||||
{
|
||||
Bitset<> usedFunctions;
|
||||
@@ -51,11 +49,22 @@ namespace Nz::ShaderAst
|
||||
private:
|
||||
void Resolve(const UsageSet& usageSet);
|
||||
|
||||
using AstRecursiveVisitor::Visit;
|
||||
|
||||
void Visit(CallFunctionExpression& node) override;
|
||||
void Visit(VariableExpression& node) override;
|
||||
|
||||
void Visit(DeclareExternalStatement& node) override;
|
||||
void Visit(DeclareFunctionStatement& node) override;
|
||||
void Visit(DeclareStructStatement& node) override;
|
||||
void Visit(DeclareVariableStatement& node) override;
|
||||
|
||||
std::optional<std::size_t> m_currentFunctionIndex;
|
||||
std::optional<std::size_t> m_currentVariableDeclIndex;
|
||||
std::unordered_map<std::size_t, UsageSet> m_functionUsages;
|
||||
std::unordered_map<std::size_t, UsageSet> m_structUsages;
|
||||
std::unordered_map<std::size_t, UsageSet> m_variableUsages;
|
||||
Config m_config;
|
||||
UsageSet m_globalUsage;
|
||||
UsageSet m_resolvedUsage;
|
||||
};
|
||||
|
||||
@@ -11,29 +11,23 @@
|
||||
#include <Nazara/Core/Bitset.hpp>
|
||||
#include <Nazara/Shader/Config.hpp>
|
||||
#include <Nazara/Shader/Ast/AstCloner.hpp>
|
||||
#include <Nazara/Shader/Ast/DependencyCheckerVisitor.hpp>
|
||||
|
||||
namespace Nz::ShaderAst
|
||||
{
|
||||
class NAZARA_SHADER_API EliminateUnusedPassVisitor : AstCloner
|
||||
{
|
||||
public:
|
||||
struct Config;
|
||||
|
||||
EliminateUnusedPassVisitor() = default;
|
||||
EliminateUnusedPassVisitor(const EliminateUnusedPassVisitor&) = delete;
|
||||
EliminateUnusedPassVisitor(EliminateUnusedPassVisitor&&) = delete;
|
||||
~EliminateUnusedPassVisitor() = default;
|
||||
|
||||
StatementPtr Process(Statement& statement, const Config& config = {});
|
||||
StatementPtr Process(Statement& statement, const DependencyCheckerVisitor::UsageSet& usageSet);
|
||||
|
||||
EliminateUnusedPassVisitor& operator=(const EliminateUnusedPassVisitor&) = delete;
|
||||
EliminateUnusedPassVisitor& operator=(EliminateUnusedPassVisitor&&) = delete;
|
||||
|
||||
struct Config
|
||||
{
|
||||
ShaderStageTypeFlags usedShaderStages = ShaderStageType_All;
|
||||
};
|
||||
|
||||
private:
|
||||
using AstCloner::Clone;
|
||||
StatementPtr Clone(DeclareExternalStatement& node) override;
|
||||
@@ -49,7 +43,8 @@ namespace Nz::ShaderAst
|
||||
Context* m_context;
|
||||
};
|
||||
|
||||
inline StatementPtr EliminateUnusedPass(Statement& ast, const EliminateUnusedPassVisitor::Config& config = {});
|
||||
inline StatementPtr EliminateUnusedPass(Statement& ast, const DependencyCheckerVisitor::Config& config = {});
|
||||
inline StatementPtr EliminateUnusedPass(Statement& ast, const DependencyCheckerVisitor::UsageSet& usageSet);
|
||||
}
|
||||
|
||||
#include <Nazara/Shader/Ast/EliminateUnusedPassVisitor.inl>
|
||||
|
||||
@@ -7,10 +7,19 @@
|
||||
|
||||
namespace Nz::ShaderAst
|
||||
{
|
||||
inline StatementPtr EliminateUnusedPass(Statement& ast, const EliminateUnusedPassVisitor::Config& config)
|
||||
inline StatementPtr EliminateUnusedPass(Statement& ast, const DependencyCheckerVisitor::Config& config)
|
||||
{
|
||||
DependencyCheckerVisitor dependencyVisitor;
|
||||
dependencyVisitor.Process(ast, config);
|
||||
dependencyVisitor.Resolve();
|
||||
|
||||
return EliminateUnusedPass(ast, dependencyVisitor.GetUsage());
|
||||
}
|
||||
|
||||
StatementPtr EliminateUnusedPass(Statement& ast, const DependencyCheckerVisitor::UsageSet& usageSet)
|
||||
{
|
||||
EliminateUnusedPassVisitor visitor;
|
||||
return visitor.Process(ast, config);
|
||||
return visitor.Process(ast, usageSet);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user