Set the error after freeing stuff, just in case one of those functions resets
the error string. --HG-- branch : SDL-1.2 extra : convert_revision : svn%3Ac70aab31-4412-0410-b14c-859654838e24/branches/SDL-1.2%402471
This commit is contained in:
parent
a37ebaa8e6
commit
3183821d09
1 changed files with 2 additions and 2 deletions
|
@ -91,10 +91,10 @@ static int SDLCALL win32_file_open(SDL_RWops *context, const char *filename, con
|
||||||
wchar_t *filenameW = SDL_stack_alloc(wchar_t, size);
|
wchar_t *filenameW = SDL_stack_alloc(wchar_t, size);
|
||||||
|
|
||||||
if ( MultiByteToWideChar(CP_UTF8, 0, filename, -1, filenameW, size) == 0 ) {
|
if ( MultiByteToWideChar(CP_UTF8, 0, filename, -1, filenameW, size) == 0 ) {
|
||||||
SDL_SetError("Unable to convert filename to Unicode");
|
|
||||||
SDL_stack_free(filenameW);
|
SDL_stack_free(filenameW);
|
||||||
SDL_free(context->hidden.win32io.buffer.data);
|
SDL_free(context->hidden.win32io.buffer.data);
|
||||||
context->hidden.win32io.buffer.data = NULL;
|
context->hidden.win32io.buffer.data = NULL;
|
||||||
|
SDL_SetError("Unable to convert filename to Unicode");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
h = CreateFile(filenameW, (w_right|r_right), (w_right)? 0 : FILE_SHARE_READ,
|
h = CreateFile(filenameW, (w_right|r_right), (w_right)? 0 : FILE_SHARE_READ,
|
||||||
|
@ -113,9 +113,9 @@ static int SDLCALL win32_file_open(SDL_RWops *context, const char *filename, con
|
||||||
#endif /* _WIN32_WCE */
|
#endif /* _WIN32_WCE */
|
||||||
|
|
||||||
if (h==INVALID_HANDLE_VALUE) {
|
if (h==INVALID_HANDLE_VALUE) {
|
||||||
SDL_SetError("Couldn't open %s",filename);
|
|
||||||
SDL_free(context->hidden.win32io.buffer.data);
|
SDL_free(context->hidden.win32io.buffer.data);
|
||||||
context->hidden.win32io.buffer.data = NULL;
|
context->hidden.win32io.buffer.data = NULL;
|
||||||
|
SDL_SetError("Couldn't open %s",filename);
|
||||||
return -2; /* failed (CreateFile) */
|
return -2; /* failed (CreateFile) */
|
||||||
}
|
}
|
||||||
context->hidden.win32io.h = h;
|
context->hidden.win32io.h = h;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue