X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fglsl%2Ffinalize.h;h=79ba54b81b027c8b16743e0f1281b3e961611319;hb=5be19592e0c75ea8f9b7e5abb31b4fabd907d9ef;hp=263be454f252038cbee069abedcf854c9729ec97;hpb=c32051dc7e77faf0fe6bdad2a6f1025e7b43da19;p=libs%2Fgl.git diff --git a/source/glsl/finalize.h b/source/glsl/finalize.h index 263be454..79ba54b8 100644 --- a/source/glsl/finalize.h +++ b/source/glsl/finalize.h @@ -29,31 +29,30 @@ class LocationAllocator: private TraversingVisitor private: struct Uniform { - int location; - int desc_set; - int bind_point; - - Uniform(): location(-1), desc_set(-1), bind_point(-1) { } + int location = -1; + int desc_set = 0; + int bind_point = -1; }; + Features features; + bool alloc_new = true; std::map > used_locations; std::map uniforms; std::map > used_bindings; std::vector unplaced_variables; std::vector unbound_textures; - std::vector unbound_blocks; + std::vector unbound_blocks; public: - void apply(Module &, const Features &); + void apply(Module &, const Features &, bool = true); private: void apply(Stage &); void allocate_locations(const std::string &); void bind_uniform(RefPtr &, const std::string &, unsigned); - void add_layout_value(RefPtr &, const std::string &, unsigned); + bool visit_uniform(const std::string &, RefPtr &); virtual void visit(VariableDeclaration &); - virtual void visit(InterfaceBlock &); virtual void visit(FunctionDeclaration &) { } }; @@ -117,14 +116,12 @@ private: bool supports_stage(Stage::Type) const; bool supports_unified_interface_syntax() const; virtual void visit(VariableReference &); - virtual void visit(InterfaceBlockReference &); virtual void visit(MemberAccess &); virtual void visit(Assignment &); bool supports_unified_sampling_functions() const; virtual void visit(FunctionCall &); - virtual void visit(VariableDeclaration &); bool supports_interface_blocks(const std::string &) const; - virtual void visit(InterfaceBlock &); + virtual void visit(VariableDeclaration &); }; /** Converts qualifiers on variables and blocksto match a particular set of @@ -142,9 +139,8 @@ private: bool supports_sample_sampling() const; bool supports_uniform_location() const; bool supports_binding() const; - virtual void visit(VariableDeclaration &); bool supports_interface_block_location() const; - virtual void visit(InterfaceBlock &); + virtual void visit(VariableDeclaration &); }; } // namespace SL