X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?p=laserbrain_demo;a=blobdiff_plain;f=src%2Fopengl.c;h=80f712d1b36396581bf8679b29698b98aeaf9465;hp=9fe7ea3f7a817c04a9aba0dd2c1b77328af3c375;hb=da8e3a1dd04a5ac29bcaa9582430c58a769ac571;hpb=215f16e2f26cc2acc79255bab06f13452ec06ae5 diff --git a/src/opengl.c b/src/opengl.c index 9fe7ea3..80f712d 100644 --- a/src/opengl.c +++ b/src/opengl.c @@ -1,8 +1,11 @@ +#include #include "opengl.h" #include "logger.h" -static void gldebug_logger(unsigned int src, unsigned int type, unsigned int id, - unsigned int severity, int len, const char *msg, const void *cls); + +static void GLAPIENTRY gldebug_logger(GLenum src, GLenum type, GLuint id, GLenum severity, + GLsizei len, const char *msg, const void *cls); + static const char *gldebug_srcstr(unsigned int src); static const char *gldebug_typestr(unsigned int type); static const char *gldebug_sevstr(unsigned int sev); @@ -14,6 +17,7 @@ int init_opengl(void) glewInit(); glcaps.debug = GLEW_ARB_debug_output; + glcaps.draw_range = GLEW_EXT_draw_range_elements; #ifndef NDEBUG if(glcaps.debug) { @@ -25,9 +29,36 @@ int init_opengl(void) return 0; } +void dump_gl_texture(unsigned int tex, const char *fname) +{ + FILE *fp; + int i, width, height; + unsigned char *pixels; + + glBindTexture(GL_TEXTURE_2D, tex); + glGetTexLevelParameteriv(GL_TEXTURE_2D, 0, GL_TEXTURE_WIDTH, &width); + glGetTexLevelParameteriv(GL_TEXTURE_2D, 0, GL_TEXTURE_HEIGHT, &height); + + if(!(pixels = malloc(width * height * 3))) { + return; + } + glGetTexImage(GL_TEXTURE_2D, 0, GL_RGB, GL_UNSIGNED_BYTE, pixels); + + if(!(fp = fopen(fname, "wb"))) { + free(pixels); + return; + } + fprintf(fp, "P6\n%d %d\n255\n", width, height); + for(i=0; i