X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=vg%2Fvg.h;h=c6b8fb9d21af30ad17914dca6bb19244da0affe5;hb=a36c7a3bddb23de2276f844d94dfd20227b68093;hp=28aa229d3515b735bbb51e4f7e24d64bc190e13f;hpb=79c56f6fa4b07352dd7cce8627246f04508955a7;p=fishladder.git diff --git a/vg/vg.h b/vg/vg.h index 28aa229..c6b8fb9 100644 --- a/vg/vg.h +++ b/vg/vg.h @@ -11,15 +11,23 @@ #include "gl/glfw3.h" #define STB_DS_IMPLEMENTATION +#define STB_IMAGE_IMPLEMENTATION #include "stb/stb_ds.h" +#include "stb/stb_image.h" + +#include "cglm/include/cglm/cglm.h" void vg_register_exit( void( *funcptr )(void), const char *name ); void vg_exiterr( const char *strErr ); +mat4 vg_pv; + #include "vg/vg_platform.h" #include "vg/vg_io.h" #include "vg/vg_audio.h" #include "vg/vg_shader.h" +#include "vg/vg_lines.h" +#include "vg/vg_tex.h" #include "steam/steamworks_thin.h" @@ -179,6 +187,23 @@ void vg_update_inputs(void) // Engine main // =========================================================================================================== +#ifndef VG_RELEASE +void vg_checkgl( const char *src_info ) +{ + GLenum err; + while( (err = glGetError()) != GL_NO_ERROR ) + { + vg_error( "(%s) OpenGL Error: #%d\n", src_info, err ); + } +} + + #define VG_STRINGIT( X ) #X + #define VG_CHECK_GL() vg_checkgl( __FILE__ ":L" VG_STRINGIT(__LINE__) ) +#else + #define VG_CHECK_GL() +#endif + + #define VG_GAMELOOP void( *vg_on_exit[16] )(void); @@ -230,6 +255,7 @@ void vg_framebuffer_resize_callback( GLFWwindow *ptrW, int w, int h ) vg_window_y = h; } +static void vg_register(void) VG_GAMELOOP; static void vg_start(void) VG_GAMELOOP; static void vg_update(void) VG_GAMELOOP; static void vg_render(void) VG_GAMELOOP; @@ -258,7 +284,7 @@ static void vg_init( int argc, char *argv[], const char *window_name ) glfwWindowHint( GLFW_OPENGL_PROFILE, GLFW_OPENGL_CORE_PROFILE ); glfwWindowHint( GLFW_OPENGL_DEBUG_CONTEXT, GL_TRUE ); - glfwWindowHint( GLFW_SAMPLES, 4 ); + glfwWindowHint( GLFW_SAMPLES, 1 ); GLFWmonitor *monitor_primary = glfwGetPrimaryMonitor(); @@ -314,10 +340,16 @@ static void vg_init( int argc, char *argv[], const char *window_name ) vg_audio_init(); vg_register_exit( &vg_audio_free, "vg_audio_free" ); + vg_lines_init(); + vg_register_exit( &vg_lines_free, "vg_lines_free" ); + + vg_register(); + vg_register_exit( &vg_free, "vg_free" ); - vg_start(); if( vg_shaders_compile() ) { + vg_start(); + // Main gameloop while( !glfwWindowShouldClose( vg_window ) ) { @@ -332,19 +364,19 @@ static void vg_init( int argc, char *argv[], const char *window_name ) vg_time_delta = vg_min( vg_time - vg_time_last, 0.1f ); vg_update_inputs(); - vg_update(); + vg_render(); - // Update mashed projections etc + vg_lines_drawall(); - vg_render(); vg_ui(); glfwSwapBuffers( vg_window ); + + VG_CHECK_GL(); } } - vg_free(); vg_exit(); }