Skip to content

Commit e954e32

Browse files
committed
Fixed bug 4726 - Fix for tvOS GetPrefPath
Caleb Cornett Unlike iOS and macOS, tvOS does not have any persistent local storage. In fact, the ApplicationSupport directory pointed to by the existing Cocoa GetPrefPath() throws an error whenever any attempt is made to access it. To get any local storage on an Apple TV, our only option is to use a temporary cache directory. This patch changes the tvOS PrefPath to this cache directory and also logs a critical warning that this if developers want their save data to persist across game sessions, they must use some form of iCloud storage.
1 parent 52e6232 commit e954e32

File tree

1 file changed

+21
-0
lines changed

1 file changed

+21
-0
lines changed

src/filesystem/cocoa/SDL_sysfilesystem.m

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -32,6 +32,7 @@
3232
#include "SDL_error.h"
3333
#include "SDL_stdinc.h"
3434
#include "SDL_filesystem.h"
35+
#include "SDL_log.h"
3536

3637
char *
3738
SDL_GetBasePath(void)
@@ -80,7 +81,27 @@
8081
}
8182

8283
char *retval = NULL;
84+
#if !TARGET_OS_TV
8385
NSArray *array = NSSearchPathForDirectoriesInDomains(NSApplicationSupportDirectory, NSUserDomainMask, YES);
86+
#else
87+
/* tvOS does not have persistent local storage!
88+
* The only place on-device where we can store data is
89+
* a cache directory that the OS can empty at any time.
90+
*
91+
* It's therefore very likely that save data will be erased
92+
* between sessions. If you want your app's save data to
93+
* actually stick around, you'll need to use iCloud storage.
94+
*/
95+
96+
static SDL_bool shown = SDL_FALSE;
97+
if (!shown)
98+
{
99+
shown = SDL_TRUE;
100+
SDL_LogCritical(SDL_LOG_CATEGORY_SYSTEM, "tvOS does not have persistent local storage! Use iCloud storage if you want your data to persist between sessions.\n");
101+
}
102+
103+
NSArray *array = NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES);
104+
#endif /* !TARGET_OS_TV */
84105

85106
if ([array count] > 0) { /* we only want the first item in the list. */
86107
NSString *str = [array objectAtIndex:0];

0 commit comments

Comments
 (0)