cli port: in-game save/load

This commit is contained in:
matusz 2009-03-26 01:47:51 +00:00
parent dee9315f14
commit 7c9647b954
1 changed files with 53 additions and 4 deletions

View File

@ -21,12 +21,16 @@
*/ */
#include "ctrlssdl.h" #include "ctrlssdl.h"
#include "saves.h"
#include "SPU.h"
u16 keyboard_cfg[NB_KEYS]; u16 keyboard_cfg[NB_KEYS];
u16 joypad_cfg[NB_KEYS]; u16 joypad_cfg[NB_KEYS];
u16 nbr_joy; u16 nbr_joy;
mouse_status mouse; mouse_status mouse;
extern volatile BOOL execute;
static SDL_Joystick **open_joysticks = NULL; static SDL_Joystick **open_joysticks = NULL;
/* Keypad key names */ /* Keypad key names */
@ -377,6 +381,8 @@ process_joystick_events( u16 *keypad) {
} }
} }
u16 shift_pressed;
/* Manage input events */ /* Manage input events */
int int
process_ctrls_events( u16 *keypad, process_ctrls_events( u16 *keypad,
@ -404,14 +410,57 @@ process_ctrls_events( u16 *keypad,
break; break;
case SDL_KEYDOWN: case SDL_KEYDOWN:
switch(event.key.keysym.sym){
case SDLK_LSHIFT:
shift_pressed |= 1;
break;
case SDLK_RSHIFT:
shift_pressed |= 2;
break;
default:
key = lookup_key(event.key.keysym.sym); key = lookup_key(event.key.keysym.sym);
ADD_KEY( *keypad, key ); ADD_KEY( *keypad, key );
break; break;
}
break;
case SDL_KEYUP: case SDL_KEYUP:
switch(event.key.keysym.sym){
case SDLK_LSHIFT:
shift_pressed &= ~1;
break;
case SDLK_RSHIFT:
shift_pressed &= ~2;
break;
case SDLK_F1:
case SDLK_F2:
case SDLK_F3:
case SDLK_F4:
case SDLK_F5:
case SDLK_F6:
case SDLK_F7:
case SDLK_F8:
case SDLK_F9:
case SDLK_F10:
int prevexec;
prevexec = execute;
execute = FALSE;
SPU_Pause(1);
if(!shift_pressed){
loadstate_slot(event.key.keysym.sym - SDLK_F1 + 1);
}else{
savestate_slot(event.key.keysym.sym - SDLK_F1 + 1);
}
execute = prevexec;
SPU_Pause(!execute);
break;
default:
key = lookup_key(event.key.keysym.sym); key = lookup_key(event.key.keysym.sym);
RM_KEY( *keypad, key ); RM_KEY( *keypad, key );
break; break;
}
break;
case SDL_MOUSEBUTTONDOWN: case SDL_MOUSEBUTTONDOWN:
if(event.button.button==1) if(event.button.button==1)