diff options
Diffstat (limited to 'source')
-rw-r--r-- | source/cheats.h | 12 | ||||
-rw-r--r-- | source/cheats2.c | 75 | ||||
-rw-r--r-- | source/display.h | 2 | ||||
-rw-r--r-- | source/memmap.c | 127 | ||||
-rw-r--r-- | source/port.h | 3 | ||||
-rw-r--r-- | source/spc7110.c | 2 |
6 files changed, 84 insertions, 137 deletions
diff --git a/source/cheats.h b/source/cheats.h index df8a9a6..94caf2b 100644 --- a/source/cheats.h +++ b/source/cheats.h @@ -42,21 +42,19 @@ typedef enum S9X_8_BITS, S9X_16_BITS, S9X_24_BITS, S9X_32_BITS } S9xCheatDataSize; -void S9xInitCheatData(); +void S9xInitCheatData(void); const char* S9xGameGenieToRaw(const char* code, uint32_t* address, uint8_t* byte); const char* S9xProActionReplayToRaw(const char* code, uint32_t* address, uint8_t* byte); const char* S9xGoldFingerToRaw(const char* code, uint32_t* address, bool* sram, uint8_t* num_bytes, uint8_t bytes[3]); -void S9xApplyCheats(); +void S9xApplyCheats(void); void S9xApplyCheat(uint32_t which1); -void S9xRemoveCheats(); +void S9xRemoveCheats(void); void S9xRemoveCheat(uint32_t which1); void S9xEnableCheat(uint32_t which1); void S9xDisableCheat(uint32_t which1); -void S9xDisableAllCheat(); +void S9xDisableAllCheat(void); void S9xAddCheat(bool enable, bool save_current_value, uint32_t address, uint8_t byte); -void S9xDeleteCheats(); +void S9xDeleteCheats(void); void S9xDeleteCheat(uint32_t which1); -bool S9xLoadCheatFile(const char* filename); -bool S9xSaveCheatFile(const char* filename); #endif diff --git a/source/cheats2.c b/source/cheats2.c index 067a929..11595e2 100644 --- a/source/cheats2.c +++ b/source/cheats2.c @@ -124,78 +124,3 @@ void S9xRemoveCheats(void) if (Cheat.c [i].enabled) S9xRemoveCheat(i); } - -bool S9xLoadCheatFile(const char* filename) -{ - uint8_t data [8 + MAX_SFCCHEAT_NAME]; - FILE* fs = fopen(filename, "rb"); - Cheat.num_cheats = 0; - - if (!fs) - return false; - - while (fread((void*) data, 1, 8 + MAX_SFCCHEAT_NAME, fs) == 8 + MAX_SFCCHEAT_NAME) - { - if (data[6] != 254 || data[7] != 252) - { - fclose(fs); - return false; - } - Cheat.c [Cheat.num_cheats].enabled = (data [0] & 4) == 0; - Cheat.c [Cheat.num_cheats].byte = data [1]; - Cheat.c [Cheat.num_cheats].address = data [2] | (data [3] << 8) | (data [4] << 16); - Cheat.c [Cheat.num_cheats].saved_byte = data [5]; - Cheat.c [Cheat.num_cheats].saved = (data [0] & 8) != 0; - memcpy(Cheat.c [Cheat.num_cheats].name, &data [8], MAX_SFCCHEAT_NAME - 1); - Cheat.c [Cheat.num_cheats++].name [MAX_SFCCHEAT_NAME - 1] = 0; - } - fclose(fs); - - return true; -} - -bool S9xSaveCheatFile(const char* filename) -{ - uint32_t i; - uint8_t data [8 + MAX_SFCCHEAT_NAME]; - FILE* fs; - - if (Cheat.num_cheats == 0) - { - (void) remove(filename); - return true; - } - - fs = fopen(filename, "wb"); - - if (!fs) - return false; - - for (i = 0; i < Cheat.num_cheats; i++) - { - memset(data, 0, 8 + MAX_SFCCHEAT_NAME); - data [6] = 254; - data [7] = 252; - if (!Cheat.c [i].enabled) - data [0] |= 4; - - if (Cheat.c [i].saved) - data [0] |= 8; - - data [1] = Cheat.c [i].byte; - data [2] = (uint8_t) Cheat.c [i].address; - data [3] = (uint8_t)(Cheat.c [i].address >> 8); - data [4] = (uint8_t)(Cheat.c [i].address >> 16); - data [5] = Cheat.c [i].saved_byte; - - memcpy(&data [8], Cheat.c [i].name, MAX_SFCCHEAT_NAME - 1); - if (fwrite(data, 8 + MAX_SFCCHEAT_NAME, 1, fs) != 1) - { - fclose(fs); - return false; - } - } - - fclose(fs); - return true; -} diff --git a/source/display.h b/source/display.h index 213955b..ee40183 100644 --- a/source/display.h +++ b/source/display.h @@ -12,6 +12,4 @@ void S9xInitDisplay(void); void S9xDeinitDisplay(void); void S9xToggleSoundChannel(int32_t channel); void S9xNextController(void); - -const char* S9xGetFilename(const char* extension); #endif diff --git a/source/memmap.c b/source/memmap.c index da04eb4..f382066 100644 --- a/source/memmap.c +++ b/source/memmap.c @@ -350,6 +350,66 @@ void S9xDeinitMemory(void) } #ifndef LOAD_FROM_MEMORY +static void _makepath(char* path, + const char* dir, const char* fname, const char* ext) +{ + if (dir && *dir) + { + strcpy(path, dir); + strcat(path, "/"); + } + else + *path = 0; + + if (fname) + strcat(path, fname); + + if (ext && *ext) + { + strcat(path, "."); + strcat(path, ext); + } +} + +static void _splitpath (const char* path, + char* dir, char* fname, char* ext) +{ + const char* slash = strrchr(path, '/'); + const char* dot = strrchr(path, '.'); + + if (!slash) + slash = strrchr((char*)path, '\\'); + + if (dot && slash && dot < slash) + dot = NULL; + + if (!slash) + { + *dir = 0; + strcpy(fname, path); + if (dot) + { + fname[dot - path] = 0; + strcpy(ext, dot + 1); + } + else + *ext = 0; + } + else + { + strcpy(dir, path); + dir[slash - path] = 0; + strcpy(fname, slash + 1); + if (dot) + { + fname[dot - slash - 1] = 0; + strcpy(ext, dot + 1); + } + else + *ext = 0; + } +} + /* Read variable size MSB int from a file */ static int32_t ReadInt(FILE* f, uint32_t nbytes) { @@ -364,20 +424,30 @@ static int32_t ReadInt(FILE* f, uint32_t nbytes) return v; } +static const char* S9xGetFilename(const char* in) +{ + static char filename [PATH_MAX + 1]; + char dir [_MAX_DIR + 1]; + char fname [_MAX_FNAME + 1]; + char ext [_MAX_EXT + 1]; + _splitpath(Memory.ROMFilename, dir, fname, ext); + _makepath(filename, dir, fname, in); + return filename; +} + #define IPS_EOF 0x00454F46l static void CheckForIPSPatch(const char* rom_filename, bool header, int32_t* rom_size) { char dir [_MAX_DIR + 1]; - char drive [_MAX_DRIVE + 1]; char name [_MAX_FNAME + 1]; char ext [_MAX_EXT + 1]; char fname [_MAX_PATH + 1]; FILE* patch_file = NULL; int32_t offset = header ? 512 : 0; - _splitpath(rom_filename, drive, dir, name, ext); - _makepath(fname, drive, dir, name, "ips"); + _splitpath(rom_filename, dir, name, ext); + _makepath(fname, dir, name, "ips"); if (!(patch_file = fopen(fname, "rb"))) if (!(patch_file = fopen(S9xGetFilename("ips"), "rb"))) @@ -462,19 +532,17 @@ err_eof: static uint32_t FileLoader(uint8_t* buffer, const char* filename, int32_t maxsize) { FILE* ROMFile; - int32_t TotalFileSize = 0; int32_t len = 0; char dir [_MAX_DIR + 1]; - char drive [_MAX_DRIVE + 1]; char name [_MAX_FNAME + 1]; char ext [_MAX_EXT + 1]; char fname [_MAX_PATH + 1]; uint32_t FileSize = 0; - _splitpath(filename, drive, dir, name, ext); - _makepath(fname, drive, dir, name, ext); + _splitpath(filename, dir, name, ext); + _makepath(fname, dir, name, ext); #ifdef _WIN32 /* memmove required: Overlapping addresses [Neb] */ @@ -484,20 +552,17 @@ static uint32_t FileLoader(uint8_t* buffer, const char* filename, int32_t maxsiz if ((ROMFile = fopen(fname, "rb")) == NULL) return 0; - strcpy(Memory.ROMFilename, fname); - Memory.HeaderCount = 0; uint8_t* ptr = buffer; - bool more = false; - do { int32_t calc_size; FileSize = fread(ptr, 1, maxsize + 0x200 - (ptr - Memory.ROM), ROMFile); fclose(ROMFile); calc_size = FileSize & ~0x1FFF; /* round to the lower 0x2000 */ - if ((FileSize - calc_size == 512 && !Settings.ForceNoHeader) || Settings.ForceHeader) + if ((FileSize - calc_size == 512 && !Settings.ForceNoHeader) + || Settings.ForceHeader) { /* memmove required: Overlapping addresses [Neb] */ /* DS2 DMA notes: Can be split into 512-byte DMA blocks [Neb] */ @@ -519,41 +584,10 @@ static uint32_t FileLoader(uint8_t* buffer, const char* filename, int32_t maxsiz FileSize -= 512; } - ptr += FileSize; - TotalFileSize += FileSize; - - - /* check for multi file roms */ - - if ((ptr - Memory.ROM) < (maxsize + 0x200) && (isdigit(ext [0]) && ext [1] == 0 && ext [0] < '9')) - { - more = true; - ext [0]++; -#ifdef _WIN32 - /* memmove required: Overlapping addresses [Neb] */ - memmove(&ext [1], &ext [0], 4); - ext [0] = '.'; -#endif - _makepath(fname, drive, dir, name, ext); - } - else if (ptr - Memory.ROM < maxsize + 0x200 && (((len = strlen(name)) == 7 || len == 8) && strncasecmp(name, "sf", 2) == 0 && isdigit(name [2]) && isdigit(name [3]) && isdigit(name [4]) && isdigit(name [5]) && isalpha(name [len - 1]))) - { - more = true; - name [len - 1]++; -#ifdef _WIN32 - /* memmove required: Overlapping addresses [Neb] */ - memmove(&ext [1], &ext [0], 4); - ext [0] = '.'; -#endif - _makepath(fname, drive, dir, name, ext); - } - else - more = false; - + ptr += FileSize; } - while (more && (ROMFile = fopen(fname, "rb")) != NULL); - return TotalFileSize; + return FileSize; } #endif @@ -589,8 +623,6 @@ bool LoadROM( again: #ifdef LOAD_FROM_MEMORY - strncpy(Memory.ROMFilename, game->path, sizeof(Memory.ROMFilename)); - Memory.HeaderCount = 0; TotalFileSize = game->size; src = game->data; @@ -927,7 +959,6 @@ again: Tales = true; InitROM(Tales); - S9xLoadCheatFile(S9xGetFilename("cht")); S9xInitCheatData(); S9xApplyCheats(); S9xReset(); diff --git a/source/port.h b/source/port.h index fcfe836..5defb76 100644 --- a/source/port.h +++ b/source/port.h @@ -43,9 +43,6 @@ #ifndef _MAX_PATH #define _MAX_PATH PATH_MAX #endif - -void _makepath(char* path, const char* drive, const char* dir, const char* fname, const char* ext); -void _splitpath(const char* path, char* drive, char* dir, char* fname, char* ext); #else /* _WIN32 */ #define strcasecmp stricmp #define strncasecmp strnicmp diff --git a/source/spc7110.c b/source/spc7110.c index 249bbc9..67fd068 100644 --- a/source/spc7110.c +++ b/source/spc7110.c @@ -5,8 +5,6 @@ #include "memmap.h" #include <time.h> -const char* S9xGetFilename(const char*); - SPC7110Regs s7r; /* SPC7110 registers, about 33KB */ S7RTC rtc_f9; /* FEOEZ (and Shounen Jump no SHou) RTC */ void S9xUpdateRTC(void); /* S-RTC function hacked to work with the RTC */ |