X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Frenderpass.h;h=428c74ce7b1f280046e4268b66ec7005d2cf7a4c;hb=146df2d02940a04aeafe854bdd981a1489cc80b3;hp=3570151258beb225f84ecd6ef43dd269f8579c7b;hpb=3500f13f51dabadd2e7f06b81820936520cc8115;p=libs%2Fgl.git diff --git a/source/renderpass.h b/source/renderpass.h index 35701512..428c74ce 100644 --- a/source/renderpass.h +++ b/source/renderpass.h @@ -34,6 +34,7 @@ public: void material_inline(); void material(const std::string &); + void shader(const std::string &); void texunit(unsigned); void texunit_auto(const std::string &); void texunit_named(unsigned, const std::string &); @@ -58,7 +59,8 @@ private: void texture2d(); }; - const Program *shprog; + RefPtr shprog; + bool shprog_from_material; RefPtr shdata; std::map uniform_slots; RefPtr material; @@ -74,12 +76,13 @@ public: ~RenderPass(); private: - void finalize_material(); + void finalize_material(DataFile::Collection *); + void maybe_create_material_shader(DataFile::Collection *); void ensure_private_shader_data(); public: void set_shader_program(const Program *, const ProgramData *); - const Program *get_shader_program() const { return shprog; } + const Program *get_shader_program() const { return shprog.get(); } const ProgramData *get_shader_data() const { return shdata.get(); } const std::string &get_slotted_uniform_name(const std::string &) const; void set_material(const Material *);