mirror of
https://github.com/dborth/snes9xgx.git
synced 2025-01-27 10:25:30 +01:00
improved save file detection algorithm
This commit is contained in:
parent
144091b948
commit
671aa8d6b4
@ -1470,6 +1470,47 @@ static int MenuGame()
|
|||||||
return menu;
|
return menu;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* FindGameSaveNum
|
||||||
|
*
|
||||||
|
* Determines the save file number of the given file name
|
||||||
|
* Returns -1 if none is found
|
||||||
|
***************************************************************************/
|
||||||
|
static int FindGameSaveNum(char * savefile, int method)
|
||||||
|
{
|
||||||
|
int n = -1;
|
||||||
|
int romlen = strlen(Memory.ROMFilename);
|
||||||
|
int savelen = strlen(savefile);
|
||||||
|
|
||||||
|
if(romlen > 26 && (method == METHOD_MC_SLOTA || method == METHOD_MC_SLOTB))
|
||||||
|
romlen = 26; // memory card filenames are a maximum of 32 chars
|
||||||
|
|
||||||
|
int diff = savelen-romlen;
|
||||||
|
|
||||||
|
if(strncmp(savefile, Memory.ROMFilename, romlen) != 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
if(method == METHOD_MC_SLOTA || method == METHOD_MC_SLOTB)
|
||||||
|
{
|
||||||
|
if(diff == 2)
|
||||||
|
n = atoi(&savefile[savelen-2]);
|
||||||
|
else if(diff == 1)
|
||||||
|
n = atoi(&savefile[savelen-1]);
|
||||||
|
}
|
||||||
|
else if(savefile[romlen] == ' ')
|
||||||
|
{
|
||||||
|
if(diff == 5 && strncmp((const char *)savefile[romlen+1], "Auto", 4) == 0)
|
||||||
|
n = 0; // found Auto save
|
||||||
|
else if(diff == 2 || diff == 3)
|
||||||
|
n = atoi(&savefile[romlen+1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(n >= 0 && n < MAX_SAVES)
|
||||||
|
return n;
|
||||||
|
else
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* MenuGameSaves
|
* MenuGameSaves
|
||||||
*
|
*
|
||||||
@ -1479,12 +1520,12 @@ static int MenuGameSaves(int action)
|
|||||||
{
|
{
|
||||||
int menu = MENU_NONE;
|
int menu = MENU_NONE;
|
||||||
int ret;
|
int ret;
|
||||||
int i, n, len, len2;
|
int i, n, type, len, len2;
|
||||||
int j = 0;
|
int j = 0;
|
||||||
SaveList saves;
|
SaveList saves;
|
||||||
char filepath[1024];
|
char filepath[1024];
|
||||||
char scrfile[1024];
|
char scrfile[1024];
|
||||||
char tmp[256];
|
char tmp[MAXJOLIET];
|
||||||
struct stat filestat;
|
struct stat filestat;
|
||||||
struct tm * timeinfo;
|
struct tm * timeinfo;
|
||||||
int method = GCSettings.SaveMethod;
|
int method = GCSettings.SaveMethod;
|
||||||
@ -1573,40 +1614,32 @@ static int MenuGameSaves(int action)
|
|||||||
ParseDirectory(GCSettings.SaveMethod);
|
ParseDirectory(GCSettings.SaveMethod);
|
||||||
}
|
}
|
||||||
|
|
||||||
for(i=0; i < browser.numEntries; i++)
|
|
||||||
{
|
|
||||||
len = strlen(Memory.ROMFilename);
|
len = strlen(Memory.ROMFilename);
|
||||||
len2 = strlen(browserList[i].filename);
|
|
||||||
|
|
||||||
if(len > 26 && (method == METHOD_MC_SLOTA || method == METHOD_MC_SLOTB))
|
|
||||||
len = 26; // memory card filenames are a maximum of 32 chars
|
|
||||||
|
|
||||||
// find matching files
|
// find matching files
|
||||||
if(len2 > 5 && strncmp(browserList[i].filename, Memory.ROMFilename, len) == 0)
|
for(i=0; i < browser.numEntries; i++)
|
||||||
{
|
{
|
||||||
|
len2 = strlen(browserList[i].filename);
|
||||||
|
|
||||||
|
if(len2 < 6 || len2-len < 5)
|
||||||
|
continue;
|
||||||
|
|
||||||
if(strncmp(&browserList[i].filename[len2-4], ".srm", 4) == 0)
|
if(strncmp(&browserList[i].filename[len2-4], ".srm", 4) == 0)
|
||||||
saves.type[j] = FILE_SRAM;
|
type = FILE_SRAM;
|
||||||
else if(strncmp(&browserList[i].filename[len2-4], ".frz", 4) == 0)
|
else if(strncmp(&browserList[i].filename[len2-4], ".frz", 4) == 0)
|
||||||
saves.type[j] = FILE_SNAPSHOT;
|
type = FILE_SNAPSHOT;
|
||||||
else
|
else
|
||||||
saves.type[j] = -1;
|
continue;
|
||||||
|
|
||||||
if(saves.type[j] != -1)
|
strncpy(tmp, browserList[i].filename, MAXJOLIET);
|
||||||
{
|
|
||||||
strncpy(tmp, browserList[i].filename, 255);
|
|
||||||
tmp[len2-4] = 0;
|
tmp[len2-4] = 0;
|
||||||
|
n = FindGameSaveNum(tmp, method);
|
||||||
|
|
||||||
if(len2 - len == 7)
|
if(n >= 0)
|
||||||
n = atoi(&tmp[len2-5]);
|
{
|
||||||
else if(len2 - len == 6)
|
saves.type[j] = type;
|
||||||
n = atoi(&tmp[len2-6]);
|
|
||||||
else
|
|
||||||
n = -1;
|
|
||||||
|
|
||||||
if(n > 0 && n < MAX_SAVES)
|
|
||||||
saves.files[saves.type[j]][n] = 1;
|
saves.files[saves.type[j]][n] = 1;
|
||||||
|
strncpy(saves.filename[j], browserList[i].filename, MAXJOLIET);
|
||||||
strncpy(saves.filename[j], browserList[i].filename, 255);
|
|
||||||
|
|
||||||
if(method != METHOD_MC_SLOTA && method != METHOD_MC_SLOTB)
|
if(method != METHOD_MC_SLOTA && method != METHOD_MC_SLOTB)
|
||||||
{
|
{
|
||||||
@ -1630,7 +1663,6 @@ static int MenuGameSaves(int action)
|
|||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
saves.length = j;
|
saves.length = j;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user