store saves and configs in gpsp dir
Don't like ROM dir littering. Still looking there for .sav and .cht files though.
This commit is contained in:
parent
a88b04319e
commit
d0944fc942
8
common.h
8
common.h
|
@ -23,6 +23,14 @@
|
||||||
#define ror(dest, value, shift) \
|
#define ror(dest, value, shift) \
|
||||||
dest = ((value) >> shift) | ((value) << (32 - shift)) \
|
dest = ((value) >> shift) | ((value) << (32 - shift)) \
|
||||||
|
|
||||||
|
#if defined(_WIN32) || defined(_WIN32_WCE)
|
||||||
|
#define PATH_SEPARATOR "\\"
|
||||||
|
#define PATH_SEPARATOR_CHAR '\\'
|
||||||
|
#else
|
||||||
|
#define PATH_SEPARATOR "/"
|
||||||
|
#define PATH_SEPARATOR_CHAR '/'
|
||||||
|
#endif
|
||||||
|
|
||||||
// These includes must be used before SDL is included.
|
// These includes must be used before SDL is included.
|
||||||
#ifdef ARM_ARCH
|
#ifdef ARM_ARCH
|
||||||
|
|
||||||
|
|
34
gui.c
34
gui.c
|
@ -767,7 +767,7 @@ s32 load_game_config_file()
|
||||||
char game_config_filename[512];
|
char game_config_filename[512];
|
||||||
u32 file_loaded = 0;
|
u32 file_loaded = 0;
|
||||||
u32 i;
|
u32 i;
|
||||||
change_ext(gamepak_filename, game_config_filename, ".cfg");
|
make_rpath(game_config_filename, sizeof(game_config_filename), ".cfg");
|
||||||
|
|
||||||
file_open(game_config_file, game_config_filename, read);
|
file_open(game_config_file, game_config_filename, read);
|
||||||
|
|
||||||
|
@ -841,11 +841,7 @@ s32 load_config_file()
|
||||||
{
|
{
|
||||||
char config_path[512];
|
char config_path[512];
|
||||||
|
|
||||||
#if defined(_WIN32) || defined(_WIN32_WCE)
|
sprintf(config_path, "%s" PATH_SEPARATOR "%s", main_path, GPSP_CONFIG_FILENAME);
|
||||||
sprintf(config_path, "%s\\%s", main_path, GPSP_CONFIG_FILENAME);
|
|
||||||
#else
|
|
||||||
sprintf(config_path, "%s/%s", main_path, GPSP_CONFIG_FILENAME);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
file_open(config_file, config_path, read);
|
file_open(config_file, config_path, read);
|
||||||
|
|
||||||
|
@ -915,7 +911,7 @@ s32 save_game_config_file()
|
||||||
char game_config_filename[512];
|
char game_config_filename[512];
|
||||||
u32 i;
|
u32 i;
|
||||||
|
|
||||||
change_ext(gamepak_filename, game_config_filename, ".cfg");
|
make_rpath(game_config_filename, sizeof(game_config_filename), ".cfg");
|
||||||
|
|
||||||
file_open(game_config_file, game_config_filename, write);
|
file_open(game_config_file, game_config_filename, write);
|
||||||
|
|
||||||
|
@ -947,11 +943,7 @@ s32 save_config_file()
|
||||||
{
|
{
|
||||||
char config_path[512];
|
char config_path[512];
|
||||||
|
|
||||||
#if (defined(PSP_BUILD) || defined(ARM_ARCH)) && !defined(_WIN32_WCE)
|
sprintf(config_path, "%s" PATH_SEPARATOR "%s", main_path, GPSP_CONFIG_FILENAME);
|
||||||
sprintf(config_path, "%s/%s", main_path, GPSP_CONFIG_FILENAME);
|
|
||||||
#else
|
|
||||||
sprintf(config_path, "%s\\%s", main_path, GPSP_CONFIG_FILENAME);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
file_open(config_file, config_path, write);
|
file_open(config_file, config_path, write);
|
||||||
|
|
||||||
|
@ -1044,22 +1036,18 @@ void get_savestate_snapshot(char *savestate_filename)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void get_savestate_filename(u32 slot, char *name_buffer)
|
|
||||||
{
|
|
||||||
char savestate_ext[16];
|
|
||||||
|
|
||||||
sprintf(savestate_ext, "%d.svs", slot);
|
|
||||||
change_ext(gamepak_filename, name_buffer, savestate_ext);
|
|
||||||
|
|
||||||
get_savestate_snapshot(name_buffer);
|
|
||||||
}
|
|
||||||
|
|
||||||
void get_savestate_filename_noshot(u32 slot, char *name_buffer)
|
void get_savestate_filename_noshot(u32 slot, char *name_buffer)
|
||||||
{
|
{
|
||||||
char savestate_ext[16];
|
char savestate_ext[16];
|
||||||
|
|
||||||
sprintf(savestate_ext, "%d.svs", slot);
|
sprintf(savestate_ext, "%d.svs", slot);
|
||||||
change_ext(gamepak_filename, name_buffer, savestate_ext);
|
make_rpath(name_buffer, 512, savestate_ext);
|
||||||
|
}
|
||||||
|
|
||||||
|
void get_savestate_filename(u32 slot, char *name_buffer)
|
||||||
|
{
|
||||||
|
get_savestate_filename_noshot(slot, name_buffer);
|
||||||
|
get_savestate_snapshot(name_buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PSP_BUILD
|
#ifdef PSP_BUILD
|
||||||
|
|
33
main.c
33
main.c
|
@ -178,6 +178,9 @@ void init_main()
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
|
char bios_filename[512];
|
||||||
|
int ret;
|
||||||
|
|
||||||
#ifdef PSP_BUILD
|
#ifdef PSP_BUILD
|
||||||
sceKernelRegisterSubIntrHandler(PSP_VBLANK_INT, 0,
|
sceKernelRegisterSubIntrHandler(PSP_VBLANK_INT, 0,
|
||||||
vblank_interrupt_handler, NULL);
|
vblank_interrupt_handler, NULL);
|
||||||
|
@ -208,13 +211,11 @@ int main(int argc, char *argv[])
|
||||||
|
|
||||||
init_video();
|
init_video();
|
||||||
|
|
||||||
#ifdef GP2X_BUILD
|
sprintf(bios_filename, "%s" PATH_SEPARATOR "%s", main_path, "gba_bios.bin");
|
||||||
char bios_filename[512];
|
ret = load_bios(bios_filename);
|
||||||
sprintf(bios_filename, "%s/%s", main_path, "gba_bios.bin");
|
if (ret != 0)
|
||||||
if(load_bios(bios_filename) == -1)
|
ret = load_bios("gba_bios.bin");
|
||||||
#else
|
if (ret != 0)
|
||||||
if(load_bios("gba_bios.bin") == -1)
|
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
gui_action_type gui_action = CURSOR_NONE;
|
gui_action_type gui_action = CURSOR_NONE;
|
||||||
|
|
||||||
|
@ -579,10 +580,10 @@ u32 update_gba()
|
||||||
frame_ticks++;
|
frame_ticks++;
|
||||||
|
|
||||||
#ifdef PC_BUILD
|
#ifdef PC_BUILD
|
||||||
printf("frame update (%x), %d instructions total, %d RAM flushes\n",
|
/* printf("frame update (%x), %d instructions total, %d RAM flushes\n",
|
||||||
reg[REG_PC], instruction_count - last_frame, flush_ram_count);
|
reg[REG_PC], instruction_count - last_frame, flush_ram_count);
|
||||||
last_frame = instruction_count;
|
last_frame = instruction_count;
|
||||||
|
*/
|
||||||
/* printf("%d gbc audio updates\n", gbc_update_count);
|
/* printf("%d gbc audio updates\n", gbc_update_count);
|
||||||
printf("%d oam updates\n", oam_update_count); */
|
printf("%d oam updates\n", oam_update_count); */
|
||||||
gbc_update_count = 0;
|
gbc_update_count = 0;
|
||||||
|
@ -943,6 +944,20 @@ void change_ext(const char *src, char *buffer, const char *extension)
|
||||||
strcpy(dot_position, extension);
|
strcpy(dot_position, extension);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// make path: <main_path>/<romname>.<ext>
|
||||||
|
void make_rpath(char *buff, size_t size, const char *ext)
|
||||||
|
{
|
||||||
|
char *p;
|
||||||
|
p = strrchr(gamepak_filename, PATH_SEPARATOR_CHAR);
|
||||||
|
if (p == NULL)
|
||||||
|
p = gamepak_filename;
|
||||||
|
|
||||||
|
snprintf(buff, size, "%s/%s", main_path, p);
|
||||||
|
p = strrchr(buff, '.');
|
||||||
|
if (p != NULL)
|
||||||
|
strcpy(p, ext);
|
||||||
|
}
|
||||||
|
|
||||||
#define main_savestate_builder(type) \
|
#define main_savestate_builder(type) \
|
||||||
void main_##type##_savestate(file_tag_type savestate_file) \
|
void main_##type##_savestate(file_tag_type savestate_file) \
|
||||||
{ \
|
{ \
|
||||||
|
|
1
main.h
1
main.h
|
@ -185,6 +185,7 @@ static u32 prescale_table[] = { 0, 6, 8, 10 };
|
||||||
#endif // IN_MEMORY_C
|
#endif // IN_MEMORY_C
|
||||||
|
|
||||||
void change_ext(const char *src, char *buffer, const char *extension);
|
void change_ext(const char *src, char *buffer, const char *extension);
|
||||||
|
void make_rpath(char *buff, size_t size, const char *ext);
|
||||||
|
|
||||||
void set_clock_speed();
|
void set_clock_speed();
|
||||||
|
|
||||||
|
|
23
memory.c
23
memory.c
|
@ -2022,11 +2022,7 @@ s32 load_game_config(char *gamepak_title, char *gamepak_code, char *gamepak_make
|
||||||
translation_gate_targets = 0;
|
translation_gate_targets = 0;
|
||||||
flash_device_id = FLASH_DEVICE_MACRONIX_64KB;
|
flash_device_id = FLASH_DEVICE_MACRONIX_64KB;
|
||||||
|
|
||||||
#if (defined(PSP_BUILD) || defined(ARM_ARCH)) && !defined(_WIN32_WCE)
|
sprintf(config_path, "%s" PATH_SEPARATOR "%s", main_path, CONFIG_FILENAME);
|
||||||
sprintf(config_path, "%s/%s", main_path, CONFIG_FILENAME);
|
|
||||||
#else
|
|
||||||
sprintf(config_path, "%s\\%s", main_path, CONFIG_FILENAME);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
config_file = fopen(config_path, "rb");
|
config_file = fopen(config_path, "rb");
|
||||||
|
|
||||||
|
@ -2113,6 +2109,9 @@ s32 load_game_config(char *gamepak_title, char *gamepak_code, char *gamepak_make
|
||||||
fclose(config_file);
|
fclose(config_file);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef PSP_BUILD
|
||||||
|
printf("game config missing\n");
|
||||||
|
#endif
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2182,11 +2181,17 @@ u32 load_gamepak(char *name)
|
||||||
{
|
{
|
||||||
gamepak_size = (file_size + 0x7FFF) & ~0x7FFF;
|
gamepak_size = (file_size + 0x7FFF) & ~0x7FFF;
|
||||||
|
|
||||||
strcpy(backup_filename, name);
|
strncpy(gamepak_filename, name, sizeof(gamepak_filename));
|
||||||
strncpy(gamepak_filename, name, 512);
|
gamepak_filename[sizeof(gamepak_filename) - 1] = 0;
|
||||||
change_ext(gamepak_filename, backup_filename, ".sav");
|
|
||||||
|
|
||||||
load_backup(backup_filename);
|
make_rpath(backup_filename, sizeof(backup_filename), ".sav");
|
||||||
|
if (!load_backup(backup_filename))
|
||||||
|
{
|
||||||
|
// try path used by older versions
|
||||||
|
strcpy(backup_filename, name);
|
||||||
|
change_ext(gamepak_filename, backup_filename, ".sav");
|
||||||
|
load_backup(backup_filename);
|
||||||
|
}
|
||||||
|
|
||||||
memcpy(gamepak_title, gamepak_rom + 0xA0, 12);
|
memcpy(gamepak_title, gamepak_rom + 0xA0, 12);
|
||||||
memcpy(gamepak_code, gamepak_rom + 0xAC, 4);
|
memcpy(gamepak_code, gamepak_rom + 0xAC, 4);
|
||||||
|
|
Loading…
Reference in New Issue