From 838ffbe68f0f812591ae53394c6d687356bc959c Mon Sep 17 00:00:00 2001 From: Misa Date: Thu, 4 Mar 2021 16:39:07 -0800 Subject: [PATCH] Add FILESYSTEM_isFile() This function will be used to differentiate files from directories. Or at least that was the hope. Symlink support was added in 2.3, but it doesn't seem like PHYSFS_stat() lets you follow the symlink to check if what it points to is itself a file or directory. And there doesn't seem to be any function to follow the symlink yourself... So for now, this function considers symlinks to directories to be files. --- desktop_version/src/FileSystemUtils.cpp | 22 ++++++++++++++++++++++ desktop_version/src/FileSystemUtils.h | 2 ++ 2 files changed, 24 insertions(+) diff --git a/desktop_version/src/FileSystemUtils.cpp b/desktop_version/src/FileSystemUtils.cpp index d0190b1c..1a340f02 100644 --- a/desktop_version/src/FileSystemUtils.cpp +++ b/desktop_version/src/FileSystemUtils.cpp @@ -164,6 +164,28 @@ char *FILESYSTEM_getUserLevelDirectory(void) return levelDir; } +bool FILESYSTEM_isFile(const char* filename) +{ + PHYSFS_Stat stat; + + bool success = PHYSFS_stat(filename, &stat); + + if (!success) + { + printf( + "Could not stat file: %s\n", + PHYSFS_getErrorByCode(PHYSFS_getLastErrorCode()) + ); + return false; + } + + /* We unfortunately cannot follow symlinks (PhysFS limitation). + * Let the caller deal with them. + */ + return stat.filetype == PHYSFS_FILETYPE_REGULAR + || stat.filetype == PHYSFS_FILETYPE_SYMLINK; +} + static bool FILESYSTEM_exists(const char *fname) { return PHYSFS_exists(fname); diff --git a/desktop_version/src/FileSystemUtils.h b/desktop_version/src/FileSystemUtils.h index ffb641a0..ddd163aa 100644 --- a/desktop_version/src/FileSystemUtils.h +++ b/desktop_version/src/FileSystemUtils.h @@ -12,6 +12,8 @@ void FILESYSTEM_deinit(void); char *FILESYSTEM_getUserSaveDirectory(void); char *FILESYSTEM_getUserLevelDirectory(void); +bool FILESYSTEM_isFile(const char* filename); + void FILESYSTEM_mount(const char *fname); void FILESYSTEM_loadZip(const char* filename); extern bool FILESYSTEM_assetsmounted;