diff options
author | sanine <sanine.not@pm.me> | 2022-08-22 10:31:56 -0500 |
---|---|---|
committer | sanine <sanine.not@pm.me> | 2022-08-22 10:31:56 -0500 |
commit | 65ad3a58adcfe21690f379ab894a104b3852e3e9 (patch) | |
tree | 2e86cb35d06b29ac98ca22c7eb6d051d4fde855b | |
parent | f84ee69cdf694a1f64f2536efed4b7d0dd75553a (diff) |
refactor: move shader functions into separate file
-rw-r--r-- | CMakeLists.txt | 1 | ||||
-rw-r--r-- | demo/honey.lua | 26 | ||||
-rw-r--r-- | src/gl/gl.c | 120 | ||||
-rw-r--r-- | src/gl/gl.h | 1 | ||||
-rw-r--r-- | src/gl/shader.c | 124 |
5 files changed, 144 insertions, 128 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt index b5e8502..618e8de 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -36,6 +36,7 @@ set(HONEY_LIB_FILES ${SRC_ROOT}/logging/logging.c ${SRC_ROOT}/gl/glad/glad.c ${SRC_ROOT}/gl/gl.c + ${SRC_ROOT}/gl/shader.c ${SRC_ROOT}/gl/window.c ) diff --git a/demo/honey.lua b/demo/honey.lua index 15acbf2..0a4758a 100644 --- a/demo/honey.lua +++ b/demo/honey.lua @@ -46,19 +46,19 @@ void main() } ]] -local vertexShader = gl.createShader(gl.shaderType.vertexShader) -gl.setShaderSource(vertexShader, vertexShaderSource) -gl.compileShader(vertexShader) -local fragmentShader = gl.createShader(gl.shaderType.fragmentShader) -gl.setShaderSource(fragmentShader, fragmentShaderSource) -gl.compileShader(fragmentShader) +local vertexShader = gl.shader.create(gl.shader.type.vertexShader) +gl.shader.setSource(vertexShader, vertexShaderSource) +gl.shader.compile(vertexShader) +local fragmentShader = gl.shader.create(gl.shader.type.fragmentShader) +gl.shader.setSource(fragmentShader, fragmentShaderSource) +gl.shader.compile(fragmentShader) -local shader = gl.createProgram() -gl.programAttachShader(shader, vertexShader) -gl.programAttachShader(shader, fragmentShader) -gl.linkProgram(shader) -gl.deleteShader(vertexShader) -gl.deleteShader(fragmentShader) +local shader = gl.shader.createProgram() +gl.shader.attachShader(shader, vertexShader) +gl.shader.attachShader(shader, fragmentShader) +gl.shader.link(shader) +gl.shader.delete(vertexShader) +gl.shader.delete(fragmentShader) local vertices = { @@ -90,7 +90,7 @@ while not window.shouldClose(w) do gl.setClearColor(0.2, 0.3, 0.3, 1.0) gl.clear(gl.bufferMask.colorBuffer); - gl.useProgram(shader) + gl.shader.use(shader) gl.bindVertexArray(vertexArray) gl.drawArrays(gl.primitiveType.triangles, 0, 3) diff --git a/src/gl/gl.c b/src/gl/gl.c index cef93fa..d0fb33c 100644 --- a/src/gl/gl.c +++ b/src/gl/gl.c @@ -4,6 +4,7 @@ #include <GLFW/glfw3.h> #include <lua.h> #include <honeysuckle.h> +#include "gl.h" /* needs to be here because glad uses macros to define glBufferData */ #ifdef HONEY_TEST_H @@ -27,17 +28,6 @@ int gl_vertex_array_bind(lua_State *L); int gl_vertex_attrib_pointer(lua_State *L); int gl_vertex_array_enable_attrib(lua_State *L); -/* shaders */ -int gl_create_shader(lua_State *L); -int gl_shader_set_source(lua_State *L); -int gl_shader_compile(lua_State *L); -int gl_shader_delete(lua_State *L); - -int gl_program_create(lua_State *L); -int gl_program_attach_shader(lua_State *L); -int gl_program_link(lua_State *L); -int gl_program_use(lua_State *L); - /* drawing */ int gl_set_viewport(lua_State *L); int gl_draw_arrays(lua_State *L); @@ -63,6 +53,7 @@ void setup_gl(lua_State *L, int honey_index) int buffer_binding_targets = hs_create_table(L, hs_str_int("arrayBuffer", GL_ARRAY_BUFFER), + hs_str_int("elementArrayBuffer", GL_ELEMENT_ARRAY_BUFFER), ); int buffer_usage_patterns = hs_create_table(L, @@ -71,11 +62,6 @@ void setup_gl(lua_State *L, int honey_index) hs_str_int("dynamicDraw", GL_DYNAMIC_DRAW), ); - int shader_types = hs_create_table(L, - hs_str_int("vertexShader", GL_VERTEX_SHADER), - hs_str_int("fragmentShader", GL_FRAGMENT_SHADER), - ); - int primitive_types = hs_create_table(L, hs_str_int("points", GL_POINTS), hs_str_int("lines", GL_LINES), @@ -88,7 +74,7 @@ void setup_gl(lua_State *L, int honey_index) hs_str_int("stencilBuffer", GL_STENCIL_BUFFER_BIT), ); - hs_create_table(L, + int gl_index = hs_create_table(L, hs_str_cfunc("init", gl_init), hs_str_cfunc("initGlad", glad_init), hs_str_cfunc("terminate", gl_terminate), @@ -110,19 +96,6 @@ void setup_gl(lua_State *L, int honey_index) hs_str_tbl("bufferTarget", buffer_binding_targets), hs_str_tbl("bufferUsage", buffer_usage_patterns), - /* shader */ - hs_str_cfunc("createShader", gl_create_shader), - hs_str_cfunc("setShaderSource", gl_shader_set_source), - hs_str_cfunc("compileShader", gl_shader_compile), - hs_str_cfunc("deleteShader", gl_shader_delete), - - hs_str_cfunc("createProgram", gl_program_create), - hs_str_cfunc("programAttachShader", gl_program_attach_shader), - hs_str_cfunc("linkProgram", gl_program_link), - hs_str_cfunc("useProgram", gl_program_use), - - hs_str_tbl("shaderType", shader_types), - /* drawing */ hs_str_cfunc("drawArrays", gl_draw_arrays), hs_str_cfunc("setClearColor", gl_set_clear_color), @@ -132,6 +105,8 @@ void setup_gl(lua_State *L, int honey_index) hs_str_tbl("primitiveType", primitive_types), hs_str_tbl("bufferMask", buffer_masks), ); + + setup_shader(L, gl_index); lua_setfield(L, honey_index, "gl"); } @@ -236,91 +211,6 @@ int gl_buffer_data(lua_State *L) } -int gl_create_shader(lua_State *L) -{ - lua_Integer type; - hs_parse_args(L, hs_int(type)); - lua_Integer shader = glCreateShader(type); - lua_pushinteger(L, shader); - return 1; -} - - -int gl_shader_set_source(lua_State *L) -{ - lua_Integer shader; - char *code; - hs_parse_args(L, hs_int(shader), hs_str(code)); - glShaderSource(shader, 1, &code, NULL); - return 0; -} - - -int gl_shader_compile(lua_State *L) -{ - lua_Integer shader; - hs_parse_args(L, hs_int(shader)); - glCompileShader(shader); - int success; char log[1024]; - glGetShaderiv(shader, GL_COMPILE_STATUS, &success); - if (!success) { - glGetShaderInfoLog(shader, 1024, NULL, log); - hs_throw_error(L, "shader compilation failed: %s", log); - } - return 0; -} - - -int gl_shader_delete(lua_State *L) -{ - lua_Integer shader; - hs_parse_args(L, hs_int(shader)); - glDeleteShader(shader); - return 0; -} - - -int gl_program_create(lua_State *L) -{ - lua_Integer program = glCreateProgram(); - lua_pushinteger(L, program); - return 1; -} - - -int gl_program_attach_shader(lua_State *L) -{ - lua_Integer program, shader; - hs_parse_args(L, hs_int(program), hs_int(shader)), - glAttachShader(program, shader); - return 0; -} - - -int gl_program_link(lua_State *L) -{ - lua_Integer program; - hs_parse_args(L, hs_int(program)); - glLinkProgram(program); - int success; char log[1024]; - glGetProgramiv(program, GL_LINK_STATUS, &success); - if (!success) { - glGetProgramInfoLog(program, 1024, NULL, log); - hs_throw_error(L, "shader linking failed: %s", log); - } - return 0; -} - - -int gl_program_use(lua_State *L) -{ - lua_Integer program; - hs_parse_args(L, hs_int(program)); - glUseProgram(program); - return 0; -} - - int gl_vertex_array_create(lua_State *L) { int array; diff --git a/src/gl/gl.h b/src/gl/gl.h index 2e27851..b209957 100644 --- a/src/gl/gl.h +++ b/src/gl/gl.h @@ -4,6 +4,7 @@ #include <lua.h> void setup_gl(lua_State *L, int honey_index); +void setup_shader(lua_State *L, int gl_index); void setup_window(lua_State *L, int honey_index); #endif diff --git a/src/gl/shader.c b/src/gl/shader.c new file mode 100644 index 0000000..96946fe --- /dev/null +++ b/src/gl/shader.c @@ -0,0 +1,124 @@ +#include "gl/glad/glad.h" +#include <GLFW/glfw3.h> +#include <lua.h> +#include <honeysuckle.h> + +int gl_create_shader(lua_State *L); +int gl_shader_set_source(lua_State *L); +int gl_shader_compile(lua_State *L); +int gl_shader_delete(lua_State *L); + +int gl_program_create(lua_State *L); +int gl_program_attach_shader(lua_State *L); +int gl_program_link(lua_State *L); +int gl_program_use(lua_State *L); + + +void setup_shader(lua_State *L, int gl_index) +{ + int shader_types = hs_create_table(L, + hs_str_int("vertexShader", GL_VERTEX_SHADER), + hs_str_int("fragmentShader", GL_FRAGMENT_SHADER), + ); + + hs_create_table(L, + hs_str_cfunc("create", gl_create_shader), + hs_str_cfunc("setSource", gl_shader_set_source), + hs_str_cfunc("compile", gl_shader_compile), + hs_str_cfunc("delete", gl_shader_delete), + + hs_str_cfunc("createProgram", gl_program_create), + hs_str_cfunc("attachShader", gl_program_attach_shader), + hs_str_cfunc("link", gl_program_link), + hs_str_cfunc("use", gl_program_use), + + hs_str_tbl("type", shader_types), + ); + + lua_setfield(L, gl_index, "shader"); +} + + +int gl_create_shader(lua_State *L) +{ + lua_Integer type; + hs_parse_args(L, hs_int(type)); + lua_Integer shader = glCreateShader(type); + lua_pushinteger(L, shader); + return 1; +} + + +int gl_shader_set_source(lua_State *L) +{ + lua_Integer shader; + char *code; + hs_parse_args(L, hs_int(shader), hs_str(code)); + glShaderSource(shader, 1, &code, NULL); + return 0; +} + + +int gl_shader_compile(lua_State *L) +{ + lua_Integer shader; + hs_parse_args(L, hs_int(shader)); + glCompileShader(shader); + int success; char log[1024]; + glGetShaderiv(shader, GL_COMPILE_STATUS, &success); + if (!success) { + glGetShaderInfoLog(shader, 1024, NULL, log); + hs_throw_error(L, "shader compilation failed: %s", log); + } + return 0; +} + + +int gl_shader_delete(lua_State *L) +{ + lua_Integer shader; + hs_parse_args(L, hs_int(shader)); + glDeleteShader(shader); + return 0; +} + + +int gl_program_create(lua_State *L) +{ + lua_Integer program = glCreateProgram(); + lua_pushinteger(L, program); + return 1; +} + + +int gl_program_attach_shader(lua_State *L) +{ + lua_Integer program, shader; + hs_parse_args(L, hs_int(program), hs_int(shader)), + glAttachShader(program, shader); + return 0; +} + + +int gl_program_link(lua_State *L) +{ + lua_Integer program; + hs_parse_args(L, hs_int(program)); + glLinkProgram(program); + int success; char log[1024]; + glGetProgramiv(program, GL_LINK_STATUS, &success); + if (!success) { + glGetProgramInfoLog(program, 1024, NULL, log); + hs_throw_error(L, "shader linking failed: %s", log); + } + return 0; +} + + +int gl_program_use(lua_State *L) +{ + lua_Integer program; + hs_parse_args(L, hs_int(program)); + glUseProgram(program); + return 0; +} |