-static void menu_btn_map_a( int event ){}
-static void menu_btn_map_b( int event ){}
-static void menu_btn_map_c( int event ){}
-
-static void menu_btn_paused( int event )
-{
-
-}
-
-static void menu_btn_fuckoff( int event )
-{
- glfwSetWindowShouldClose( vg.window, 1 );
-}
-
-static void menu_btn_quit( int event )
-{
- menu_page = 0x8;
- menu_loc = 0xd;
-}
-
-static void menu_btn_map( int event )
-{
- menu_page = 0x4;
- menu_loc = 7;
-}
-
-static void menu_btn_skater( int event )
-{
- menu_page = 0x2;
-}
-
-static void menu_init(void)
-{
- menu_model = mdl_load( "models/rs_menu.mdl" );
-
- if( !menu_model )
- vg_fatal_exit_loop( "No menu model" );
-
- for( int i=0; i<vg_list_size(menu_buttons); i++ )
- {
- struct menu_button *btn = &menu_buttons[i];
- btn->pnode = mdl_node_from_name( menu_model, btn->name );
-
- if( !btn->pnode )
- vg_fatal_exit_loop( "Menu programming error" );
- }
-
- vg_convar_push( (struct vg_convar){
- .name = "cl_playermdl_id",
- .data = &cl_playermdl_id,
- .data_type = k_convar_dtype_i32,
- .opt_i32 = { .min=0, .max=2, .clamp=1 },
- .persistent = 1
- });
-
- vg_acquire_thread_sync();
- mdl_unpack_glmesh( menu_model, &menu_glmesh );
- vg_release_thread_sync();
-
- shader_menu_register();
-}
-
-static void menu_run_directional(void)
-{
- struct menu_button *btn = &menu_buttons[ menu_loc ];
-
- if( vg_get_button_down( "jump" ) )
- {
- if( btn->fn_press )
- {
- btn->fn_press( 1 );
- return;
- }
- }
-
- if( menu_input_cooldown <= 0.0f )
- {
- v2f dir = { vg_get_axis( "lookh" ), vg_get_axis( "lookv" ) };
-
- if( v2_length2( dir ) > 0.8f*0.8f )
- {
- int idir = 0;
-
- if( fabsf(dir[0]) > fabsf(dir[1]) )
- {
- if( dir[0] > 0.0f ) idir = 2;
- else idir = 0;
- }
- else
- {
- if( dir[1] > 0.0f ) idir = 3;
- else idir = 1;
- }
-
- int link = btn->links[idir];
-
- if( link != -1 )
- {
- menu_loc_last = menu_loc;
- menu_loc = link;
- menu_input_cooldown = 0.25f;
- }
- }
- }
-}
-
-static int menu_page_should_backout(void)
-{
- return vg_get_button_down( "break" );
-}
-
-static void menu_close(void)
-{
- cl_menu_go_away = 1;
- menu_page = 0;
-}
-
-static void menu_page_main(void)
-{
- if( menu_page_should_backout() )
- {
- menu_close();
- return;
- }
-
- menu_fov_target = 112.0f;
- menu_run_directional();
-}
-
-static void menu_page_map(void)
-{
- if( menu_page_should_backout() )
- {
- menu_page = 1;
- menu_loc = 3;
- }
-
- menu_fov_target = 80.0f;
- menu_run_directional();
-}
-
-static void menu_page_quit(void)