X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Ftechnique.h;h=1078433f39f7d5c028b80ca622150882446ac3e4;hp=d1fab38f7ad9649f45d7c2be6b9fd4f805a1e3d0;hb=133fe7352831197c9ec59f923c1126651d80edcb;hpb=a86623004ba91baef76dac9275e9b79366acce16 diff --git a/source/technique.h b/source/technique.h index d1fab38f..1078433f 100644 --- a/source/technique.h +++ b/source/technique.h @@ -1,5 +1,5 @@ -#ifndef TECHNIQUE_H_ -#define TECHNIQUE_H_ +#ifndef MSP_GL_TECHNIQUE_H_ +#define MSP_GL_TECHNIQUE_H_ #include "renderpass.h" #include "tag.h" @@ -11,6 +11,7 @@ class Material; class Texture; /** +Ties multiple tagged render passes together. */ class Technique { @@ -34,6 +35,7 @@ private: InheritLoader(Technique &, Collection &); private: + void material(const std::string &, const std::string &); void texture(const std::string &, const std::string &); }; @@ -44,10 +46,12 @@ private: PassMap passes; public: - RenderPass &add_pass(const GL::Tag &); - bool has_pass(const GL::Tag &) const; - const RenderPass &get_pass(const GL::Tag &) const; + RenderPass &add_pass(const Tag &); + bool has_pass(const Tag &) const; + const RenderPass &get_pass(const Tag &) const; const PassMap &get_passes() const { return passes; } + bool replace_texture(const std::string &, const Texture &); + bool replace_material(const std::string &, const Material &); bool has_shaders() const; };