diff options
author | Kostas Nakos | 2008-08-09 18:09:24 +0000 |
---|---|---|
committer | Kostas Nakos | 2008-08-09 18:09:24 +0000 |
commit | 355f100793c8c8946b5fc418f00b2744cd4b2089 (patch) | |
tree | 61cd39600d9295b8d2f1aa71615d5138c676abc0 /backends/platform | |
parent | e02f94d3922b39bdc8d0333c2e9fd602aeb40ef6 (diff) | |
download | scummvm-rg350-355f100793c8c8946b5fc418f00b2744cd4b2089.tar.gz scummvm-rg350-355f100793c8c8946b5fc418f00b2744cd4b2089.tar.bz2 scummvm-rg350-355f100793c8c8946b5fc418f00b2744cd4b2089.zip |
fix MR on ce: allocate large buffer on the heap instead and of the stack, and improve the workaround
svn-id: r33714
Diffstat (limited to 'backends/platform')
-rw-r--r-- | backends/platform/wince/missing/missing.cpp | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/backends/platform/wince/missing/missing.cpp b/backends/platform/wince/missing/missing.cpp index c760b1f7df..f03f00bb9a 100644 --- a/backends/platform/wince/missing/missing.cpp +++ b/backends/platform/wince/missing/missing.cpp @@ -171,7 +171,7 @@ int _access(const char *path, int mode) { MultiByteToWideChar(CP_ACP, 0, path, -1, fname, sizeof(fname)/sizeof(TCHAR)); WIN32_FIND_DATA ffd; - HANDLE h=FindFirstFile(fname, &ffd); + HANDLE h = FindFirstFile(fname, &ffd); FindClose(h); if (h == INVALID_HANDLE_VALUE) @@ -179,9 +179,14 @@ int _access(const char *path, int mode) { if (ffd.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY) { // WORKAROUND: WinCE (or the emulator) sometimes returns bogus direcotry - // hits for files that don't exist. Checking for the same fname twice + // hits for files that don't exist. TRIPLE checking for the same fname // seems to weed out those false positives. - HANDLE h=FindFirstFile(fname, &ffd); + // Exhibited in kyra engine. + HANDLE h = FindFirstFile(fname, &ffd); + FindClose(h); + if (h == INVALID_HANDLE_VALUE) + return -1; //Can't find file + h = FindFirstFile(fname, &ffd); FindClose(h); if (h == INVALID_HANDLE_VALUE) return -1; //Can't find file |