- if( localplayer.board_view_slot ){
- struct cache_board *cache_ptr = localplayer.board_view_slot;
- if( cache_ptr->reg_ptr ){
- if( cache_ptr->reg_ptr->workshop_id )
- vg_msg_wkvu64( &sav, "board", cache_ptr->reg_ptr->workshop_id );
- else
- vg_msg_wkvstr( &sav, "board", cache_ptr->reg_ptr->foldername );
+ vg_msg_cmd kv = vg_msg_seekkv( msg, key, 0 );
+ if( kv.code == k_vg_msg_kvstring ){
+ vg_strncpy( kv.value, alias->foldername, sizeof(alias->foldername),
+ k_strncpy_allow_cutoff );
+ }
+ else
+ alias->workshop_id = vg_msg_read_as_u64( &kv );
+}
+
+static void skaterift_write_main_savedata(void){
+ if( !vg_loader_availible() ) return;
+
+ vg_linear_clear( vg_async.buffer );
+ struct savedata *sav = vg_linear_alloc( vg_async.buffer,
+ vg_align8(sizeof(struct savedata)) );
+
+ strcpy( sav->path, "save.bkv" );
+
+ vg_msg kvsav = {0};
+ kvsav.buf = sav->buf;
+ kvsav.max = sizeof(sav->buf);
+
+ vg_msg_frame( &kvsav, "player" );
+ {
+ skaterift_write_viewslot( &kvsav, "board", k_addon_type_board,
+ localplayer.board_view_slot );
+ skaterift_write_viewslot( &kvsav, "playermodel", k_addon_type_player,
+ localplayer.playermodel_view_slot );
+ }
+ vg_msg_end_frame( &kvsav );
+
+ vg_msg_frame( &kvsav, "world" );
+ {
+ addon_reg *reg = world_static.addon_client;
+ if( reg && (world_static.active_instance > 0) ){
+ skaterift_write_addon_alias( &kvsav, "alias", ®->alias );
+ vg_msg_wkvu32( &kvsav, "index", world_static.active_instance );
+ vg_msg_wkvnum( &kvsav, "position", k_vg_msg_float|k_vg_msg_32b, 3,
+ localplayer.rb.co );