/* Copyright (C) 2021-2022 Harry Godden (hgn) - All Rights Reserved */
+#ifndef VG_LINES_H
+#define VG_LINES_H
+
+#include "vg/vg.h"
+
static int debug_lines_enable = 1;
#ifdef VG_3D
}
vg_lines;
-static void vg_lines_init(void)
+static int vg_lines_init(void)
{
+ vg_info( "vg_lines_init\n" );
+
vg_convar_push( (struct vg_convar){
.name = "debug_lines",
.data = &debug_lines_enable,
vg_shader_register( &_shader_lines );
- glGenVertexArrays( 1, &vg_lines.vao );
- glGenBuffers( 1, &vg_lines.vbo );
- glBindVertexArray( vg_lines.vao );
-
- glBindBuffer( GL_ARRAY_BUFFER, vg_lines.vbo );
-
- vg_lines.cap = 50000;
- vg_lines.buffer_size = vg_lines.cap * sizeof( struct vg_lines_vert );
-
- glBufferData( GL_ARRAY_BUFFER, vg_lines.buffer_size, NULL, GL_DYNAMIC_DRAW );
- glBindVertexArray( vg_lines.vao );
-
- glVertexAttribPointer(
- 0,
- sizeof( vg_lines.buffer[0].co ) / sizeof(float),
- GL_FLOAT,
- GL_FALSE,
- sizeof( struct vg_lines_vert ),
- (void *)0
- );
- glEnableVertexAttribArray( 0 );
-
- glVertexAttribPointer(
- 1,
- 4,
- GL_UNSIGNED_BYTE,
- GL_TRUE,
- sizeof( struct vg_lines_vert ),
- (void*)(offsetof( struct vg_lines_vert, colour ))
- );
- glEnableVertexAttribArray( 1 );
- vg_lines.buffer = malloc( vg_lines.buffer_size );
+
+ if( vg_acquire_thread_sync(1) )
+ {
+ glGenVertexArrays( 1, &vg_lines.vao );
+ glGenBuffers( 1, &vg_lines.vbo );
+ glBindVertexArray( vg_lines.vao );
+ glBindBuffer( GL_ARRAY_BUFFER, vg_lines.vbo );
+
+ vg_lines.cap = 50000;
+ vg_lines.buffer_size = vg_lines.cap * sizeof( struct vg_lines_vert );
+
+ glBufferData( GL_ARRAY_BUFFER, vg_lines.buffer_size,
+ NULL, GL_DYNAMIC_DRAW );
+ glBindVertexArray( vg_lines.vao );
+
+ if( VG_CHECK_GL_ERR() )
+ {
+ vg_release_thread_sync(1);
+ vg_error( "Failed\n" );
+ }
+
+ /* Pointers */
+ glVertexAttribPointer(
+ 0,
+ sizeof( vg_lines.buffer[0].co ) / sizeof(float),
+ GL_FLOAT,
+ GL_FALSE,
+ sizeof( struct vg_lines_vert ),
+ (void *)0
+ );
+ glEnableVertexAttribArray( 0 );
+
+ glVertexAttribPointer(
+ 1,
+ 4,
+ GL_UNSIGNED_BYTE,
+ GL_TRUE,
+ sizeof( struct vg_lines_vert ),
+ (void*)(offsetof( struct vg_lines_vert, colour ))
+ );
+ glEnableVertexAttribArray( 1 );
+
+ if( VG_CHECK_GL_ERR() )
+ goto il_delete_buffers_and_fail;
+
+ /* Alloc RAM */
+ vg_lines.buffer = malloc( vg_lines.buffer_size );
+ if( vg_lines.buffer )
+ {
+ vg_success( "done\n" );
+ vg_release_thread_sync(1);
+ return 1;
+ }
+
+il_delete_buffers_and_fail:
+ glDeleteBuffers( 1, &vg_lines.vbo );
+ glDeleteVertexArrays( 1, &vg_lines.vao );
+ vg_release_thread_sync(1);
+ return 0;
+ }
+
+ return 0;
}
-static void vg_lines_free(void)
+static void vg_lines_free(void *nothing)
{
glDeleteVertexArrays( 1, &vg_lines.vao );
glDeleteBuffers( 1, &vg_lines.vbo );
-
free( vg_lines.buffer );
}
vg_line( p100, p010, colour );
}
+static void vg_line_cross(v3f pos,u32 colour, float scale)
+{
+ v3f p0, p1;
+ v3_add( (v3f){ scale,0.0f,0.0f}, pos, p0 );
+ v3_add( (v3f){-scale,0.0f,0.0f}, pos, p1 );
+ vg_line( p0, p1, colour );
+ v3_add( (v3f){0.0f, scale,0.0f}, pos, p0 );
+ v3_add( (v3f){0.0f,-scale,0.0f}, pos, p1 );
+ vg_line( p0, p1, colour );
+ v3_add( (v3f){0.0f,0.0f, scale}, pos, p0 );
+ v3_add( (v3f){0.0f,0.0f,-scale}, pos, p1 );
+ vg_line( p0, p1, colour );
+}
+
static void vg_line_pt3( v3f pt, float size, u32 colour )
{
boxf box =
vg_line_boxf( box, colour );
}
+
+#endif /* VG_LINES_H */