X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcore%2Fprogram.h;h=b7f46ee4082a74a17ff68aa24328b6c5c01cf9f5;hb=1b23728908f5ec9beb08b2b70737c3903745fddc;hp=1ca146f1e998c0fd0d05221a4dab0b66a6da31e6;hpb=2e09b4f72f06537431151fe8b2574e1aa886ad48;p=libs%2Fgl.git diff --git a/source/core/program.h b/source/core/program.h index 1ca146f1..b7f46ee4 100644 --- a/source/core/program.h +++ b/source/core/program.h @@ -4,10 +4,9 @@ #include #include #include -#include "datatype.h" #include "gl.h" #include "module.h" -#include "tag.h" +#include "reflectdata.h" #include "vertexformat.h" namespace Msp { @@ -51,51 +50,6 @@ private: void specialize_int(const std::string &, int); }; -public: - typedef unsigned LayoutHash; - struct UniformBlockInfo; - - struct UniformInfo - { - std::string name; - const UniformBlockInfo *block; - union - { - int location; - unsigned offset; - }; - unsigned array_size; - unsigned array_stride; - unsigned matrix_stride; - DataType type; - Tag tag; - int binding; - - UniformInfo(); - }; - - struct UniformBlockInfo - { - std::string name; - unsigned data_size; - int bind_point; - std::vector uniforms; - LayoutHash layout_hash; - - UniformBlockInfo(); - }; - - struct AttributeInfo - { - std::string name; - unsigned location; - unsigned array_size; - DataType type; - - AttributeInfo(); - }; - -private: enum Stage { VERTEX, @@ -116,10 +70,7 @@ private: const Module *module; TransientData *transient; bool linked; - std::vector uniform_blocks; - std::vector uniforms; - LayoutHash uniform_layout_hash; - std::vector attributes; + ReflectData reflect_data; std::string debug_name; public: @@ -146,28 +97,26 @@ public: void link(); private: void query_uniforms(); - void query_uniform_blocks(const std::vector &); + void query_uniform_blocks(const std::vector &); void query_attributes(); void collect_uniforms(); void collect_block_uniforms(const SpirVModule::Structure &, const std::string &, unsigned, std::vector &); void collect_attributes(); - void update_layout_hash(); - static LayoutHash compute_layout_hash(const std::vector &); - static bool uniform_location_compare(const UniformInfo *, const UniformInfo *); + public: bool is_linked() const { return linked; } - LayoutHash get_uniform_layout_hash() const { return uniform_layout_hash; } - const std::vector &get_uniform_blocks() const { return uniform_blocks; } - 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; + ReflectData::LayoutHash get_uniform_layout_hash() const { return reflect_data.layout_hash; } + const std::vector &get_uniform_blocks() const { return reflect_data.uniform_blocks; } + const ReflectData::UniformBlockInfo &get_uniform_block_info(const std::string &) const; + const std::vector &get_uniforms() const { return reflect_data.uniforms; } + const ReflectData::UniformInfo &get_uniform_info(const std::string &) const; + const ReflectData::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; + const std::vector &get_attributes() const { return reflect_data.attributes; } + const ReflectData::AttributeInfo &get_attribute_info(const std::string &) const; int get_attribute_location(const std::string &) const; void set_debug_name(const std::string &);