Make path separator OS-dependent (PR #954)

This commit is contained in:
Andrea 2021-05-19 21:10:22 +01:00 committed by GitHub
parent 1b9a769332
commit de7f35e6bd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
10 changed files with 30 additions and 24 deletions

View File

@ -143,6 +143,12 @@ enum AppMode_e
#define WM_USER_FULLSCREEN WM_USER+8 #define WM_USER_FULLSCREEN WM_USER+8
#define VK_SNAPSHOT_TEXT WM_USER+9 // PrintScreen+Ctrl #define VK_SNAPSHOT_TEXT WM_USER+9 // PrintScreen+Ctrl
#ifdef _MSC_VER
#define PATH_SEPARATOR '\\'
#else
#define PATH_SEPARATOR '/'
#endif
enum eIRQSRC {IS_6522=0, IS_SPEECH, IS_SSC, IS_MOUSE}; enum eIRQSRC {IS_6522=0, IS_SPEECH, IS_SSC, IS_MOUSE};
// //

View File

@ -288,8 +288,8 @@ bool SetCurrentImageDir(const std::string& pszImageDir)
{ {
g_sCurrentDir = pszImageDir; g_sCurrentDir = pszImageDir;
if (!g_sCurrentDir.empty() && *g_sCurrentDir.rbegin() != '\\') if (!g_sCurrentDir.empty() && *g_sCurrentDir.rbegin() != PATH_SEPARATOR)
g_sCurrentDir += '\\'; g_sCurrentDir += PATH_SEPARATOR;
if (SetCurrentDirectory(g_sCurrentDir.c_str())) if (SetCurrentDirectory(g_sCurrentDir.c_str()))
return true; return true;

View File

@ -3690,7 +3690,7 @@ Update_t CmdConfigSetDebugDir (int nArgs)
{ {
sPath = g_aArgs[1].sArg; sPath = g_aArgs[1].sArg;
} }
else if (g_aArgs[1].sArg[0] == '\\') // Absolute else if (g_aArgs[1].sArg[0] == PATH_SEPARATOR) // Absolute
{ {
if (g_sCurrentDir[1] == ':') if (g_sCurrentDir[1] == ':')
{ {
@ -5982,7 +5982,7 @@ Update_t CmdOutputRun (int nArgs)
sMiniFileName = pFileName.substr(0, MIN(pFileName.size(), CONSOLE_WIDTH)); sMiniFileName = pFileName.substr(0, MIN(pFileName.size(), CONSOLE_WIDTH));
// strcat( sMiniFileName, ".aws" ); // HACK: MAGIC STRING // strcat( sMiniFileName, ".aws" ); // HACK: MAGIC STRING
if (pFileName[0] == '\\' || pFileName[1] == ':') // NB. Any prefix quote has already been stripped if (pFileName[0] == PATH_SEPARATOR || pFileName[1] == ':') // NB. Any prefix quote has already been stripped
{ {
// Abs pathname // Abs pathname
sFileName = sMiniFileName; sFileName = sMiniFileName;

View File

@ -202,7 +202,7 @@ void Disk2InterfaceCard::SaveLastDiskImage(const int drive)
TCHAR szPathName[MAX_PATH]; TCHAR szPathName[MAX_PATH];
StringCbCopy(szPathName, MAX_PATH, DiskGetFullPathName(drive).c_str()); StringCbCopy(szPathName, MAX_PATH, DiskGetFullPathName(drive).c_str());
TCHAR* slash = _tcsrchr(szPathName, TEXT('\\')); TCHAR* slash = _tcsrchr(szPathName, TEXT(PATH_SEPARATOR));
if (slash != NULL) if (slash != NULL)
{ {
slash[1] = '\0'; slash[1] = '\0';
@ -599,7 +599,7 @@ void Disk2InterfaceCard::GetFilenameAndPathForSaveState(std::string& filename, s
filename = GetBaseName(i); filename = GetBaseName(i);
std::string pathname = DiskGetFullPathName(i); std::string pathname = DiskGetFullPathName(i);
int idx = pathname.find_last_of('\\'); int idx = pathname.find_last_of(PATH_SEPARATOR);
if (idx >= 0 && idx+1 < (int)pathname.length()) // path exists? if (idx >= 0 && idx+1 < (int)pathname.length()) // path exists?
{ {
path = pathname.substr(0, idx+1); path = pathname.substr(0, idx+1);

View File

@ -260,8 +260,8 @@ void GetImageTitle(LPCTSTR pPathname, std::string & pImageName, std::string & pF
LPCTSTR startpos = pPathname; LPCTSTR startpos = pPathname;
// imagetitle = <FILENAME.EXT> // imagetitle = <FILENAME.EXT>
if (_tcsrchr(startpos, TEXT('\\'))) if (_tcsrchr(startpos, TEXT(PATH_SEPARATOR)))
startpos = _tcsrchr(startpos, TEXT('\\'))+1; startpos = _tcsrchr(startpos, TEXT(PATH_SEPARATOR))+1;
_tcsncpy(imagetitle, startpos, MAX_DISK_FULL_NAME); _tcsncpy(imagetitle, startpos, MAX_DISK_FULL_NAME);
imagetitle[MAX_DISK_FULL_NAME] = 0; imagetitle[MAX_DISK_FULL_NAME] = 0;

View File

@ -1541,8 +1541,8 @@ void CImageHelperBase::GetCharLowerExt(TCHAR* pszExt, LPCTSTR pszImageFilename,
{ {
LPCTSTR pImageFileExt = pszImageFilename; LPCTSTR pImageFileExt = pszImageFilename;
if (_tcsrchr(pImageFileExt, TEXT('\\'))) if (_tcsrchr(pImageFileExt, TEXT(PATH_SEPARATOR)))
pImageFileExt = _tcsrchr(pImageFileExt, TEXT('\\'))+1; pImageFileExt = _tcsrchr(pImageFileExt, TEXT(PATH_SEPARATOR))+1;
if (_tcsrchr(pImageFileExt, TEXT('.'))) if (_tcsrchr(pImageFileExt, TEXT('.')))
pImageFileExt = _tcsrchr(pImageFileExt, TEXT('.')); pImageFileExt = _tcsrchr(pImageFileExt, TEXT('.'));

View File

@ -247,9 +247,9 @@ static void HD_SaveLastDiskImage(const int iDrive)
char szPathName[MAX_PATH]; char szPathName[MAX_PATH];
strcpy(szPathName, HD_GetFullPathName(iDrive).c_str()); strcpy(szPathName, HD_GetFullPathName(iDrive).c_str());
if (_tcsrchr(szPathName, TEXT('\\'))) if (_tcsrchr(szPathName, TEXT(PATH_SEPARATOR)))
{ {
char* pPathEnd = _tcsrchr(szPathName, TEXT('\\'))+1; char* pPathEnd = _tcsrchr(szPathName, TEXT(PATH_SEPARATOR))+1;
*pPathEnd = 0; *pPathEnd = 0;
RegSaveString(TEXT(REG_PREFS), TEXT(REGVALUE_PREF_HDV_START_DIR), 1, szPathName); RegSaveString(TEXT(REG_PREFS), TEXT(REGVALUE_PREF_HDV_START_DIR), 1, szPathName);
} }
@ -335,7 +335,7 @@ void HD_GetFilenameAndPathForSaveState(std::string& filename, std::string& path)
filename = HD_DiskGetBaseName(i); filename = HD_DiskGetBaseName(i);
std::string pathname = HD_GetFullPathName(i); std::string pathname = HD_GetFullPathName(i);
int idx = pathname.find_last_of('\\'); int idx = pathname.find_last_of(PATH_SEPARATOR);
if (idx >= 0 && idx+1 < (int)pathname.length()) // path exists? if (idx >= 0 && idx+1 < (int)pathname.length()) // path exists?
{ {
path = pathname.substr(0, idx+1); path = pathname.substr(0, idx+1);

View File

@ -86,8 +86,8 @@ static void Snapshot_SetPathname(const std::string& strPathname)
g_strSaveStateFilename = DEFAULT_SNAPSHOT_NAME; g_strSaveStateFilename = DEFAULT_SNAPSHOT_NAME;
g_strSaveStatePathname = g_sCurrentDir; g_strSaveStatePathname = g_sCurrentDir;
if (!g_strSaveStatePathname.empty() && *g_strSaveStatePathname.rbegin() != '\\') if (!g_strSaveStatePathname.empty() && *g_strSaveStatePathname.rbegin() != PATH_SEPARATOR)
g_strSaveStatePathname += "\\"; g_strSaveStatePathname += PATH_SEPARATOR;
g_strSaveStatePathname.append(DEFAULT_SNAPSHOT_NAME); g_strSaveStatePathname.append(DEFAULT_SNAPSHOT_NAME);
g_strSaveStatePath = g_sCurrentDir; g_strSaveStatePath = g_sCurrentDir;
@ -97,7 +97,7 @@ static void Snapshot_SetPathname(const std::string& strPathname)
std::string strFilename = strPathname; // Set default, as maybe there's no path std::string strFilename = strPathname; // Set default, as maybe there's no path
g_strSaveStatePath.clear(); g_strSaveStatePath.clear();
int nIdx = strPathname.find_last_of('\\'); int nIdx = strPathname.find_last_of(PATH_SEPARATOR);
if (nIdx >= 0 && nIdx+1 < (int)strPathname.length()) // path exists? if (nIdx >= 0 && nIdx+1 < (int)strPathname.length()) // path exists?
{ {
strFilename = &strPathname[nIdx+1]; strFilename = &strPathname[nIdx+1];
@ -113,12 +113,12 @@ void Snapshot_SetFilename(const std::string& filename, const std::string& path/*
if (path.empty()) if (path.empty())
return Snapshot_SetPathname(filename); return Snapshot_SetPathname(filename);
_ASSERT(filename.find('\\') == std::string::npos); // since we have a path, then filename mustn't contain a path too! _ASSERT(filename.find(PATH_SEPARATOR) == std::string::npos); // since we have a path, then filename mustn't contain a path too!
// Ensure path is suffixed with '\' before adding filename // Ensure path is suffixed with '\' before adding filename
std::string pathname = path; std::string pathname = path;
if (*pathname.rbegin() != '\\') if (*pathname.rbegin() != PATH_SEPARATOR)
pathname += "\\"; pathname += PATH_SEPARATOR;
Snapshot_SetPathname(pathname+filename); Snapshot_SetPathname(pathname+filename);
} }

View File

@ -321,7 +321,7 @@ static std::string GetFullPath(LPCSTR szFileName)
{ {
std::string strPathName; std::string strPathName;
if (szFileName[0] == '\\' || szFileName[1] == ':') if (szFileName[0] == PATH_SEPARATOR || szFileName[1] == ':')
{ {
// Abs pathname // Abs pathname
strPathName = szFileName; strPathName = szFileName;
@ -344,7 +344,7 @@ static void SetCurrentDir(std::string pathname)
// . if -[sN]d1 and -[sN]d2 are specified, then g_sCurrentDir will be set to the d2 image's path // . if -[sN]d1 and -[sN]d2 are specified, then g_sCurrentDir will be set to the d2 image's path
// This is purely dependent on the current order of InsertFloppyDisks() & InsertHardDisks() - ie. very brittle! // This is purely dependent on the current order of InsertFloppyDisks() & InsertHardDisks() - ie. very brittle!
// . better to use -current-dir to be explicit // . better to use -current-dir to be explicit
std::size_t found = pathname.find_last_of("\\"); std::size_t found = pathname.find_last_of(PATH_SEPARATOR);
std::string path = pathname.substr(0, found); std::string path = pathname.substr(0, found);
SetCurrentImageDir(path); SetCurrentImageDir(path);
} }

View File

@ -340,7 +340,7 @@ static void GetProgramDirectory(void)
int loop = g_sProgramDir.size(); int loop = g_sProgramDir.size();
while (loop--) while (loop--)
{ {
if ((g_sProgramDir[loop] == TEXT('\\')) || (g_sProgramDir[loop] == TEXT(':'))) if ((g_sProgramDir[loop] == TEXT(PATH_SEPARATOR)) || (g_sProgramDir[loop] == TEXT(':')))
{ {
g_sProgramDir.resize(loop + 1); // this reduces the size g_sProgramDir.resize(loop + 1); // this reduces the size
break; break;
@ -619,7 +619,7 @@ int APIENTRY WinMain(HINSTANCE passinstance, HINSTANCE, LPSTR lpCmdLine, int)
char startDir[_MAX_PATH]; char startDir[_MAX_PATH];
GetCurrentDirectory(sizeof(startDir), startDir); GetCurrentDirectory(sizeof(startDir), startDir);
g_sStartDir = startDir; g_sStartDir = startDir;
if (*(g_sStartDir.end()-1) != '\\') g_sStartDir += '\\'; if (*(g_sStartDir.end()-1) != PATH_SEPARATOR) g_sStartDir += PATH_SEPARATOR;
if (!ProcessCmdLine(lpCmdLine)) if (!ProcessCmdLine(lpCmdLine))
return 0; return 0;
@ -948,7 +948,7 @@ static void RepeatInitialization(void)
if (g_cmdLine.szSnapshotName) if (g_cmdLine.szSnapshotName)
{ {
std::string strPathname(g_cmdLine.szSnapshotName); std::string strPathname(g_cmdLine.szSnapshotName);
int nIdx = strPathname.find_last_of('\\'); int nIdx = strPathname.find_last_of(PATH_SEPARATOR);
if (nIdx >= 0 && nIdx+1 < (int)strPathname.length()) // path exists? if (nIdx >= 0 && nIdx+1 < (int)strPathname.length()) // path exists?
{ {
const std::string strPath = strPathname.substr(0, nIdx+1); const std::string strPath = strPathname.substr(0, nIdx+1);