X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=build.c;h=558299bd955045231c2d6e6e0ca7a740d76c5529;hb=aed3995840d5472275b7bf143efed7c4f9daa358;hp=bc6e81a89d6cc8e7ce9a1bfcf0cbfa62971044d5;hpb=2a6a779a1ad3f1a781e2437732bc62055096439e;p=carveJwlIkooP6JGAAIwe30JlM.git diff --git a/build.c b/build.c index bc6e81a..558299b 100644 --- a/build.c +++ b/build.c @@ -1,7 +1,11 @@ +#include #include "vg/vg_platform.h" #include "vg/vg_log.h" #include "vg/vg_opt.h" #include "vg/vg_build.h" +#include "vg/vg_build_utils_shader.h" +#include "vg/vg_msg.h" +#include "workshop_types.h" /* * c build.c --release --clang @@ -15,7 +19,7 @@ void build_server( enum compiler compiler ) { vg_build_start( "skaterift_server", compiler ); vg_build_object( "server.c " ); - vg_build_link( "-pthread -lm -lsdkencryptedappticket -lsteam_api " ); + vg_build_link( "-lm -lsdkencryptedappticket -lsteam_api " ); vg_build_library_dir( "-L./vg/dep/steam " ); vg_build_bin_dependency_file( "vg/dep/steam/steamclient.so" ); @@ -26,8 +30,27 @@ void build_server( enum compiler compiler ) compiled_something = 1; } +void write_msg( vg_msg *msg, const char *path ){ + FILE *fp = fopen( path, "wb" ); + if( !fp ){ + vg_error( "Cannot open %s for writing.\n", path ); + exit(0); + } + + fwrite( msg->buf, msg->cur, 1, fp ); + fclose( fp ); + vg_success( "Written %s (%ub)\n", path, msg->cur ); +} + +void build_shaders(void); void build_game( enum compiler compiler ) { + static int shaders_built = 0; + if( !shaders_built ){ + shaders_built = 1; + build_shaders(); + } + vg_build_start( "skaterift", compiler ); vg_build_object( "skaterift.c " ); vg_build_add_link_for_graphics(); @@ -38,11 +61,101 @@ void build_game( enum compiler compiler ) vg_build_symbolic_link( "textures_src", "textures" ); vg_build_symbolic_link( "models_src", "models" ); + vg_build_symbolic_link( "boards_src", "boards" ); vg_build_symbolic_link( "maps_src", "maps" ); vg_build_symbolic_link( "sound_src", "sound" ); vg_build_syscall( "mkdir -p %s/cfg", vg_compiler.build_dir ); - vg_build_miniaudio(); + u8 descriptor_buf[ 512 ]; + vg_msg descriptor; + + { + vg_msg_init( &descriptor, descriptor_buf, 512 ); + vg_msg_frame( &descriptor, "workshop" ); + vg_msg_wkvstr( &descriptor, "title", "Longboard" ); + vg_msg_wkvstr( &descriptor, "author", "Skaterift" ); + vg_msg_wkvuint(&descriptor, "type", u32 value=k_workshop_file_type_board); + vg_msg_end_frame( &descriptor ); + vg_msg_wkvstr( &descriptor, "content", "board.mdl" ); + write_msg( &descriptor, "boards_src/skaterift_long/addon.inf" ); + } + + { + vg_msg_init( &descriptor, descriptor_buf, 512 ); + vg_msg_frame( &descriptor, "workshop" ); + vg_msg_wkvstr( &descriptor, "title", "Fractal" ); + vg_msg_wkvstr( &descriptor, "author", "Skaterift" ); + vg_msg_wkvuint(&descriptor, "type", u32 value=k_workshop_file_type_board); + vg_msg_end_frame( &descriptor ); + vg_msg_wkvstr( &descriptor, "content", "board.mdl" ); + write_msg( &descriptor, "boards_src/skaterift_fract/addon.inf" ); + } + + { + vg_msg_init( &descriptor, descriptor_buf, 512 ); + vg_msg_frame( &descriptor, "workshop" ); + vg_msg_wkvstr( &descriptor, "title", "Striped" ); + vg_msg_wkvstr( &descriptor, "author", "Skaterift" ); + vg_msg_wkvuint(&descriptor, "type", u32 value=k_workshop_file_type_board); + vg_msg_end_frame( &descriptor ); + vg_msg_wkvstr( &descriptor, "content", "board.mdl" ); + write_msg( &descriptor, "boards_src/skaterift_striped/addon.inf" ); + } + + { + vg_msg_init( &descriptor, descriptor_buf, 512 ); + vg_msg_frame( &descriptor, "workshop" ); + vg_msg_wkvstr( &descriptor, "title", "Licco" ); + vg_msg_wkvstr( &descriptor, "author", "Skaterift" ); + vg_msg_wkvuint(&descriptor, "type", u32 value=k_workshop_file_type_board); + vg_msg_end_frame( &descriptor ); + vg_msg_wkvstr( &descriptor, "content", "board.mdl" ); + write_msg( &descriptor, "boards_src/skaterift_licco/addon.inf" ); + } + + { + vg_msg_init( &descriptor, descriptor_buf, 512 ); + vg_msg_frame( &descriptor, "workshop" ); + vg_msg_wkvstr( &descriptor, "title", "Hypno" ); + vg_msg_wkvstr( &descriptor, "author", "Skaterift" ); + vg_msg_wkvuint(&descriptor, "type", u32 value=k_workshop_file_type_board); + vg_msg_end_frame( &descriptor ); + vg_msg_wkvstr( &descriptor, "content", "board.mdl" ); + write_msg( &descriptor, "boards_src/skaterift_spiral/addon.inf" ); + } + + { + vg_msg_init( &descriptor, descriptor_buf, 512 ); + vg_msg_frame( &descriptor, "workshop" ); + vg_msg_wkvstr( &descriptor, "title", "Shark" ); + vg_msg_wkvstr( &descriptor, "author", "Skaterift" ); + vg_msg_wkvuint(&descriptor, "type", u32 value=k_workshop_file_type_board); + vg_msg_end_frame( &descriptor ); + vg_msg_wkvstr( &descriptor, "content", "board.mdl" ); + write_msg( &descriptor, "boards_src/skaterift_shark/addon.inf" ); + } + + /* method 2 */ +#if 0 + vg_info( "TRYING OUT METHOD 2 BINGO BONGO\n" ); + vg_msg root; + vg_msg_init( &root, descriptor_buf, descriptor.cur ); + + vg_msg workshop = root; + if( vg_msg_seekframe( &workshop, "workshop", k_vg_msg_first )){ + const char *err = vg_msg_seekkvstr(&workshop,"NOT HERE",k_vg_msg_first); + const char *author = vg_msg_seekkvstr(&workshop,"author",k_vg_msg_first); + const char *title = vg_msg_seekkvstr(&workshop,"title",k_vg_msg_first); + + vg_info( "TITLE: %s\n", title ); + vg_info( "AUTHOR: %s\n", author ); + vg_info( "and error code is: %s\n", err ); + } + + const char *content = vg_msg_seekkvstr(&root, "content", k_vg_msg_first); + vg_info( "CONTENT: %s\n", content ); +#endif + vg_build(); compiled_something = 1; } @@ -72,6 +185,16 @@ int main( int argc, char *argv[] ) if( vg_long_opt( "mingw" ) ) build_game( k_compiler_mingw ); + if( vg_opt('p') || vg_long_opt("run") ) + { + chdir( vg_compiler.build_dir ); + if( vg_compiler.compiler == k_compiler_mingw ) + vg_build_syscall( "wine %s.exe", vg_compiler.name ); + else + vg_build_syscall( "./%s", vg_compiler.name ); + chdir( "../../" ); + } + if( vg_long_opt( "tar" ) || vg_opt( 't' ) ) { vg_build_syscall( "mkdir -p dist" ); @@ -80,13 +203,6 @@ int main( int argc, char *argv[] ) vg_compiler.name, uid, vg_compiler.build_dir ); } - if( vg_opt('p') || vg_long_opt("run") ) - { - chdir( vg_compiler.build_dir ); - vg_build_syscall( "./%s", vg_compiler.name ); - chdir( "../../" ); - } - if( vg_long_opt( "zip" ) || vg_opt( 'z' ) ) { vg_build_syscall( "mkdir -p dist" ); @@ -96,3 +212,41 @@ int main( int argc, char *argv[] ) } } } + +#define _S( NAME, VS, FS ) \ + vg_build_shader( "shaders/" VS, "shaders/" FS, NULL, "shaders", NAME ) + +void build_shaders(void) +{ + vg_shader_set_include_dir( "shaders" ); + + /* Scene */ + _S( "scene_standard", "scene.vs", "scene_standard.fs" ); + _S( "scene_standard_alphatest", "scene.vs", "scene_standard_alphatest.fs" ); + _S( "scene_vertex_blend", "scene.vs", "scene_vertex_blend.fs" ); + _S( "scene_terrain", "scene.vs", "scene_terrain.fs" ); + _S( "scene_route", "scene.vs", "scene_route.fs" ); + _S( "scene_depth", "scene.vs", "scene_depth.fs" ); + _S( "scene_position", "scene.vs", "scene_position.fs" ); + _S( "scene_water", "scene.vs", "scene_water.fs" ); + _S( "scene_water_fast", "scene.vs", "scene_water_fast.fs" ); + _S( "scene_scoretext", "scene_sfd.vs", "scene_standard.fs" ); + + /* Models */ + _S( "model_sky", "model.vs", "model_sky.fs" ); + _S( "model_menu", "model.vs", "model_menu.fs" ); + _S( "model_character_view", "model_skinned.vs", "model_character_view.fs" ); + _S( "model_board_view", "model.vs", "model_character_view.fs" ); + _S( "model_entity", "model.vs", "model_entity.fs" ); + _S( "model_gate", "model_gate.vs", "model_gate_lq.fs" ); + _S( "model_font", "model_font.vs", "model_font.fs" ); + + /* Pointcloud */ + _S( "point_map", "cloud.vs", "cloud.fs" ); + + /* 2D */ + _S( "blit", "blit.vs", "blit.fs" ); + _S( "blitblur", "blit.vs", "blitblur.fs" ); + _S( "blitcolour","blit.vs", "colour.fs" ); + _S( "routeui", "routeui.vs", "routeui.fs" ); +}