cli port: in-game save/load
This commit is contained in:
parent
dee9315f14
commit
7c9647b954
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue