X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fprogram.h;h=af249edefa2066c29bcf23e7c6f643ddd7d6c95c;hb=cea3c333797cadd9629aefaa5b82243173a02d16;hp=682ac99fb895b02498a9f9054735f69c558d44a0;hpb=1431f24f29bd6862d547b831c40b2686ff56d1ef;p=libs%2Fgl.git diff --git a/source/program.h b/source/program.h index 682ac99f..af249ede 100644 --- a/source/program.h +++ b/source/program.h @@ -11,7 +11,7 @@ Distributed under the LGPL #include #include #include -#include "shader.h" +#include #include "types.h" namespace Msp { @@ -21,24 +21,56 @@ class Shader; class Program { +private: + uint id; + std::list shaders; + bool del_shaders; + bool linked; + + static Program *cur_prog; + public: + class Loader: public DataFile::Loader + { + private: + Program &prog; + + public: + Loader(Program &); + ~Loader(); + + private: + void vertex_shader(const std::string &); + void fragment_shader(const std::string &); + }; + Program(); - ~Program(); + Program(const std::string &, const std::string &); + virtual ~Program(); void attach_shader(Shader &shader); void detach_shader(Shader &shader); + const std::list &get_shaders() const { return shaders; } + void set_del_shaders(bool); + void bind_attribute(int, const std::string &); bool link(); int get_param(GLenum param) const; + bool get_linked() const { return linked; } std::string get_info_log() const; void bind(); + int get_uniform_location(const std::string &) const; + void uniform(int, int); + void uniform(int, float); + void uniform(int, float, float); + void uniform(int, float, float, float); + void uniform(int, float, float, float, float); + void uniform4(int, const float *); + void uniform_matrix4(int, const float *); static void unbind(); -private: - uint id; - std::list shaders; - bool linked; - static Program *cur_prog; +private: + void maybe_bind(); }; } // namespace GL