-#define KEYBOARD_GLYPH( X ) "\x1f" X " "
-
-static const char *button_display_string( enum sr_bind button )
-{
- const char *controller_table[ k_srbind_max ] = {
- [k_srbind_jump] = controller_glyph( SDL_CONTROLLER_BUTTON_A ),
- [k_srbind_push] = controller_glyph( SDL_CONTROLLER_BUTTON_B ),
- [k_srbind_trick0] = controller_glyph( SDL_CONTROLLER_BUTTON_A ),
- [k_srbind_trick1] = controller_glyph( SDL_CONTROLLER_BUTTON_B ),
- [k_srbind_trick2] = controller_glyph( SDL_CONTROLLER_BUTTON_X ),
- [k_srbind_use] = controller_glyph( SDL_CONTROLLER_BUTTON_Y ),
- [k_srbind_reset] = controller_glyph( SDL_CONTROLLER_BUTTON_LEFTSHOULDER ),
- [k_srbind_camera] = controller_glyph( SDL_CONTROLLER_BUTTON_RIGHTSHOULDER ),
- [k_srbind_mleft] = controller_glyph( SDL_CONTROLLER_BUTTON_DPAD_LEFT ),
- [k_srbind_mright] = controller_glyph( SDL_CONTROLLER_BUTTON_DPAD_RIGHT ),
- [k_srbind_world_left] = controller_glyph( SDL_CONTROLLER_BUTTON_DPAD_LEFT ),
- [k_srbind_world_right] = controller_glyph( SDL_CONTROLLER_BUTTON_DPAD_RIGHT ),
- [k_srbind_home] = controller_glyph( SDL_CONTROLLER_BUTTON_Y ),
- [k_srbind_mup] = controller_glyph( SDL_CONTROLLER_BUTTON_DPAD_UP ),
- [k_srbind_mdown] = controller_glyph( SDL_CONTROLLER_BUTTON_DPAD_DOWN ),
- [k_srbind_mback] = controller_glyph( SDL_CONTROLLER_BUTTON_B ),
- [k_srbind_maccept]= controller_glyph( SDL_CONTROLLER_BUTTON_A ),
- [k_srbind_mopen] = controller_glyph( SDL_CONTROLLER_BUTTON_GUIDE ),
-[k_srbind_replay_play]= controller_glyph( SDL_CONTROLLER_BUTTON_X ),
-[k_srbind_replay_freecam]=controller_glyph(SDL_CONTROLLER_BUTTON_Y ),
-[k_srbind_replay_resume]=controller_glyph( SDL_CONTROLLER_BUTTON_A ),
- [k_srbind_sit] = controller_glyph( SDL_CONTROLLER_BUTTON_B ),
- [k_srbind_lobby] = controller_glyph( SDL_CONTROLLER_BUTTON_DPAD_LEFT ),
- [k_srbind_chat] = ""
- };
-
- const char *keyboard_table[ k_srbind_max ] = {
- [k_srbind_jump] = "\xa1",
- [k_srbind_push] = KEYBOARD_GLYPH( "W" ),
- [k_srbind_trick0] = "\x99",
- [k_srbind_trick1] = "\x9a",
- [k_srbind_trick2] = "\x9b",
- [k_srbind_use] = KEYBOARD_GLYPH( "E" ),
- [k_srbind_reset] = KEYBOARD_GLYPH( "R" ),
- [k_srbind_camera] = KEYBOARD_GLYPH( "C" ),
- [k_srbind_mleft] = KEYBOARD_GLYPH( "\x93" ),
- [k_srbind_mright] = KEYBOARD_GLYPH( "\x95" ),
- [k_srbind_world_left] = KEYBOARD_GLYPH( "\x93" ),
- [k_srbind_world_right] = KEYBOARD_GLYPH( "\x95" ),
- [k_srbind_home] = KEYBOARD_GLYPH( "H" ),
- [k_srbind_mup] = KEYBOARD_GLYPH( "\x94" ),
- [k_srbind_mdown] = KEYBOARD_GLYPH( "\x96" ),
- [k_srbind_mback] = "\xa3",
- [k_srbind_maccept]= "\xa2",
- [k_srbind_mopen] = "\xa3" ,
-[k_srbind_replay_play]= KEYBOARD_GLYPH( "G" ),
-[k_srbind_replay_freecam] = KEYBOARD_GLYPH( "F" ),
-[k_srbind_replay_resume]= "\xa1",
- [k_srbind_sit] = KEYBOARD_GLYPH( "Z" ),
- [k_srbind_lobby] = KEYBOARD_GLYPH( "" ), // FIXME: what is tab?
- [k_srbind_chat] = KEYBOARD_GLYPH( "Y" )
- };
-
- if( vg_input.display_input_method == k_input_method_controller )
- return controller_table[ button ];
- else
- return keyboard_table[ button ];
-}
+static vg_input_op *input_joy_list[] = {
+[k_srjoystick_steer] = (vg_input_op[]){
+ vg_index, 0, vg_mode_add, vg_keyboard, SDLK_d,
+ vg_mode_sub, vg_keyboard, SDLK_a,
+ vg_index, 1, vg_mode_add, vg_keyboard, SDLK_s,
+ vg_mode_sub, vg_keyboard, SDLK_w,
+ vg_mode_absmax, vg_joy_ls,
+ vg_end
+},
+[k_srjoystick_grab] = (vg_input_op[]){
+ vg_joy_rs, vg_end
+},
+[k_srjoystick_look] = (vg_input_op[]){
+ vg_joy_rs, vg_end
+},
+[k_srjoystick_max]=NULL
+};