X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fglsl%2Ffinalize.h;h=4f6ee4193bd869ba61ace5191cc1cd9382b14b4e;hb=d03f6d46d0646c53ec3dcd00ddfd6c718ad18720;hp=212007131e80a3d0e37173364005d68f3b8d1166;hpb=c8de66203565f07f10898a74dbd55072432790fc;p=libs%2Fgl.git diff --git a/source/glsl/finalize.h b/source/glsl/finalize.h index 21200713..4f6ee419 100644 --- a/source/glsl/finalize.h +++ b/source/glsl/finalize.h @@ -1,5 +1,5 @@ -#ifndef MSP_GL_SL_COMPATIBILITY_H_ -#define MSP_GL_SL_COMPATIBILITY_H_ +#ifndef MSP_GL_SL_FINALIZE_H_ +#define MSP_GL_SL_FINALIZE_H_ #include #include "visitor.h" @@ -8,37 +8,70 @@ namespace Msp { namespace GL { namespace SL { -/** Generates default precision declarations if they are missing, to satisfy -GLSL ES requirements. */ -class DefaultPrecisionGenerator: private TraversingVisitor +/** Assigns offset layout qualifiers to struct members. */ +class StructOrganizer: private TraversingVisitor { private: - Stage *stage; - std::set have_default; - NodeList::iterator insert_point; + int offset = -1; public: - DefaultPrecisionGenerator(); + void apply(Stage &s) { s.content.visit(*this); } - void apply(Stage &); +private: + virtual void visit(StructDeclaration &); + virtual void visit(VariableDeclaration &); +}; +/** Assigns location and binding layout qualifiers to interface variables and +blocks. */ +class LocationAllocator: private TraversingVisitor +{ private: - virtual void visit(Block &); - virtual void visit(Precision &); + struct Uniform + { + int location; + int desc_set; + int bind_point; + + Uniform(): location(-1), desc_set(-1), bind_point(-1) { } + }; + + std::map > used_locations; + std::map uniforms; + std::map > used_bindings; + std::vector unplaced_variables; + std::vector unbound_textures; + std::vector unbound_blocks; + +public: + void apply(Module &, const Features &); +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); + virtual void visit(VariableDeclaration &); + virtual void visit(InterfaceBlock &); + virtual void visit(FunctionDeclaration &) { } }; -/** Removes precision qualifiers from variable declarations, as well as -default precision declarations. */ -class PrecisionRemover: private TraversingVisitor +/** Generates default precision declarations or removes precision declarations +according to the requirements of the target API. */ +class PrecisionConverter: private TraversingVisitor { private: + Stage *stage = 0; + std::set have_default; + NodeList::iterator insert_point; std::set nodes_to_remove; public: void apply(Stage &); private: + virtual void visit(Block &); virtual void visit(Precision &); virtual void visit(VariableDeclaration &); }; @@ -48,35 +81,41 @@ features. */ class LegacyConverter: private TraversingVisitor { private: - Stage *stage; + Stage *stage = 0; Features features; - std::string r_type; - VariableDeclaration *frag_out; + VariableDeclaration *frag_out = 0; NodeList::iterator uniform_insert_point; std::set nodes_to_remove; + RefPtr r_replaced_reference; + bool r_flattened_interface = false; public: - LegacyConverter(); - virtual void apply(Stage &, const Features &); private: void unsupported(const std::string &); virtual void visit(Block &); + virtual void visit(RefPtr &); bool check_version(const Version &) const; bool check_extension(bool Features::*) const; 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 &); bool supports_interface_layouts() const; + bool supports_stage_interface_layouts() const; bool supports_centroid_sampling() const; bool supports_sample_sampling() const; + bool supports_uniform_location() const; + bool supports_binding() const; virtual void visit(VariableDeclaration &); bool supports_interface_blocks(const std::string &) const; + bool supports_interface_block_location() const; virtual void visit(InterfaceBlock &); };