X-Git-Url: http://git.mutantstargoat.com?a=blobdiff_plain;f=src%2Fshader.cc;h=39fa0de9e6ce6484760d6f4894f1c655e8b1dfdf;hb=c3d7c1b7f8a7f4bcfc7661b6baf166ce0648083a;hp=703c2dc852123a696af11a76cdc2ca357561c4e7;hpb=64e2adbbab48320b6cd792e515b44cea112a3be4;p=demo diff --git a/src/shader.cc b/src/shader.cc index 703c2dc..39fa0de 100644 --- a/src/shader.cc +++ b/src/shader.cc @@ -1,18 +1,71 @@ +#include #include #include "shader.h" Shader::Shader() {} -Shader::~Shader() {} +Shader::~Shader() +{ + type = SDR_UNKNOWN; +} -ShaderProgram::ShaderProgram() +bool Shader::load(const char *fname, SType type) +{ + switch(type) { + case SDR_VERTEX: + case SDR_FRAGMENT: + this->type = type; + break; + default: + fprintf(stderr, "Invalid shader type used in loading.\n"); + return false; + } + + FILE *fp; + unsigned int fsz; + + if(!(fp = fopen(fname, "rb"))) { + fprintf(stderr, "Failed to open shader: %s\n", fname); + + return false; + } + fseek(fp, 0, SEEK_END); + fsz = ftell(fp); + rewind(fp); + + char *buf = new char[fsz + 1]; + + if(fread(buf, 1, fsz, fp) < fsz) { + fprintf(stderr, "Failed to read shader: %s\n", fname); + delete buf; + fclose(fp); + + return false; + } + buf[fsz] = '\0'; + fclose(fp); + + create(buf, fsz, fname); + return true; +} + +SType Shader::get_type() { + return type; } -ShaderProgram::~ShaderProgram() +ShaderProgram::ShaderProgram() { + int len = sizeof shaders / sizeof *shaders; + for(int i=0; i