X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fglsl%2Freflect.cpp;h=811679f3295c320b30d2caaf8bb92d7ac164f992;hp=6027acde36862363a6597bebe60db488fa666351;hb=9978e2f62777795bf478b301aadffdd0ee8cbd41;hpb=31f76e306f8e01884fa464ac6e09e8b48af5f79b diff --git a/source/glsl/reflect.cpp b/source/glsl/reflect.cpp index 6027acde..811679f3 100644 --- a/source/glsl/reflect.cpp +++ b/source/glsl/reflect.cpp @@ -1,4 +1,5 @@ #include +#include #include "reflect.h" using namespace std; @@ -387,16 +388,44 @@ void DependencyCollector::visit(FunctionDeclaration &func) } -set AssignmentCollector::apply(Node &node) +set AssignmentCollector::apply(Node &node) { node.visit(*this); return assigned_variables; } +void AssignmentCollector::visit(VariableReference &var) +{ + if(assignment_target) + assigned_variables.insert(var.declaration); +} + +void AssignmentCollector::visit(InterfaceBlockReference &iface) +{ + if(assignment_target) + assigned_variables.insert(iface.declaration); +} + +void AssignmentCollector::visit(UnaryExpression &unary) +{ + SetFlag set_assignment(assignment_target, (unary.oper->token[1]=='+' || unary.oper->token[1]=='-')); + TraversingVisitor::visit(unary); +} + +void AssignmentCollector::visit(BinaryExpression &binary) +{ + binary.left->visit(*this); + SetFlag clear_assignment(assignment_target, false); + binary.right->visit(*this); +} + void AssignmentCollector::visit(Assignment &assign) { - if(VariableDeclaration *var = dynamic_cast(assign.target.declaration)) - assigned_variables.insert(var); + { + SetFlag set_assignment(assignment_target); + assign.left->visit(*this); + } + assign.right->visit(*this); } } // namespace SL