X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fglsl%2Freflect.cpp;h=a1ffcd3d449783caf24aa9c79d4c403199972234;hp=8ee8a88dfe96750dd3234d88a751cc131e27ad10;hb=0585e361d8714ac4efc3ae3e1d5c8c9aa8841c34;hpb=23779cd03a8b1f6fdc3b2e4d8880170d3fa6146f diff --git a/source/glsl/reflect.cpp b/source/glsl/reflect.cpp index 8ee8a88d..a1ffcd3d 100644 --- a/source/glsl/reflect.cpp +++ b/source/glsl/reflect.cpp @@ -1,4 +1,5 @@ #include +#include #include "reflect.h" using namespace std; @@ -283,6 +284,9 @@ void MemoryRequirementsCalculator::visit(BasicTypeDeclaration &basic) } else if(basic.kind==BasicTypeDeclaration::ARRAY) basic.base_type->visit(*this); + + if(basic.extended_alignment) + r_alignment = (r_alignment+15)&~15U; } void MemoryRequirementsCalculator::visit(StructDeclaration &strct) @@ -295,7 +299,7 @@ void MemoryRequirementsCalculator::visit(StructDeclaration &strct) r_alignment = 1; r_offset = -1; s->visit(*this); - if(r_offset) + if(r_offset>=0) total = r_offset; total += r_alignment-1; total -= total%r_alignment; @@ -304,16 +308,15 @@ void MemoryRequirementsCalculator::visit(StructDeclaration &strct) } r_size = total; r_alignment = max_align; + if(strct.extended_alignment) + r_alignment = (r_alignment+15)&~15U; + r_size += r_alignment-1; + r_size -= r_size%r_alignment; } void MemoryRequirementsCalculator::visit(VariableDeclaration &var) { - if(var.layout) - { - auto i = find_member(var.layout->qualifiers, string("offset"), &Layout::Qualifier::name); - if(i!=var.layout->qualifiers.end()) - r_offset = i->value; - } + r_offset = get_layout_value(var.layout.get(), "offset"); if(var.type_declaration) var.type_declaration->visit(*this); @@ -323,7 +326,7 @@ void MemoryRequirementsCalculator::visit(VariableDeclaration &var) { unsigned aligned_size = r_size+r_alignment-1; aligned_size -= aligned_size%r_alignment; - r_size += aligned_size*(literal->value.value()-1); + r_size = aligned_size*literal->value.value(); } } @@ -385,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