-VG_STATIC void load_playermodels(void)
-{
- player_model_load( &localplayer_models[0], "models/ch_new.mdl" );
- player_model_load( &localplayer_models[1], "models/ch_outlaw.mdl" );
- player_model_load( &localplayer_models[2], "models/ch_jordan.mdl" );
+static void async_skaterift_player_start( void *payload, u32 size ){
+ world_switch_instance(0);
+}
+
+static void async_call_ready( void *payload, u32 size ){
+ skaterift.op = k_async_op_none;
+}
+
+static void skaterift_restore_state(void){
+ savedata_file sav;
+ strcpy( sav.path, str_skaterift_main_save );
+ savedata_file_read( &sav );
+
+ vg_msg kvsav;
+ vg_msg_init( &kvsav, sav.buf, sizeof(sav.buf) );
+ skaterift.achievements |= vg_msg_getkvu32( &kvsav, "ach", 0 );
+
+ u32 board_reg_id = 0,
+ player_reg_id = 0;
+
+ vg_msg_cursor orig = kvsav.cur;
+ if( vg_msg_seekframe( &kvsav, "player" ) ){
+ addon_alias q;
+
+ /* board */
+ skaterift_read_addon_alias( &kvsav, "board", k_addon_type_board, &q );
+ u32 reg_id = addon_match( &q );
+ if( reg_id != 0xffffffff )
+ board_reg_id = reg_id;
+
+ /* playermodel */
+ skaterift_read_addon_alias( &kvsav, "playermodel",
+ k_addon_type_player, &q );
+ reg_id = addon_match( &q );
+ if( reg_id != 0xffffffff )
+ player_reg_id = reg_id;
+ }
+
+ localplayer.board_view_slot =
+ addon_cache_create_viewer( k_addon_type_board, board_reg_id );
+ localplayer.playermodel_view_slot =
+ addon_cache_create_viewer( k_addon_type_player, player_reg_id );
+
+ kvsav.cur = orig;
+}