mirror of
https://github.com/Ryujinx/SDL.git
synced 2024-12-22 20:05:30 +00:00
SDL_RWFromFile, stdio: reject if the file is not a regular file.
Fixes https://github.com/libsdl-org/SDL/issues/8935 (cherry picked from commit 230ae797a7406358b7fcf74701d39b5f342f9807)
This commit is contained in:
parent
aac7d1c2ae
commit
3bf60755cb
|
@ -36,6 +36,7 @@
|
||||||
|
|
||||||
#ifdef HAVE_STDIO_H
|
#ifdef HAVE_STDIO_H
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_LIMITS_H
|
#ifdef HAVE_LIMITS_H
|
||||||
|
@ -523,6 +524,24 @@ static int SDLCALL mem_close(SDL_RWops *context)
|
||||||
|
|
||||||
/* Functions to create SDL_RWops structures from various data sources */
|
/* Functions to create SDL_RWops structures from various data sources */
|
||||||
|
|
||||||
|
#if defined(HAVE_STDIO_H) && !(defined(__WIN32__) || defined(__GDK__))
|
||||||
|
static SDL_bool SDL_IsRegularFile(FILE *f)
|
||||||
|
{
|
||||||
|
#ifdef __WINRT__
|
||||||
|
struct __stat64 st;
|
||||||
|
if (_fstat64(_fileno(f), &st) < 0 || !S_ISREG(st.st_mode)) {
|
||||||
|
return SDL_FALSE;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
struct stat st;
|
||||||
|
if (fstat(fileno(f), &st) < 0 || !S_ISREG(st.st_mode)) {
|
||||||
|
return SDL_FALSE;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
return SDL_TRUE;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
SDL_RWops *SDL_RWFromFile(const char *file, const char *mode)
|
SDL_RWops *SDL_RWFromFile(const char *file, const char *mode)
|
||||||
{
|
{
|
||||||
SDL_RWops *rwops = NULL;
|
SDL_RWops *rwops = NULL;
|
||||||
|
@ -536,6 +555,11 @@ SDL_RWops *SDL_RWFromFile(const char *file, const char *mode)
|
||||||
if (*file == '/') {
|
if (*file == '/') {
|
||||||
FILE *fp = fopen(file, mode);
|
FILE *fp = fopen(file, mode);
|
||||||
if (fp) {
|
if (fp) {
|
||||||
|
if (!SDL_IsRegularFile(fp)) {
|
||||||
|
fclose(fp);
|
||||||
|
SDL_SetError("%s is not a regular file", file);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
return SDL_RWFromFP(fp, 1);
|
return SDL_RWFromFP(fp, 1);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -551,6 +575,11 @@ SDL_RWops *SDL_RWFromFile(const char *file, const char *mode)
|
||||||
fp = fopen(path, mode);
|
fp = fopen(path, mode);
|
||||||
SDL_stack_free(path);
|
SDL_stack_free(path);
|
||||||
if (fp) {
|
if (fp) {
|
||||||
|
if (!SDL_IsRegularFile(fp)) {
|
||||||
|
fclose(fp);
|
||||||
|
SDL_SetError("%s is not a regular file", path);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
return SDL_RWFromFP(fp, 1);
|
return SDL_RWFromFP(fp, 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -604,6 +633,10 @@ SDL_RWops *SDL_RWFromFile(const char *file, const char *mode)
|
||||||
#endif
|
#endif
|
||||||
if (!fp) {
|
if (!fp) {
|
||||||
SDL_SetError("Couldn't open %s", file);
|
SDL_SetError("Couldn't open %s", file);
|
||||||
|
} else if (!SDL_IsRegularFile(fp)) {
|
||||||
|
fclose(fp);
|
||||||
|
fp = NULL;
|
||||||
|
SDL_SetError("%s is not a regular file", file);
|
||||||
} else {
|
} else {
|
||||||
rwops = SDL_RWFromFP(fp, SDL_TRUE);
|
rwops = SDL_RWFromFP(fp, SDL_TRUE);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue