diff options
author | Max Horn | 2008-08-03 17:05:01 +0000 |
---|---|---|
committer | Max Horn | 2008-08-03 17:05:01 +0000 |
commit | b54a1227d9bb53135e434ba9e00ce6cba592f6b1 (patch) | |
tree | 17a36024f26ce9062619e8ca9e95edf7b34c0f9b /common/system.cpp | |
parent | 6377b8bdd570d3c23dbdc9239b844492f7e09b9d (diff) | |
download | scummvm-rg350-b54a1227d9bb53135e434ba9e00ce6cba592f6b1.tar.gz scummvm-rg350-b54a1227d9bb53135e434ba9e00ce6cba592f6b1.tar.bz2 scummvm-rg350-b54a1227d9bb53135e434ba9e00ce6cba592f6b1.zip |
OSYSTEM: Pushed some SDL/Symbian specific code to the respective backends; made openConfigFileForReading/openConfigFileForWriting return 0 if they failed to open a file
svn-id: r33585
Diffstat (limited to 'common/system.cpp')
-rw-r--r-- | common/system.cpp | 77 |
1 files changed, 9 insertions, 68 deletions
diff --git a/common/system.cpp b/common/system.cpp index 1362177011..1b18339623 100644 --- a/common/system.cpp +++ b/common/system.cpp @@ -149,62 +149,14 @@ FIXME: The config file loading code below needs to be cleaned up. #if defined(UNIX) -#ifdef MACOSX -#define DEFAULT_CONFIG_FILE "Library/Preferences/ScummVM Preferences" -#else #define DEFAULT_CONFIG_FILE ".scummvmrc" -#endif #else #define DEFAULT_CONFIG_FILE "scummvm.ini" #endif static Common::String getDefaultConfigFileName() { char configFile[MAXPATHLEN]; -#if defined (WIN32) && !defined(_WIN32_WCE) && !defined(__SYMBIAN32__) - OSVERSIONINFO win32OsVersion; - ZeroMemory(&win32OsVersion, sizeof(OSVERSIONINFO)); - win32OsVersion.dwOSVersionInfoSize = sizeof(OSVERSIONINFO); - GetVersionEx(&win32OsVersion); - // Check for non-9X version of Windows. - if (win32OsVersion.dwPlatformId != VER_PLATFORM_WIN32_WINDOWS) { - // Use the Application Data directory of the user profile. - if (win32OsVersion.dwMajorVersion >= 5) { - if (!GetEnvironmentVariable("APPDATA", configFile, sizeof(configFile))) - error("Unable to access application data directory"); - } else { - if (!GetEnvironmentVariable("USERPROFILE", configFile, sizeof(configFile))) - error("Unable to access user profile directory"); - - strcat(configFile, "\\Application Data"); - CreateDirectory(configFile, NULL); - } - - strcat(configFile, "\\ScummVM"); - CreateDirectory(configFile, NULL); - strcat(configFile, "\\" DEFAULT_CONFIG_FILE); - - if (fopen(configFile, "r") == NULL) { - // Check windows directory - char oldConfigFile[MAXPATHLEN]; - GetWindowsDirectory(oldConfigFile, MAXPATHLEN); - strcat(oldConfigFile, "\\" DEFAULT_CONFIG_FILE); - if (fopen(oldConfigFile, "r")) { - printf("The default location of the config file (scummvm.ini) in ScummVM has changed,\n"); - printf("under Windows NT4/2000/XP/Vista. You may want to consider moving your config\n"); - printf("file from the old default location:\n"); - printf("%s\n", oldConfigFile); - printf("to the new default location:\n"); - printf("%s\n\n", configFile); - strcpy(configFile, oldConfigFile); - } - } - } else { - // Check windows directory - GetWindowsDirectory(configFile, MAXPATHLEN); - strcat(configFile, "\\" DEFAULT_CONFIG_FILE); - } - -#elif defined(PALMOS_MODE) +#if defined(PALMOS_MODE) strcpy(configFile,"/PALM/Programs/ScummVM/" DEFAULT_CONFIG_FILE); #elif defined(IPHONE) strcpy(configFile, OSystem_IPHONE::getConfigPath()); @@ -212,23 +164,6 @@ static Common::String getDefaultConfigFileName() { ((OSystem_PS2*)g_system)->makeConfigPath(configFile); #elif defined(__PSP__) strcpy(configFile, "ms0:/" DEFAULT_CONFIG_FILE); -#elif defined (__SYMBIAN32__) - strcpy(configFile, Symbian::GetExecutablePath()); - strcat(configFile, DEFAULT_CONFIG_FILE); -#elif defined(UNIX) && !defined(GP2X) && !defined(IPHONE) - // On UNIX type systems, by default we store the config file inside - // to the HOME directory of the user. - // - // GP2X is Linux based but Home dir can be read only so do not use - // it and put the config in the executable dir. - // - // On the iPhone, the home dir of the user when you launch the app - // from the Springboard, is /. Which we don't want. - const char *home = getenv("HOME"); - if (home != NULL && strlen(home) < MAXPATHLEN) - snprintf(configFile, MAXPATHLEN, "%s/%s", home, DEFAULT_CONFIG_FILE); - else - strcpy(configFile, DEFAULT_CONFIG_FILE); #else strcpy(configFile, DEFAULT_CONFIG_FILE); #endif @@ -239,7 +174,10 @@ static Common::String getDefaultConfigFileName() { Common::SeekableReadStream *OSystem::openConfigFileForReading() { Common::File *confFile = new Common::File(); assert(confFile); - confFile->open(getDefaultConfigFileName()); + if (!confFile->open(getDefaultConfigFileName())) { + delete confFile; + confFile = 0; + } return confFile; } @@ -249,7 +187,10 @@ Common::WriteStream *OSystem::openConfigFileForWriting() { #else Common::DumpFile *confFile = new Common::DumpFile(); assert(confFile); - confFile->open(getDefaultConfigFileName()); + if (!confFile->open(getDefaultConfigFileName())) { + delete confFile; + confFile = 0; + } return confFile; #endif } |