mirror of
https://github.com/dborth/fceugx.git
synced 2025-01-23 05:51:10 +01:00
tidy up file code
This commit is contained in:
parent
5c465f680e
commit
a89d6d4d07
@ -27,6 +27,7 @@
|
|||||||
u64 dvddir = 0; // offset of currently selected file or folder
|
u64 dvddir = 0; // offset of currently selected file or folder
|
||||||
int dvddirlength = 0; // length of currently selected file or folder
|
int dvddirlength = 0; // length of currently selected file or folder
|
||||||
u64 dvdrootdir = 0; // offset of DVD root
|
u64 dvdrootdir = 0; // offset of DVD root
|
||||||
|
int dvdrootlength = 0; // length of DVD root
|
||||||
bool isWii = false;
|
bool isWii = false;
|
||||||
|
|
||||||
#ifdef HW_DOL
|
#ifdef HW_DOL
|
||||||
@ -258,8 +259,9 @@ getpvd ()
|
|||||||
memcpy(&rootdir32, &dvdbuffer[PVDROOT + EXTENT], 4);
|
memcpy(&rootdir32, &dvdbuffer[PVDROOT + EXTENT], 4);
|
||||||
dvddir = (u64)rootdir32;
|
dvddir = (u64)rootdir32;
|
||||||
dvddir <<= 11;
|
dvddir <<= 11;
|
||||||
dvdrootdir = dvddir;
|
|
||||||
memcpy (&dvddirlength, &dvdbuffer[PVDROOT + FILE_LENGTH], 4);
|
memcpy (&dvddirlength, &dvdbuffer[PVDROOT + FILE_LENGTH], 4);
|
||||||
|
dvdrootdir = dvddir;
|
||||||
|
dvdrootlength = dvddirlength;
|
||||||
IsJoliet = 1;
|
IsJoliet = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -284,8 +286,9 @@ getpvd ()
|
|||||||
memcpy (&rootdir32, &dvdbuffer[PVDROOT + EXTENT], 4);
|
memcpy (&rootdir32, &dvdbuffer[PVDROOT + EXTENT], 4);
|
||||||
dvddir = (u64)rootdir32;
|
dvddir = (u64)rootdir32;
|
||||||
dvddir <<= 11;
|
dvddir <<= 11;
|
||||||
dvdrootdir = dvddir;
|
|
||||||
memcpy (&dvddirlength, &dvdbuffer[PVDROOT + FILE_LENGTH], 4);
|
memcpy (&dvddirlength, &dvdbuffer[PVDROOT + FILE_LENGTH], 4);
|
||||||
|
dvdrootdir = dvddir;
|
||||||
|
dvdrootlength = dvddirlength;
|
||||||
IsJoliet = 0;
|
IsJoliet = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -553,6 +556,11 @@ bool SwitchDVDFolder(char origdir[])
|
|||||||
if(dir[strlen(dir)-1] == '/')
|
if(dir[strlen(dir)-1] == '/')
|
||||||
dir[strlen(dir)-1] = 0;
|
dir[strlen(dir)-1] = 0;
|
||||||
|
|
||||||
|
// start at root of DVD
|
||||||
|
dvddir = dvdrootdir;
|
||||||
|
dvddirlength = dvdrootlength;
|
||||||
|
ParseDVDdirectory();
|
||||||
|
|
||||||
return SwitchDVDFolderR(dirptr, 0);
|
return SwitchDVDFolderR(dirptr, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -566,7 +574,7 @@ bool SwitchDVDFolder(char origdir[])
|
|||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
int
|
int
|
||||||
LoadDVDFile (unsigned char *buffer, int length)
|
LoadDVDFileOffset (unsigned char *buffer, int length)
|
||||||
{
|
{
|
||||||
int offset;
|
int offset;
|
||||||
int blocks;
|
int blocks;
|
||||||
@ -574,16 +582,13 @@ LoadDVDFile (unsigned char *buffer, int length)
|
|||||||
u64 discoffset;
|
u64 discoffset;
|
||||||
char readbuffer[2048];
|
char readbuffer[2048];
|
||||||
|
|
||||||
dvddir = filelist[selection].offset;
|
|
||||||
dvddirlength = filelist[selection].length;
|
|
||||||
|
|
||||||
// How many 2k blocks to read
|
// How many 2k blocks to read
|
||||||
blocks = dvddirlength / 2048;
|
blocks = dvddirlength / 2048;
|
||||||
offset = 0;
|
offset = 0;
|
||||||
discoffset = dvddir;
|
discoffset = dvddir;
|
||||||
ShowAction ((char*) "Loading...");
|
ShowAction ((char*) "Loading...");
|
||||||
|
|
||||||
if(length > 0) // do a partial read (eg: to check file header)
|
if(length > 0 && length <= 2048) // do a partial read (eg: to check file header)
|
||||||
{
|
{
|
||||||
dvd_read (buffer, length, discoffset);
|
dvd_read (buffer, length, discoffset);
|
||||||
}
|
}
|
||||||
@ -617,6 +622,21 @@ LoadDVDFile (unsigned char *buffer, int length)
|
|||||||
return dvddirlength;
|
return dvddirlength;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
LoadDVDFile(char * buffer, char *filepath, int datasize, bool silent)
|
||||||
|
{
|
||||||
|
if(SwitchDVDFolder(filepath))
|
||||||
|
{
|
||||||
|
return LoadDVDFileOffset ((unsigned char *)buffer, datasize);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if(!silent)
|
||||||
|
WaitPrompt((char *)"Error loading file!");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* uselessinquiry
|
* uselessinquiry
|
||||||
*
|
*
|
||||||
|
@ -14,7 +14,8 @@
|
|||||||
|
|
||||||
int getpvd ();
|
int getpvd ();
|
||||||
int ParseDVDdirectory ();
|
int ParseDVDdirectory ();
|
||||||
int LoadDVDFile (unsigned char *buffer, int length);
|
int LoadDVDFileOffset(unsigned char *buffer, int length);
|
||||||
|
int LoadDVDFile(char * buffer, char *filepath, int datasize, bool silent);
|
||||||
bool TestDVD();
|
bool TestDVD();
|
||||||
int dvd_read (void *dst, unsigned int len, u64 offset);
|
int dvd_read (void *dst, unsigned int len, u64 offset);
|
||||||
int dvd_safe_read (void *dst, unsigned int len, u64 offset);
|
int dvd_safe_read (void *dst, unsigned int len, u64 offset);
|
||||||
|
@ -17,6 +17,7 @@ void DefaultSettings ();
|
|||||||
|
|
||||||
#define VERSIONNUM "2.0.6"
|
#define VERSIONNUM "2.0.6"
|
||||||
#define VERSIONSTR "FCE Ultra GX 2.0.6"
|
#define VERSIONSTR "FCE Ultra GX 2.0.6"
|
||||||
|
#define PREF_FILE_NAME "FCEUGX.xml"
|
||||||
|
|
||||||
#define NOTSILENT 0
|
#define NOTSILENT 0
|
||||||
#define SILENT 1
|
#define SILENT 1
|
||||||
@ -31,6 +32,15 @@ enum {
|
|||||||
METHOD_MC_SLOTB
|
METHOD_MC_SLOTB
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum {
|
||||||
|
FILE_ROM,
|
||||||
|
FILE_RAM,
|
||||||
|
FILE_STATE,
|
||||||
|
FILE_FDSBIOS,
|
||||||
|
FILE_CHEAT,
|
||||||
|
FILE_PREF
|
||||||
|
};
|
||||||
|
|
||||||
struct SGCSettings{
|
struct SGCSettings{
|
||||||
int AutoLoad;
|
int AutoLoad;
|
||||||
int AutoSave;
|
int AutoSave;
|
||||||
|
@ -119,17 +119,9 @@ int GCMemROM(int method, int size)
|
|||||||
|
|
||||||
char filepath[1024];
|
char filepath[1024];
|
||||||
|
|
||||||
switch (method)
|
if(MakeFilePath(filepath, FILE_FDSBIOS, method))
|
||||||
{
|
{
|
||||||
case METHOD_SD:
|
biosSize = LoadFileBuf (tmpbuffer, filepath, 0, method, SILENT);
|
||||||
case METHOD_USB:
|
|
||||||
sprintf(filepath, "%s/%s/disksys.rom", ROOTFATDIR, GCSettings.LoadFolder);
|
|
||||||
biosSize = LoadBufferFromFAT(tmpbuffer, filepath, NOTSILENT);
|
|
||||||
break;
|
|
||||||
case METHOD_SMB:
|
|
||||||
sprintf(filepath, "%s/disksys.rom", GCSettings.LoadFolder);
|
|
||||||
biosSize = LoadBufferFromSMB(tmpbuffer, filepath, 0, NOTSILENT);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(biosSize == 8192)
|
if(biosSize == 8192)
|
||||||
|
@ -71,6 +71,11 @@ int NGCFCEU_GameSave(CartInfo *LocalHWInfo, int operation)
|
|||||||
|
|
||||||
bool SaveRAM (int method, bool silent)
|
bool SaveRAM (int method, bool silent)
|
||||||
{
|
{
|
||||||
|
bool retval = false;
|
||||||
|
char filepath[1024];
|
||||||
|
int datasize = 0;
|
||||||
|
int offset = 0;
|
||||||
|
|
||||||
if(nesGameType == 4)
|
if(nesGameType == 4)
|
||||||
{
|
{
|
||||||
if(!silent)
|
if(!silent)
|
||||||
@ -78,15 +83,13 @@ bool SaveRAM (int method, bool silent)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
ShowAction ((char*) "Saving...");
|
|
||||||
|
|
||||||
if(method == METHOD_AUTO)
|
if(method == METHOD_AUTO)
|
||||||
method = autoSaveMethod();
|
method = autoSaveMethod();
|
||||||
|
|
||||||
bool retval = false;
|
if (!MakeFilePath(filepath, FILE_RAM, method))
|
||||||
char filepath[1024];
|
return false;
|
||||||
int datasize = 0;
|
|
||||||
int offset = 0;
|
ShowAction ((char*) "Saving...");
|
||||||
|
|
||||||
// save game save to savebuffer
|
// save game save to savebuffer
|
||||||
if(nesGameType == 1)
|
if(nesGameType == 1)
|
||||||
@ -96,28 +99,7 @@ bool SaveRAM (int method, bool silent)
|
|||||||
|
|
||||||
if (datasize)
|
if (datasize)
|
||||||
{
|
{
|
||||||
if(method == METHOD_SD || method == METHOD_USB)
|
offset = SaveFile(filepath, datasize, method, silent);
|
||||||
{
|
|
||||||
if(ChangeFATInterface(method, NOTSILENT))
|
|
||||||
{
|
|
||||||
sprintf (filepath, "%s/%s/%s.sav", ROOTFATDIR, GCSettings.SaveFolder, romFilename);
|
|
||||||
offset = SaveBufferToFAT (filepath, datasize, silent);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if(method == METHOD_SMB)
|
|
||||||
{
|
|
||||||
sprintf (filepath, "%s/%s.sav", GCSettings.SaveFolder, romFilename);
|
|
||||||
offset = SaveBufferToSMB (filepath, datasize, silent);
|
|
||||||
}
|
|
||||||
else if(method == METHOD_MC_SLOTA || method == METHOD_MC_SLOTB)
|
|
||||||
{
|
|
||||||
sprintf (filepath, "%08x.sav", iNESGameCRC32);
|
|
||||||
|
|
||||||
if(method == METHOD_MC_SLOTA)
|
|
||||||
offset = SaveBufferToMC (savebuffer, CARD_SLOTA, filepath, datasize, silent);
|
|
||||||
else
|
|
||||||
offset = SaveBufferToMC (savebuffer, CARD_SLOTB, filepath, datasize, silent);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (offset > 0)
|
if (offset > 0)
|
||||||
{
|
{
|
||||||
@ -136,6 +118,9 @@ bool SaveRAM (int method, bool silent)
|
|||||||
|
|
||||||
bool LoadRAM (int method, bool silent)
|
bool LoadRAM (int method, bool silent)
|
||||||
{
|
{
|
||||||
|
char filepath[1024];
|
||||||
|
int offset = 0;
|
||||||
|
|
||||||
if(nesGameType == 4)
|
if(nesGameType == 4)
|
||||||
{
|
{
|
||||||
if(!silent)
|
if(!silent)
|
||||||
@ -143,36 +128,15 @@ bool LoadRAM (int method, bool silent)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
ShowAction ((char*) "Loading...");
|
|
||||||
|
|
||||||
if(method == METHOD_AUTO)
|
if(method == METHOD_AUTO)
|
||||||
method = autoSaveMethod(); // we use 'Save' because we need R/W
|
method = autoSaveMethod(); // we use 'Save' because we need R/W
|
||||||
|
|
||||||
char filepath[1024];
|
if (!MakeFilePath(filepath, FILE_RAM, method))
|
||||||
int offset = 0;
|
return false;
|
||||||
|
|
||||||
if(method == METHOD_SD || method == METHOD_USB)
|
ShowAction ((char*) "Loading...");
|
||||||
{
|
|
||||||
if(ChangeFATInterface(method, NOTSILENT))
|
|
||||||
{
|
|
||||||
sprintf (filepath, "%s/%s/%s.sav", ROOTFATDIR, GCSettings.SaveFolder, romFilename);
|
|
||||||
offset = LoadSaveBufferFromFAT (filepath, silent);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if(method == METHOD_SMB)
|
|
||||||
{
|
|
||||||
sprintf (filepath, "%s/%s.sav", GCSettings.SaveFolder, romFilename);
|
|
||||||
offset = LoadSaveBufferFromSMB (filepath, silent);
|
|
||||||
}
|
|
||||||
else if(method == METHOD_MC_SLOTA || method == METHOD_MC_SLOTB)
|
|
||||||
{
|
|
||||||
sprintf (filepath, "%08x.sav", iNESGameCRC32);
|
|
||||||
|
|
||||||
if(method == METHOD_MC_SLOTA)
|
offset = LoadFile(filepath, method, silent);
|
||||||
offset = LoadBufferFromMC (savebuffer, CARD_SLOTA, filepath, silent);
|
|
||||||
else
|
|
||||||
offset = LoadBufferFromMC (savebuffer, CARD_SLOTB, filepath, silent);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (offset > 0)
|
if (offset > 0)
|
||||||
{
|
{
|
||||||
@ -182,12 +146,12 @@ bool LoadRAM (int method, bool silent)
|
|||||||
NGCFCEU_GameSave(&UNIFCart, 1);
|
NGCFCEU_GameSave(&UNIFCart, 1);
|
||||||
|
|
||||||
ResetNES();
|
ResetNES();
|
||||||
return 1;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// if we reached here, nothing was done!
|
// if we reached here, nothing was done!
|
||||||
if(!silent)
|
if(!silent)
|
||||||
WaitPrompt ((char*) "Save file not found");
|
WaitPrompt ((char*) "Save file not found");
|
||||||
|
|
||||||
return 0;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -281,42 +281,24 @@ int GCFCEUSS_Save()
|
|||||||
|
|
||||||
bool SaveState (int method, bool silent)
|
bool SaveState (int method, bool silent)
|
||||||
{
|
{
|
||||||
ShowAction ((char*) "Saving...");
|
|
||||||
|
|
||||||
if(method == METHOD_AUTO)
|
|
||||||
method = autoSaveMethod();
|
|
||||||
|
|
||||||
bool retval = false;
|
bool retval = false;
|
||||||
char filepath[1024];
|
char filepath[1024];
|
||||||
int datasize;
|
int datasize;
|
||||||
int offset = 0;
|
int offset = 0;
|
||||||
|
|
||||||
|
if(method == METHOD_AUTO)
|
||||||
|
method = autoSaveMethod();
|
||||||
|
|
||||||
|
if (!MakeFilePath(filepath, FILE_STATE, method))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
ShowAction ((char*) "Saving...");
|
||||||
|
|
||||||
datasize = GCFCEUSS_Save();
|
datasize = GCFCEUSS_Save();
|
||||||
|
|
||||||
if (datasize)
|
if (datasize)
|
||||||
{
|
{
|
||||||
if(method == METHOD_SD || method == METHOD_USB)
|
offset = SaveFile(filepath, datasize, method, silent);
|
||||||
{
|
|
||||||
if(ChangeFATInterface(method, NOTSILENT))
|
|
||||||
{
|
|
||||||
sprintf (filepath, "%s/%s/%s.fcs", ROOTFATDIR, GCSettings.SaveFolder, romFilename);
|
|
||||||
offset = SaveBufferToFAT (filepath, datasize, silent);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if(method == METHOD_SMB)
|
|
||||||
{
|
|
||||||
sprintf (filepath, "%s/%s.fcs", GCSettings.SaveFolder, romFilename);
|
|
||||||
offset = SaveBufferToSMB (filepath, datasize, silent);
|
|
||||||
}
|
|
||||||
else if(method == METHOD_MC_SLOTA || method == METHOD_MC_SLOTB)
|
|
||||||
{
|
|
||||||
sprintf (filepath, "%08x.fcs", iNESGameCRC32);
|
|
||||||
|
|
||||||
if(method == METHOD_MC_SLOTA)
|
|
||||||
offset = SaveBufferToMC (savebuffer, CARD_SLOTA, filepath, datasize, silent);
|
|
||||||
else
|
|
||||||
offset = SaveBufferToMC (savebuffer, CARD_SLOTB, filepath, datasize, silent);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (offset > 0)
|
if (offset > 0)
|
||||||
{
|
{
|
||||||
@ -330,41 +312,18 @@ bool SaveState (int method, bool silent)
|
|||||||
|
|
||||||
bool LoadState (int method, bool silent)
|
bool LoadState (int method, bool silent)
|
||||||
{
|
{
|
||||||
ShowAction ((char*) "Loading...");
|
char filepath[1024];
|
||||||
|
int offset = 0;
|
||||||
|
|
||||||
if(method == METHOD_AUTO)
|
if(method == METHOD_AUTO)
|
||||||
method = autoSaveMethod(); // we use 'Save' because we need R/W
|
method = autoSaveMethod(); // we use 'Save' because we need R/W
|
||||||
|
|
||||||
char filepath[1024];
|
if (!MakeFilePath(filepath, FILE_STATE, method))
|
||||||
int offset = 0;
|
return false;
|
||||||
|
|
||||||
if(method == METHOD_SD || method == METHOD_USB)
|
ShowAction ((char*) "Loading...");
|
||||||
{
|
|
||||||
ChangeFATInterface(method, NOTSILENT);
|
|
||||||
sprintf (filepath, "%s/%s/%s.fcs", ROOTFATDIR, GCSettings.SaveFolder, romFilename);
|
|
||||||
offset = LoadSaveBufferFromFAT (filepath, silent);
|
|
||||||
|
|
||||||
if(offset == 0) // file not found
|
offset = LoadFile(filepath, method, silent);
|
||||||
{
|
|
||||||
// look for CRC save
|
|
||||||
sprintf (filepath, "%08x.fcs", iNESGameCRC32);
|
|
||||||
offset = LoadSaveBufferFromFAT (filepath, silent);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if(method == METHOD_SMB)
|
|
||||||
{
|
|
||||||
sprintf (filepath, "%s/%s.fcs", GCSettings.SaveFolder, romFilename);
|
|
||||||
offset = LoadSaveBufferFromSMB (filepath, silent);
|
|
||||||
}
|
|
||||||
else if(method == METHOD_MC_SLOTA || method == METHOD_MC_SLOTB)
|
|
||||||
{
|
|
||||||
sprintf (filepath, "%08x.fcs", iNESGameCRC32);
|
|
||||||
|
|
||||||
if(method == METHOD_MC_SLOTA)
|
|
||||||
offset = LoadBufferFromMC (savebuffer, CARD_SLOTA, filepath, silent);
|
|
||||||
else
|
|
||||||
offset = LoadBufferFromMC (savebuffer, CARD_SLOTB, filepath, silent);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (offset > 0)
|
if (offset > 0)
|
||||||
{
|
{
|
||||||
|
@ -26,27 +26,6 @@
|
|||||||
// FAT file pointer - the only one we should ever use!
|
// FAT file pointer - the only one we should ever use!
|
||||||
FILE * fatfile;
|
FILE * fatfile;
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* MountFAT
|
|
||||||
* Attempts to mount the FAT device specified
|
|
||||||
* Sets libfat to use the device by default
|
|
||||||
* Enables read-ahead cache for SD/USB
|
|
||||||
***************************************************************************/
|
|
||||||
bool MountFAT(PARTITION_INTERFACE part)
|
|
||||||
{
|
|
||||||
bool mounted = fatMountNormalInterface(part, 8);
|
|
||||||
|
|
||||||
if(mounted)
|
|
||||||
{
|
|
||||||
fatSetDefaultInterface(part);
|
|
||||||
#ifdef HW_RVL
|
|
||||||
if(part == PI_INTERNAL_SD || part == PI_USBSTORAGE)
|
|
||||||
fatEnableReadAhead (part, 6, 64);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
return mounted;
|
|
||||||
}
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* UnmountFAT
|
* UnmountFAT
|
||||||
* Unmounts the FAT device specified
|
* Unmounts the FAT device specified
|
||||||
@ -71,6 +50,31 @@ void UnmountAllFAT()
|
|||||||
UnmountFAT(PI_SDGECKO_B);
|
UnmountFAT(PI_SDGECKO_B);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* MountFAT
|
||||||
|
* Checks if the device needs to be (re)mounted
|
||||||
|
* If so, unmounts the device
|
||||||
|
* Attempts to mount the device specified
|
||||||
|
* Sets libfat to use the device by default
|
||||||
|
* Enables read-ahead cache for SD/USB
|
||||||
|
***************************************************************************/
|
||||||
|
bool MountFAT(PARTITION_INTERFACE part)
|
||||||
|
{
|
||||||
|
UnmountFAT(part);
|
||||||
|
|
||||||
|
bool mounted = fatMountNormalInterface(part, 8);
|
||||||
|
|
||||||
|
if(mounted)
|
||||||
|
{
|
||||||
|
fatSetDefaultInterface(part);
|
||||||
|
#ifdef HW_RVL
|
||||||
|
if(part == PI_INTERNAL_SD || part == PI_USBSTORAGE)
|
||||||
|
fatEnableReadAhead (part, 6, 64);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
return mounted;
|
||||||
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* ChangeFATInterface
|
* ChangeFATInterface
|
||||||
* Unmounts all devices and attempts to mount/configure the device specified
|
* Unmounts all devices and attempts to mount/configure the device specified
|
||||||
@ -79,9 +83,6 @@ bool ChangeFATInterface(int method, bool silent)
|
|||||||
{
|
{
|
||||||
bool mounted = false;
|
bool mounted = false;
|
||||||
|
|
||||||
// unmount all FAT devices
|
|
||||||
UnmountAllFAT();
|
|
||||||
|
|
||||||
if(method == METHOD_SD)
|
if(method == METHOD_SD)
|
||||||
{
|
{
|
||||||
#ifdef HW_RVL
|
#ifdef HW_RVL
|
||||||
@ -99,6 +100,7 @@ bool ChangeFATInterface(int method, bool silent)
|
|||||||
{
|
{
|
||||||
#ifdef HW_RVL
|
#ifdef HW_RVL
|
||||||
mounted = MountFAT(PI_USBSTORAGE);
|
mounted = MountFAT(PI_USBSTORAGE);
|
||||||
|
|
||||||
if(!mounted && !silent)
|
if(!mounted && !silent)
|
||||||
WaitPrompt ((char *)"USB drive not found!");
|
WaitPrompt ((char *)"USB drive not found!");
|
||||||
#endif
|
#endif
|
||||||
@ -109,7 +111,7 @@ bool ChangeFATInterface(int method, bool silent)
|
|||||||
|
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* Browse FAT subdirectories
|
* Browse FAT subdirectories
|
||||||
***************************************************************************/
|
**************************************************************************/
|
||||||
int
|
int
|
||||||
ParseFATdirectory(int method)
|
ParseFATdirectory(int method)
|
||||||
{
|
{
|
||||||
@ -155,7 +157,6 @@ ParseFATdirectory(int method)
|
|||||||
strncpy(filelist[nbfiles].displayname, filename, MAXDISPLAY+1); // crop name for display
|
strncpy(filelist[nbfiles].displayname, filename, MAXDISPLAY+1); // crop name for display
|
||||||
filelist[nbfiles].length = filestat.st_size;
|
filelist[nbfiles].length = filestat.st_size;
|
||||||
filelist[nbfiles].flags = (filestat.st_mode & _IFDIR) == 0 ? 0 : 1; // flag this as a dir
|
filelist[nbfiles].flags = (filestat.st_mode & _IFDIR) == 0 ? 0 : 1; // flag this as a dir
|
||||||
filelist[nbfiles].offset = 0;
|
|
||||||
nbfiles++;
|
nbfiles++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -169,60 +170,6 @@ ParseFATdirectory(int method)
|
|||||||
return nbfiles;
|
return nbfiles;
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* LoadFATFile
|
|
||||||
* length > 0 - partial file read (starting from start)
|
|
||||||
* length = 0 - full read
|
|
||||||
***************************************************************************/
|
|
||||||
int
|
|
||||||
LoadFATFile (char * rbuffer, int length)
|
|
||||||
{
|
|
||||||
char zipbuffer[2048];
|
|
||||||
char filepath[MAXPATHLEN];
|
|
||||||
u32 size;
|
|
||||||
|
|
||||||
if (!MakeROMPath(filepath, METHOD_SD))
|
|
||||||
{
|
|
||||||
WaitPrompt((char*) "Maximum filepath length reached!");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
fatfile = fopen (filepath, "rb");
|
|
||||||
if (fatfile > 0)
|
|
||||||
{
|
|
||||||
if(length > 0) // do a partial read (eg: to check file header)
|
|
||||||
{
|
|
||||||
fread (rbuffer, 1, length, fatfile);
|
|
||||||
size = length;
|
|
||||||
}
|
|
||||||
else // load whole file
|
|
||||||
{
|
|
||||||
fread (zipbuffer, 1, 2048, fatfile);
|
|
||||||
|
|
||||||
if (IsZipFile (zipbuffer))
|
|
||||||
{
|
|
||||||
size = UnZipBuffer ((unsigned char *)rbuffer, METHOD_SD); // unzip from FAT
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// Just load the file up
|
|
||||||
fseek(fatfile, 0, SEEK_END);
|
|
||||||
size = ftell(fatfile); // get filesize
|
|
||||||
fseek(fatfile, 2048, SEEK_SET); // seek back to point where we left off
|
|
||||||
memcpy (rbuffer, zipbuffer, 2048); // copy what we already read
|
|
||||||
fread (rbuffer + 2048, 1, size - 2048, fatfile);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
fclose (fatfile);
|
|
||||||
return size;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
WaitPrompt((char*) "Error opening file");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* LoadFATSzFile
|
* LoadFATSzFile
|
||||||
* Loads the selected file # from the specified 7z into rbuffer
|
* Loads the selected file # from the specified 7z into rbuffer
|
||||||
@ -247,49 +194,61 @@ LoadFATSzFile(char * filepath, unsigned char * rbuffer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Load savebuffer from FAT file
|
* LoadFATFile
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
// no buffer is specified - so use savebuffer
|
|
||||||
int
|
int
|
||||||
LoadSaveBufferFromFAT (char *filepath, bool silent)
|
LoadFATFile (char * rbuffer, char *filepath, int length, bool silent)
|
||||||
{
|
|
||||||
return LoadBufferFromFAT((char *)savebuffer, filepath, silent);
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
LoadBufferFromFAT (char * sbuffer, char *filepath, bool silent)
|
|
||||||
{
|
{
|
||||||
|
char zipbuffer[2048];
|
||||||
int size = 0;
|
int size = 0;
|
||||||
|
int readsize = 0;
|
||||||
|
|
||||||
fatfile = fopen (filepath, "rb");
|
fatfile = fopen (filepath, "rb");
|
||||||
|
|
||||||
if (fatfile <= 0)
|
if (fatfile > 0)
|
||||||
{
|
{
|
||||||
if ( !silent )
|
if(length > 0 && length <= 2048) // do a partial read (eg: to check file header)
|
||||||
{
|
{
|
||||||
char msg[100];
|
fread (rbuffer, 1, length, fatfile);
|
||||||
sprintf(msg, "Couldn't open %s", filepath);
|
size = length;
|
||||||
WaitPrompt (msg);
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
else // load whole file
|
||||||
|
{
|
||||||
|
readsize = fread (zipbuffer, 1, 2048, fatfile);
|
||||||
|
|
||||||
|
if(readsize > 0)
|
||||||
|
{
|
||||||
|
if (IsZipFile (zipbuffer))
|
||||||
|
{
|
||||||
|
size = UnZipBuffer ((unsigned char *)rbuffer, METHOD_SD); // unzip from FAT
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
// Just load the file up
|
// Just load the file up
|
||||||
fseek(fatfile, 0, SEEK_END); // go to end of file
|
fseek(fatfile, 0, SEEK_END); // go to end of file
|
||||||
size = ftell(fatfile); // get filesize
|
size = ftell(fatfile); // get filesize
|
||||||
fseek(fatfile, 0, SEEK_SET); // go to start of file
|
fseek(fatfile, 0, SEEK_SET); // go to start of file
|
||||||
fread (sbuffer, 1, size, fatfile);
|
fread (rbuffer, 1, size, fatfile);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
fclose (fatfile);
|
fclose (fatfile);
|
||||||
|
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if(!silent)
|
||||||
|
WaitPrompt((char*) "Error opening file!");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Write savebuffer to FAT card file
|
* SaveFATFile
|
||||||
****************************************************************************/
|
* Write buffer to FAT card file
|
||||||
|
***************************************************************************/
|
||||||
int
|
int
|
||||||
SaveBufferToFAT (char *filepath, int datasize, bool silent)
|
SaveFATFile (char * buffer, char *filepath, int datasize, bool silent)
|
||||||
{
|
{
|
||||||
if (datasize)
|
if (datasize)
|
||||||
{
|
{
|
||||||
|
@ -24,11 +24,9 @@
|
|||||||
|
|
||||||
bool ChangeFATInterface(int method, bool silent);
|
bool ChangeFATInterface(int method, bool silent);
|
||||||
int ParseFATdirectory(int method);
|
int ParseFATdirectory(int method);
|
||||||
int LoadFATFile (char * fbuffer, int length);
|
|
||||||
int LoadFATSzFile(char * filepath, unsigned char * rbuffer);
|
int LoadFATSzFile(char * filepath, unsigned char * rbuffer);
|
||||||
int SaveBufferToFAT (char *filepath, int datasize, bool silent);
|
int SaveFATFile (char * sbuffer, char *filepath, int length, bool silent);
|
||||||
int LoadSaveBufferFromFAT (char *filepath, bool silent);
|
int LoadFATFile (char * sbuffer, char *filepath, int length, bool silent);
|
||||||
int LoadBufferFromFAT (char * buffer, char *filepath, bool silent);
|
|
||||||
|
|
||||||
extern char currFATdir[MAXPATHLEN];
|
extern char currFATdir[MAXPATHLEN];
|
||||||
extern FILE * fatfile;
|
extern FILE * fatfile;
|
||||||
|
@ -114,12 +114,11 @@ int UpdateDirName(int method)
|
|||||||
char * test;
|
char * test;
|
||||||
char temp[1024];
|
char temp[1024];
|
||||||
|
|
||||||
// update DVD directory (does not utilize 'currentdir')
|
// update DVD directory
|
||||||
if(method == METHOD_DVD)
|
if(method == METHOD_DVD)
|
||||||
{
|
{
|
||||||
dvddir = filelist[selection].offset;
|
dvddir = filelist[selection].offset;
|
||||||
dvddirlength = filelist[selection].length;
|
dvddirlength = filelist[selection].length;
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* current directory doesn't change */
|
/* current directory doesn't change */
|
||||||
@ -163,26 +162,127 @@ int UpdateDirName(int method)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool MakeROMPath(char filepath[], int method)
|
bool MakeFilePath(char filepath[], int type, int method)
|
||||||
{
|
{
|
||||||
|
char file[512];
|
||||||
|
char folder[1024];
|
||||||
char temppath[MAXPATHLEN];
|
char temppath[MAXPATHLEN];
|
||||||
|
|
||||||
// Check filename length
|
if(type == FILE_ROM)
|
||||||
if ((strlen(currentdir)+1+strlen(filelist[selection].filename)) < MAXPATHLEN)
|
|
||||||
{
|
{
|
||||||
sprintf(temppath, "%s/%s",currentdir,filelist[selection].filename);
|
// Check path length
|
||||||
|
if ((strlen(currentdir)+1+strlen(filelist[selection].filename)) >= MAXPATHLEN)
|
||||||
if(method == METHOD_SMB)
|
|
||||||
strcpy(filepath, SMBPath(temppath));
|
|
||||||
else
|
|
||||||
strcpy(filepath, temppath);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
|
WaitPrompt((char*)"Maximum filepath length reached!");
|
||||||
filepath[0] = 0;
|
filepath[0] = 0;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sprintf(temppath, "%s/%s",currentdir,filelist[selection].filename);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
switch(type)
|
||||||
|
{
|
||||||
|
case FILE_RAM:
|
||||||
|
sprintf(folder, GCSettings.SaveFolder);
|
||||||
|
sprintf(file, "%s.sav", romFilename);
|
||||||
|
break;
|
||||||
|
case FILE_STATE:
|
||||||
|
sprintf(folder, GCSettings.SaveFolder);
|
||||||
|
sprintf(file, "%s.fcs", romFilename);
|
||||||
|
break;
|
||||||
|
case FILE_FDSBIOS:
|
||||||
|
sprintf(folder, GCSettings.LoadFolder);
|
||||||
|
sprintf(file, "disksys.rom");
|
||||||
|
break;
|
||||||
|
case FILE_PREF:
|
||||||
|
sprintf(folder, GCSettings.SaveFolder);
|
||||||
|
sprintf(file, "%s", PREF_FILE_NAME);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
switch(method)
|
||||||
|
{
|
||||||
|
case METHOD_SD:
|
||||||
|
case METHOD_USB:
|
||||||
|
sprintf (temppath, "%s/%s/%s", ROOTFATDIR, folder, file);
|
||||||
|
break;
|
||||||
|
case METHOD_DVD:
|
||||||
|
case METHOD_SMB:
|
||||||
|
sprintf (temppath, "%s/%s", folder, file);
|
||||||
|
break;
|
||||||
|
case METHOD_MC_SLOTA:
|
||||||
|
case METHOD_MC_SLOTB:
|
||||||
|
sprintf (temppath, "%s", file);
|
||||||
|
temppath[31] = 0; // truncate filename
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
strcpy(filepath, temppath);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
int LoadFileBuf(char * buffer, char filepath[], int length, int method, bool silent)
|
||||||
|
{
|
||||||
|
int offset = 0;
|
||||||
|
|
||||||
|
switch(method)
|
||||||
|
{
|
||||||
|
case METHOD_SD:
|
||||||
|
case METHOD_USB:
|
||||||
|
if(ChangeFATInterface(method, NOTSILENT))
|
||||||
|
offset = LoadFATFile (buffer, filepath, length, silent);
|
||||||
|
break;
|
||||||
|
case METHOD_SMB:
|
||||||
|
offset = LoadSMBFile (buffer, filepath, length, silent);
|
||||||
|
break;
|
||||||
|
case METHOD_DVD:
|
||||||
|
offset = LoadDVDFile (buffer, filepath, length, silent);
|
||||||
|
break;
|
||||||
|
case METHOD_MC_SLOTA:
|
||||||
|
offset = LoadMCFile (buffer, CARD_SLOTA, filepath, silent);
|
||||||
|
break;
|
||||||
|
case METHOD_MC_SLOTB:
|
||||||
|
offset = LoadMCFile (buffer, CARD_SLOTB, filepath, silent);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return offset;
|
||||||
|
}
|
||||||
|
|
||||||
|
int LoadFile(char filepath[], int method, bool silent)
|
||||||
|
{
|
||||||
|
return LoadFileBuf((char *)savebuffer, filepath, 0, method, silent);
|
||||||
|
}
|
||||||
|
|
||||||
|
int SaveFileBuf(char * buffer, char filepath[], int datasize, int method, bool silent)
|
||||||
|
{
|
||||||
|
int offset = 0;
|
||||||
|
|
||||||
|
switch(method)
|
||||||
|
{
|
||||||
|
case METHOD_SD:
|
||||||
|
case METHOD_USB:
|
||||||
|
if(ChangeFATInterface(method, NOTSILENT))
|
||||||
|
offset = SaveFATFile (buffer, filepath, datasize, silent);
|
||||||
|
break;
|
||||||
|
case METHOD_SMB:
|
||||||
|
offset = SaveSMBFile (buffer, filepath, datasize, silent);
|
||||||
|
break;
|
||||||
|
case METHOD_MC_SLOTA:
|
||||||
|
offset = SaveMCFile (buffer, CARD_SLOTA, filepath, datasize, silent);
|
||||||
|
break;
|
||||||
|
case METHOD_MC_SLOTB:
|
||||||
|
offset = SaveMCFile (buffer, CARD_SLOTB, filepath, datasize, silent);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return offset;
|
||||||
|
}
|
||||||
|
|
||||||
|
int SaveFile(char filepath[], int datasize, int method, bool silent)
|
||||||
|
{
|
||||||
|
return SaveFileBuf((char *)savebuffer, filepath, datasize, method, silent);
|
||||||
}
|
}
|
||||||
|
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
@ -424,11 +524,9 @@ int FileSelector (int method)
|
|||||||
if(IsSz())
|
if(IsSz())
|
||||||
{
|
{
|
||||||
// we'll store the 7z filepath for extraction later
|
// we'll store the 7z filepath for extraction later
|
||||||
if(!MakeROMPath(szpath, method))
|
if(!MakeFilePath(szpath, FILE_ROM, method))
|
||||||
{
|
|
||||||
WaitPrompt((char*) "Maximum filepath length reached!");
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
|
||||||
int szfiles = SzParse(szpath, method);
|
int szfiles = SzParse(szpath, method);
|
||||||
if(szfiles)
|
if(szfiles)
|
||||||
{
|
{
|
||||||
@ -451,30 +549,32 @@ int FileSelector (int method)
|
|||||||
|
|
||||||
int size = 0;
|
int size = 0;
|
||||||
|
|
||||||
|
if(!inSz)
|
||||||
|
{
|
||||||
|
char filepath[1024];
|
||||||
|
|
||||||
|
if(!MakeFilePath(filepath, FILE_ROM, method))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
size = LoadFileBuf((char *)nesrom, filepath, filelist[selection].length, method, NOTSILENT);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
switch (method)
|
switch (method)
|
||||||
{
|
{
|
||||||
case METHOD_SD:
|
case METHOD_SD:
|
||||||
case METHOD_USB:
|
case METHOD_USB:
|
||||||
if(inSz)
|
|
||||||
size = LoadFATSzFile(szpath, nesrom);
|
size = LoadFATSzFile(szpath, nesrom);
|
||||||
else
|
|
||||||
size = LoadFATFile((char *)nesrom, 0);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case METHOD_DVD:
|
case METHOD_DVD:
|
||||||
if(inSz)
|
|
||||||
size = SzExtractFile(filelist[selection].offset, nesrom);
|
size = SzExtractFile(filelist[selection].offset, nesrom);
|
||||||
else
|
|
||||||
size = LoadDVDFile(nesrom, 0);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case METHOD_SMB:
|
case METHOD_SMB:
|
||||||
if(inSz)
|
|
||||||
size = LoadSMBSzFile(szpath, nesrom);
|
size = LoadSMBSzFile(szpath, nesrom);
|
||||||
else
|
|
||||||
size = LoadSMBFile((char *)nesrom, 0);
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
inSz = false;
|
inSz = false;
|
||||||
|
|
||||||
if (size > 0)
|
if (size > 0)
|
||||||
@ -627,6 +727,7 @@ OpenDVD (int method)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
currentdir[0] = 0;
|
||||||
maxfiles = ParseDVDdirectory(); // load root folder
|
maxfiles = ParseDVDdirectory(); // load root folder
|
||||||
|
|
||||||
// switch to rom folder
|
// switch to rom folder
|
||||||
|
@ -39,7 +39,11 @@ extern char romFilename[];
|
|||||||
extern int nesGameType;
|
extern int nesGameType;
|
||||||
|
|
||||||
void ClearSaveBuffer ();
|
void ClearSaveBuffer ();
|
||||||
bool MakeROMPath(char filepath[], int method);
|
bool MakeFilePath(char filepath[], int type, int method);
|
||||||
|
int LoadFileBuf(char * buffer, char filepath[], int length, int method, bool silent);
|
||||||
|
int LoadFile(char filepath[], int method, bool silent);
|
||||||
|
int SaveFileBuf(char * buffer, char filepath[], int datasize, int method, bool silent);
|
||||||
|
int SaveFile(char filepath[], int datasize, int method, bool silent);
|
||||||
int OpenROM (int method);
|
int OpenROM (int method);
|
||||||
int autoLoadMethod();
|
int autoLoadMethod();
|
||||||
int autoSaveMethod();
|
int autoSaveMethod();
|
||||||
|
@ -96,7 +96,6 @@ UnZipBuffer (unsigned char *outbuffer, int method)
|
|||||||
int readoffset = 0;
|
int readoffset = 0;
|
||||||
int have = 0;
|
int have = 0;
|
||||||
char readbuffer[ZIPCHUNK];
|
char readbuffer[ZIPCHUNK];
|
||||||
char msg[128];
|
|
||||||
u64 discoffset = 0;
|
u64 discoffset = 0;
|
||||||
|
|
||||||
// Read Zip Header
|
// Read Zip Header
|
||||||
@ -123,10 +122,6 @@ UnZipBuffer (unsigned char *outbuffer, int method)
|
|||||||
|
|
||||||
pkzip.uncompressedSize = FLIP32 (pkzip.uncompressedSize);
|
pkzip.uncompressedSize = FLIP32 (pkzip.uncompressedSize);
|
||||||
|
|
||||||
sprintf (msg, "Unzipping %d bytes ... Wait",
|
|
||||||
pkzip.uncompressedSize);
|
|
||||||
ShowAction (msg);
|
|
||||||
|
|
||||||
/*** Prepare the zip stream ***/
|
/*** Prepare the zip stream ***/
|
||||||
memset (&zs, 0, sizeof (z_stream));
|
memset (&zs, 0, sizeof (z_stream));
|
||||||
zs.zalloc = Z_NULL;
|
zs.zalloc = Z_NULL;
|
||||||
@ -224,23 +219,13 @@ GetFirstZipFilename (int method)
|
|||||||
{
|
{
|
||||||
char * firstFilename = NULL;
|
char * firstFilename = NULL;
|
||||||
char tempbuffer[ZIPCHUNK];
|
char tempbuffer[ZIPCHUNK];
|
||||||
|
char filepath[1024];
|
||||||
|
|
||||||
|
if(!MakeFilePath(filepath, FILE_ROM, method))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
// read start of ZIP
|
// read start of ZIP
|
||||||
switch (method)
|
LoadFileBuf (tempbuffer, filepath, ZIPCHUNK, method, NOTSILENT);
|
||||||
{
|
|
||||||
case METHOD_SD: // SD Card
|
|
||||||
case METHOD_USB: // USB
|
|
||||||
LoadFATFile (tempbuffer, ZIPCHUNK);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case METHOD_DVD: // DVD
|
|
||||||
LoadDVDFile ((unsigned char *)tempbuffer, ZIPCHUNK);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case METHOD_SMB: // From SMB
|
|
||||||
LoadSMBFile (tempbuffer, ZIPCHUNK);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
tempbuffer[28] = 0; // truncate - filename length is 2 bytes long (bytes 26-27)
|
tempbuffer[28] = 0; // truncate - filename length is 2 bytes long (bytes 26-27)
|
||||||
int namelength = tempbuffer[26]; // filename length starts 26 bytes in
|
int namelength = tempbuffer[26]; // filename length starts 26 bytes in
|
||||||
@ -318,6 +303,7 @@ void SzDisplayError(SZ_RESULT res)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// function used by the 7zip SDK to read data from SD/USB/DVD/SMB
|
// function used by the 7zip SDK to read data from SD/USB/DVD/SMB
|
||||||
|
|
||||||
SZ_RESULT SzFileReadImp(void *object, void **buffer, size_t maxRequiredSize, size_t *processedSize)
|
SZ_RESULT SzFileReadImp(void *object, void **buffer, size_t maxRequiredSize, size_t *processedSize)
|
||||||
{
|
{
|
||||||
// the void* object is a SzFileInStream
|
// the void* object is a SzFileInStream
|
||||||
@ -361,7 +347,7 @@ SZ_RESULT SzFileSeekImp(void *object, CFileSize pos)
|
|||||||
// check if the 7z SDK wants to move the pointer to somewhere after the EOF
|
// check if the 7z SDK wants to move the pointer to somewhere after the EOF
|
||||||
if (pos >= s->len)
|
if (pos >= s->len)
|
||||||
{
|
{
|
||||||
WaitPrompt("7z Error: The 7z SDK wants to start reading somewhere behind the EOF...");
|
WaitPrompt((char *) "7z: Error - attempt to read after EOF!");
|
||||||
return SZE_FAIL;
|
return SZE_FAIL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -520,7 +506,6 @@ int SzExtractFile(int i, unsigned char *buffer)
|
|||||||
SzOffset = 0;
|
SzOffset = 0;
|
||||||
|
|
||||||
// Unzip the file
|
// Unzip the file
|
||||||
ShowAction("Unzipping file. Please wait...");
|
|
||||||
|
|
||||||
SzRes = SzExtract2(
|
SzRes = SzExtract2(
|
||||||
&SzArchiveStream.InStream,
|
&SzArchiveStream.InStream,
|
||||||
|
@ -36,7 +36,7 @@ card_stat CardStatus;
|
|||||||
*
|
*
|
||||||
* Wrapper to search through the files on the card.
|
* Wrapper to search through the files on the card.
|
||||||
* Returns TRUE if found.
|
* Returns TRUE if found.
|
||||||
****************************************************************************/
|
***************************************************************************/
|
||||||
int
|
int
|
||||||
CardFileExists (char *filename, int slot)
|
CardFileExists (char *filename, int slot)
|
||||||
{
|
{
|
||||||
@ -58,7 +58,7 @@ CardFileExists (char *filename, int slot)
|
|||||||
* TestCard
|
* TestCard
|
||||||
*
|
*
|
||||||
* Checks to see if a card is in the card slot specified
|
* Checks to see if a card is in the card slot specified
|
||||||
****************************************************************************/
|
***************************************************************************/
|
||||||
bool TestCard(int slot, bool silent)
|
bool TestCard(int slot, bool silent)
|
||||||
{
|
{
|
||||||
// Memory Cards do not work in Wii mode - disable
|
// Memory Cards do not work in Wii mode - disable
|
||||||
@ -103,7 +103,7 @@ bool TestCard(int slot, bool silent)
|
|||||||
*
|
*
|
||||||
* Mounts the memory card in the given slot.
|
* Mounts the memory card in the given slot.
|
||||||
* Returns the result of the last attempted CARD_Mount command.
|
* Returns the result of the last attempted CARD_Mount command.
|
||||||
****************************************************************************/
|
***************************************************************************/
|
||||||
int MountCard(int cslot, bool silent)
|
int MountCard(int cslot, bool silent)
|
||||||
{
|
{
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
@ -123,9 +123,9 @@ int MountCard(int cslot, bool silent)
|
|||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Verify Memory Card file against buffer
|
* Verify Memory Card file against buffer
|
||||||
****************************************************************************/
|
***************************************************************************/
|
||||||
int
|
int
|
||||||
VerifyMCFile (unsigned char *buf, int slot, char *filename, int datasize)
|
VerifyMCFile (char *buf, int slot, char *filename, int datasize)
|
||||||
{
|
{
|
||||||
int CardError;
|
int CardError;
|
||||||
unsigned int blocks;
|
unsigned int blocks;
|
||||||
@ -201,12 +201,12 @@ VerifyMCFile (unsigned char *buf, int slot, char *filename, int datasize)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
|
* LoadMCFile
|
||||||
* Load savebuffer from Memory Card file
|
* Load savebuffer from Memory Card file
|
||||||
****************************************************************************/
|
***************************************************************************/
|
||||||
int
|
int
|
||||||
LoadBufferFromMC (unsigned char *buf, int slot, char *filename, bool silent)
|
LoadMCFile (char *buf, int slot, char *filename, bool silent)
|
||||||
{
|
{
|
||||||
int CardError;
|
int CardError;
|
||||||
unsigned int blocks;
|
unsigned int blocks;
|
||||||
@ -268,10 +268,11 @@ LoadBufferFromMC (unsigned char *buf, int slot, char *filename, bool silent)
|
|||||||
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
|
* SaveMCFile
|
||||||
* Write savebuffer to Memory Card file
|
* Write savebuffer to Memory Card file
|
||||||
****************************************************************************/
|
***************************************************************************/
|
||||||
int
|
int
|
||||||
SaveBufferToMC (unsigned char *buf, int slot, char *filename, int datasize, bool silent)
|
SaveMCFile (char *buf, int slot, char *filename, int datasize, bool silent)
|
||||||
{
|
{
|
||||||
int CardError;
|
int CardError;
|
||||||
unsigned int blocks;
|
unsigned int blocks;
|
||||||
@ -405,7 +406,7 @@ SaveBufferToMC (unsigned char *buf, int slot, char *filename, int datasize, bool
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
if ( !silent )
|
if ( !silent )
|
||||||
WaitPrompt((char*) "No to data to save!");
|
WaitPrompt((char*) "This game does not appear to use RAM");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
if (slot == CARD_SLOTA)
|
if (slot == CARD_SLOTA)
|
||||||
@ -416,5 +417,3 @@ SaveBufferToMC (unsigned char *buf, int slot, char *filename, int datasize, bool
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -12,10 +12,9 @@
|
|||||||
#ifndef _MEMCARDOP_H_
|
#ifndef _MEMCARDOP_H_
|
||||||
#define _MEMCARDOP_H_
|
#define _MEMCARDOP_H_
|
||||||
|
|
||||||
int VerifyMCFile (unsigned char *buf, int slot, char *filename, int datasize);
|
int VerifyMCFile (char *buf, int slot, char *filename, int datasize);
|
||||||
|
int LoadMCFile (char *buf, int slot, char *filename, bool silent);
|
||||||
int LoadBufferFromMC (unsigned char *buf, int slot, char *filename, bool silent);
|
int SaveMCFile (char *buf, int slot, char *filename, int datasize, bool silent);
|
||||||
int SaveBufferToMC (unsigned char *buf, int slot, char *filename, int datasize, bool silent);
|
|
||||||
int MountCard(int cslot, bool silent);
|
int MountCard(int cslot, bool silent);
|
||||||
bool TestCard(int slot, bool silent);
|
bool TestCard(int slot, bool silent);
|
||||||
|
|
||||||
|
@ -33,8 +33,6 @@ extern unsigned int wmpadmap[];
|
|||||||
extern unsigned int ccpadmap[];
|
extern unsigned int ccpadmap[];
|
||||||
extern unsigned int ncpadmap[];
|
extern unsigned int ncpadmap[];
|
||||||
|
|
||||||
#define PREFS_FILE_NAME "FCEUGX.xml"
|
|
||||||
|
|
||||||
char prefscomment[2][32];
|
char prefscomment[2][32];
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@ -322,41 +320,24 @@ decodePrefsData (int method)
|
|||||||
bool
|
bool
|
||||||
SavePrefs (int method, bool silent)
|
SavePrefs (int method, bool silent)
|
||||||
{
|
{
|
||||||
|
char filepath[1024];
|
||||||
|
int datasize;
|
||||||
|
int offset = 0;
|
||||||
|
|
||||||
// there's no point in saving SMB settings TO SMB, because then we'll have no way to load them the next time!
|
// there's no point in saving SMB settings TO SMB, because then we'll have no way to load them the next time!
|
||||||
// so instead we'll save using whatever other method is available (eg: SD)
|
// so instead we'll save using whatever other method is available (eg: SD)
|
||||||
if(method == METHOD_AUTO || method == METHOD_SMB)
|
if(method == METHOD_AUTO || method == METHOD_SMB)
|
||||||
method = autoSaveMethod();
|
method = autoSaveMethod();
|
||||||
|
|
||||||
char filepath[1024];
|
if(!MakeFilePath(filepath, FILE_PREF, method))
|
||||||
int datasize;
|
return false;
|
||||||
int offset = 0;
|
|
||||||
|
|
||||||
datasize = preparePrefsData (method);
|
|
||||||
|
|
||||||
if (!silent)
|
if (!silent)
|
||||||
ShowAction ((char*) "Saving preferences...");
|
ShowAction ((char*) "Saving preferences...");
|
||||||
|
|
||||||
if(method == METHOD_SD || method == METHOD_USB)
|
datasize = preparePrefsData (method);
|
||||||
{
|
|
||||||
if(ChangeFATInterface(method, NOTSILENT))
|
offset = SaveFile(filepath, datasize, method, silent);
|
||||||
{
|
|
||||||
sprintf (filepath, "%s/%s/%s", ROOTFATDIR, GCSettings.SaveFolder, PREFS_FILE_NAME);
|
|
||||||
offset = SaveBufferToFAT (filepath, datasize, silent);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if(method == METHOD_SMB)
|
|
||||||
{
|
|
||||||
sprintf (filepath, "%s/%s", GCSettings.SaveFolder, PREFS_FILE_NAME);
|
|
||||||
offset = SaveBufferToSMB (filepath, datasize, silent);
|
|
||||||
}
|
|
||||||
else if(method == METHOD_MC_SLOTA)
|
|
||||||
{
|
|
||||||
offset = SaveBufferToMC (savebuffer, CARD_SLOTA, (char *)PREFS_FILE_NAME, datasize, silent);
|
|
||||||
}
|
|
||||||
else if(method == METHOD_MC_SLOTB)
|
|
||||||
{
|
|
||||||
offset = SaveBufferToMC (savebuffer, CARD_SLOTB, (char *)PREFS_FILE_NAME, datasize, silent);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (offset > 0)
|
if (offset > 0)
|
||||||
{
|
{
|
||||||
@ -378,31 +359,15 @@ LoadPrefsFromMethod (int method)
|
|||||||
char filepath[1024];
|
char filepath[1024];
|
||||||
int offset = 0;
|
int offset = 0;
|
||||||
|
|
||||||
if(method == METHOD_SD || method == METHOD_USB)
|
if(!MakeFilePath(filepath, FILE_PREF, method))
|
||||||
{
|
return false;
|
||||||
if(ChangeFATInterface(method, NOTSILENT))
|
|
||||||
{
|
offset = LoadFile(filepath, method, SILENT);
|
||||||
sprintf (filepath, "%s/%s/%s", ROOTFATDIR, GCSettings.SaveFolder, PREFS_FILE_NAME);
|
|
||||||
offset = LoadSaveBufferFromFAT (filepath, SILENT);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if(method == METHOD_SMB)
|
|
||||||
{
|
|
||||||
sprintf (filepath, "%s/%s", GCSettings.SaveFolder, PREFS_FILE_NAME);
|
|
||||||
offset = LoadSaveBufferFromSMB (filepath, SILENT);
|
|
||||||
}
|
|
||||||
else if(method == METHOD_MC_SLOTA)
|
|
||||||
{
|
|
||||||
offset = LoadBufferFromMC (savebuffer, CARD_SLOTA, (char *)PREFS_FILE_NAME, SILENT);
|
|
||||||
}
|
|
||||||
else if(method == METHOD_MC_SLOTB)
|
|
||||||
{
|
|
||||||
offset = LoadBufferFromMC (savebuffer, CARD_SLOTB, (char *)PREFS_FILE_NAME, SILENT);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (offset > 0)
|
if (offset > 0)
|
||||||
|
{
|
||||||
retval = decodePrefsData (method);
|
retval = decodePrefsData (method);
|
||||||
|
}
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -82,8 +82,6 @@ ConnectShare (bool silent)
|
|||||||
return false;
|
return false;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
ShowAction ((char*) "Connecting...");
|
|
||||||
|
|
||||||
// check that all parameter have been set
|
// check that all parameter have been set
|
||||||
if(strlen(GCSettings.smbuser) == 0 ||
|
if(strlen(GCSettings.smbuser) == 0 ||
|
||||||
strlen(GCSettings.smbpwd) == 0 ||
|
strlen(GCSettings.smbpwd) == 0 ||
|
||||||
@ -204,7 +202,6 @@ ParseSMBdirectory ()
|
|||||||
filelist[filecount].displayname[MAXDISPLAY] = 0;
|
filelist[filecount].displayname[MAXDISPLAY] = 0;
|
||||||
|
|
||||||
strcpy (filelist[filecount].filename, smbdir.name);
|
strcpy (filelist[filecount].filename, smbdir.name);
|
||||||
filelist[filecount].offset = 0;
|
|
||||||
filecount++;
|
filecount++;
|
||||||
}
|
}
|
||||||
} while (SMB_FindNext (&smbdir, smbconn) == SMB_SUCCESS);
|
} while (SMB_FindNext (&smbdir, smbconn) == SMB_SUCCESS);
|
||||||
@ -227,25 +224,6 @@ SMBFILE OpenSMBFile(char * filepath)
|
|||||||
return SMB_OpenFile (SMBPath(filepath), SMB_OPEN_READING, SMB_OF_OPEN, smbconn);
|
return SMB_OpenFile (SMBPath(filepath), SMB_OPEN_READING, SMB_OF_OPEN, smbconn);
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Load SMB file
|
|
||||||
* rom - pointer to memory where ROM will be stored
|
|
||||||
* length - # bytes to read (0 for all)
|
|
||||||
***************************************************************************/
|
|
||||||
int
|
|
||||||
LoadSMBFile (char * rom, int length)
|
|
||||||
{
|
|
||||||
char filepath[MAXPATHLEN];
|
|
||||||
|
|
||||||
/* Check filename length */
|
|
||||||
if (!MakeROMPath(filepath, METHOD_SMB))
|
|
||||||
{
|
|
||||||
WaitPrompt((char*) "Maximum filepath length reached!");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
return LoadBufferFromSMB(rom, filepath, length, NOTSILENT);
|
|
||||||
}
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* LoadSMBSzFile
|
* LoadSMBSzFile
|
||||||
* Loads the selected file # from the specified 7z into rbuffer
|
* Loads the selected file # from the specified 7z into rbuffer
|
||||||
@ -273,10 +251,12 @@ LoadSMBSzFile(char * filepath, unsigned char * rbuffer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Write savebuffer to SMB file
|
* SaveSMBFile
|
||||||
|
* Write buffer to SMB file
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
int
|
int
|
||||||
SaveBufferToSMB (char *filepath, int datasize, bool silent)
|
SaveSMBFile (char * sbuffer, char *filepath, int datasize, bool silent)
|
||||||
{
|
{
|
||||||
if(!ConnectShare (NOTSILENT))
|
if(!ConnectShare (NOTSILENT))
|
||||||
return 0;
|
return 0;
|
||||||
@ -295,10 +275,10 @@ SaveBufferToSMB (char *filepath, int datasize, bool silent)
|
|||||||
{
|
{
|
||||||
if (dsize > 1024)
|
if (dsize > 1024)
|
||||||
wrote =
|
wrote =
|
||||||
SMB_WriteFile ((char *) savebuffer + boffset, 1024, boffset, smbfile);
|
SMB_WriteFile ((char *) sbuffer + boffset, 1024, boffset, smbfile);
|
||||||
else
|
else
|
||||||
wrote =
|
wrote =
|
||||||
SMB_WriteFile ((char *) savebuffer + boffset, dsize, boffset, smbfile);
|
SMB_WriteFile ((char *) sbuffer + boffset, dsize, boffset, smbfile);
|
||||||
|
|
||||||
boffset += wrote;
|
boffset += wrote;
|
||||||
dsize -= wrote;
|
dsize -= wrote;
|
||||||
@ -312,31 +292,25 @@ SaveBufferToSMB (char *filepath, int datasize, bool silent)
|
|||||||
WaitPrompt (msg);
|
WaitPrompt (msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
ClearSaveBuffer ();
|
|
||||||
return boffset;
|
return boffset;
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
|
* LoadSMBFile
|
||||||
* Load up a buffer from SMB file
|
* Load up a buffer from SMB file
|
||||||
***************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
// no buffer is specified - so use savebuffer
|
|
||||||
int
|
|
||||||
LoadSaveBufferFromSMB (char *filepath, bool silent)
|
|
||||||
{
|
|
||||||
return LoadBufferFromSMB((char *)savebuffer, filepath, 0, silent);
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
int
|
||||||
LoadBufferFromSMB (char * sbuffer, char *filepath, int length, bool silent)
|
LoadSMBFile (char * sbuffer, char *filepath, int length, bool silent)
|
||||||
{
|
{
|
||||||
if(!ConnectShare (NOTSILENT))
|
if(!ConnectShare (NOTSILENT))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
smbfile = OpenSMBFile(filepath);
|
|
||||||
int ret;
|
int ret;
|
||||||
int boffset = 0;
|
int boffset = 0;
|
||||||
|
|
||||||
|
smbfile = OpenSMBFile(filepath);
|
||||||
|
|
||||||
if (!smbfile)
|
if (!smbfile)
|
||||||
{
|
{
|
||||||
if(!silent)
|
if(!silent)
|
||||||
@ -348,13 +322,13 @@ LoadBufferFromSMB (char * sbuffer, char *filepath, int length, bool silent)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(length > 0) // do a partial read (eg: to check file header)
|
if(length > 0 && length <= 2048) // do a partial read (eg: to check file header)
|
||||||
{
|
{
|
||||||
boffset = SMB_ReadFile (sbuffer, length, 0, smbfile);
|
boffset = SMB_ReadFile (sbuffer, length, 0, smbfile);
|
||||||
}
|
}
|
||||||
else // load whole file
|
else // load whole file
|
||||||
{
|
{
|
||||||
ret = SMB_ReadFile (sbuffer, 1024, boffset, smbfile);
|
ret = SMB_ReadFile (sbuffer, 2048, boffset, smbfile);
|
||||||
|
|
||||||
if (IsZipFile (sbuffer))
|
if (IsZipFile (sbuffer))
|
||||||
{
|
{
|
||||||
@ -363,10 +337,12 @@ LoadBufferFromSMB (char * sbuffer, char *filepath, int length, bool silent)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Just load the file up
|
// Just load the file up
|
||||||
while ((ret = SMB_ReadFile (sbuffer + boffset, 1024, boffset, smbfile)) > 0)
|
while ((ret = SMB_ReadFile (sbuffer + boffset, 2048, boffset, smbfile)) > 0)
|
||||||
|
{
|
||||||
boffset += ret;
|
boffset += ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
SMB_CloseFile (smbfile);
|
SMB_CloseFile (smbfile);
|
||||||
|
|
||||||
return boffset;
|
return boffset;
|
||||||
|
@ -20,11 +20,9 @@ char * SMBPath(char * path);
|
|||||||
int UpdateSMBdirname();
|
int UpdateSMBdirname();
|
||||||
int ParseSMBdirectory ();
|
int ParseSMBdirectory ();
|
||||||
SMBFILE OpenSMBFile(char * filepath);
|
SMBFILE OpenSMBFile(char * filepath);
|
||||||
int LoadSMBFile (char * fbuffer, int length);
|
|
||||||
int LoadSMBSzFile(char * filepath, unsigned char * rbuffer);
|
int LoadSMBSzFile(char * filepath, unsigned char * rbuffer);
|
||||||
int LoadSaveBufferFromSMB (char *filepath, bool silent);
|
int LoadSMBFile (char * sbuffer, char *filepath, int length, bool silent);
|
||||||
int LoadBufferFromSMB (char * sbuffer, char *filepath, int length, bool silent);
|
int SaveSMBFile (char * sbuffer, char *filepath, int length, bool silent);
|
||||||
int SaveBufferToSMB (char *filepath, int datasize, bool silent);
|
|
||||||
|
|
||||||
extern SMBFILE smbfile;
|
extern SMBFILE smbfile;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user