From 71669e3a14fd2ea16cd452a24c03553ddc331612 Mon Sep 17 00:00:00 2001 From: Zeno Rogue Date: Sun, 25 Aug 2019 19:14:28 +0200 Subject: [PATCH] shader debug support --- shaders.cpp | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/shaders.cpp b/shaders.cpp index b09c5267..ce1858fa 100644 --- a/shaders.cpp +++ b/shaders.cpp @@ -293,7 +293,10 @@ struct GLprogram { GLint uMVP, uFog, uFogColor, uColor, tTexture, tInvExpTable, uMV, uProjection, uAlpha, uFogBase; GLint uPRECX, uPRECY, uPRECZ, uIndexSL, uIterations; + string _vsh, _fsh; + GLprogram(string vsh, string fsh) { + _vsh = vsh; _fsh = fsh; _program = glCreateProgram(); #ifndef GLES_ONLY @@ -475,6 +478,17 @@ EX void be_nontextured(shader_projection sp IS(new_shader_projection)) { switch_ EX void be_textured(shader_projection sp IS(new_shader_projection)) { switch_mode(gmTextured, sp); } EX void use_projection(shader_projection sp IS(new_shader_projection)) { switch_mode(mode, sp); } +EX pair get_shaders() { + auto p = programs[mode][int(current_shader_projection)]; + return make_pair(p->_vsh, p->_fsh); + } + +EX void install_shaders(string vsh, string fsh) { + delete programs[mode][int(current_shader_projection)]; + programs[mode][int(current_shader_projection)] = new GLprogram(vsh, fsh); + mode = eMode(-1); + } + void switch_mode(eMode m, shader_projection sp) { if(m == mode && current_shader_projection == sp) return; reset_projection();