improved save file detection algorithm

This commit is contained in:
dborth 2009-06-28 07:06:21 +00:00
parent 144091b948
commit 671aa8d6b4

View File

@ -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;