X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcore%2Fprogram.h;h=201d927037c57edf0d1464ca1af4002fb28a6d1a;hb=fea00edfb3b4274cb87e131743415e1fd22d0c1a;hp=6613a13451a8493224e4fe77f26dc6f17fcdcb46;hpb=0375be1a27f8852ed8ca422db78bf6380d2b11b1;p=libs%2Fgl.git diff --git a/source/core/program.h b/source/core/program.h index 6613a134..201d9270 100644 --- a/source/core/program.h +++ b/source/core/program.h @@ -8,6 +8,7 @@ #include "datatype.h" #include "gl.h" #include "module.h" +#include "tag.h" #include "vertexformat.h" namespace Msp { @@ -72,6 +73,8 @@ public: unsigned array_stride; unsigned matrix_stride; DataType type; + Tag tag; + int binding; UniformInfo(); }; @@ -98,16 +101,17 @@ public: }; private: - struct Bindings + struct TransientData { std::map textures; std::map blocks; + std::map spec_values; }; unsigned id; std::vector stage_ids; const Module *module; - Bindings *bindings; + TransientData *transient; bool linked; std::vector uniform_blocks; std::vector uniforms; @@ -160,9 +164,6 @@ private: void update_layout_hash(); static LayoutHash compute_layout_hash(const std::vector &); static bool uniform_location_compare(const UniformInfo *, const UniformInfo *); - static bool uniform_name_compare(const UniformInfo &, const UniformInfo &); - template - static bool name_search(const T &, const std::string &); public: bool is_linked() const { return linked; } DEPRECATED std::string get_info_log() const; @@ -172,7 +173,10 @@ public: const UniformBlockInfo &get_uniform_block_info(const std::string &) const; const std::vector &get_uniforms() const { return uniforms; } const UniformInfo &get_uniform_info(const std::string &) const; + const UniformInfo &get_uniform_info(Tag) const; int get_uniform_location(const std::string &) const; + int get_uniform_location(Tag) const; + int get_uniform_binding(Tag) const; const std::vector &get_attributes() const { return attributes; } const AttributeInfo &get_attribute_info(const std::string &) const; int get_attribute_location(const std::string &) const;