X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=world.c;h=9b19387208ad9a47a5c96805b6923a83185af09b;hb=bececcbb7b2e886e72425e7c070e1fdc3aa126dc;hp=5a97d944b5f0bb6c79899765a636bab0398b450e;hpb=fdfd087053eb596f1e9123951af8acee94d8cd99;p=carveJwlIkooP6JGAAIwe30JlM.git diff --git a/world.c b/world.c index 5a97d94..9b19387 100644 --- a/world.c +++ b/world.c @@ -2,17 +2,25 @@ * Copyright (C) 2021-2023 Mt.ZERO Software, Harry Godden - All Rights Reserved */ -#ifndef WORLD_C -#define WORLD_C - +#include "skaterift.h" #include "world.h" #include "network.h" +#include "vg/vg_loader.h" +#include "vg/vg_mem.h" +#include "save.h" +#include "player.h" +#include "ent_traffic.h" + +struct world_static world_static; -static world_instance *world_current_instance(void){ +world_instance *world_current_instance(void) +{ return &world_static.instances[ world_static.active_instance ]; } -static void world_init(void) +static int skaterift_switch_instance_cmd( int argc, const char *argv[] ); + +void world_init(void) { vg_loader_step( world_render_init, NULL ); vg_loader_step( world_sfd_init, NULL ); @@ -24,9 +32,13 @@ static void world_init(void) u32 max_size = 76*1024*1024; world_static.heap = vg_create_linear_allocator( vg_mem.rtmemory, max_size, VG_MEMORY_SYSTEM ); + + vg_console_reg_cmd( "switch_active_instance", + skaterift_switch_instance_cmd, NULL ); } -static void world_switch_instance( u32 index ){ +void world_switch_instance( u32 index ) +{ localplayer.subsystem = k_player_subsystem_walk; if( index >= vg_list_size(world_static.instances) ){ @@ -62,7 +74,8 @@ static void world_switch_instance( u32 index ){ player__reset(); } -static int skaterift_switch_instance_cmd( int argc, const char *argv[] ){ +static int skaterift_switch_instance_cmd( int argc, const char *argv[] ) +{ if( argc ) world_switch_instance( atoi(argv[0]) ); else @@ -70,29 +83,20 @@ static int skaterift_switch_instance_cmd( int argc, const char *argv[] ){ return 0; } -static void skaterift_world_get_save_path( enum world_purpose which, - char buf[128] ){ +void skaterift_world_get_save_path( enum world_purpose which, char buf[128] ) +{ addon_reg *reg = world_static.instance_addons[ which ]; - assert( reg ); + + if( !reg ) + vg_fatal_error( "Looking up addon for world without one\n" ); char id[76]; addon_alias_uid( ®->alias, id ); snprintf( buf, 128, "savedata/%s.bkv", id ); } -#include "world_entity.c" -#include "world_gate.c" -#include "world_gen.c" -#include "world_load.c" -#include "world_physics.c" -#include "world_render.c" -#include "world_sfd.c" -#include "world_volumes.c" -#include "world_water.c" -#include "world_audio.c" -#include "world_routes.c" - -static void world_update( world_instance *world, v3f pos ){ +void world_update( world_instance *world, v3f pos ) +{ world_render.sky_time += world_render.sky_rate * vg.time_delta; world_render.sky_rate = vg_lerp( world_render.sky_rate, world_render.sky_target_rate, @@ -104,5 +108,3 @@ static void world_update( world_instance *world, v3f pos ){ world_sfd_update( world, pos ); world_volumes_update( world, pos ); } - -#endif /* WORLD_C */