diff options
author | thilo <thilo@edf5b092-35ff-0310-97b2-ce42778d08ea> | 2007-12-14 21:53:57 +0000 |
---|---|---|
committer | thilo <thilo@edf5b092-35ff-0310-97b2-ce42778d08ea> | 2007-12-14 21:53:57 +0000 |
commit | dfa688010700e8d1dadbe2bd6919e73d499b27ca (patch) | |
tree | 7573f20264932c532df99ec75395a485cfdef794 /code | |
parent | 7fda2bcce8db155720ec8bfe16b7ea17667aaf89 (diff) | |
download | ioquake3-aero-dfa688010700e8d1dadbe2bd6919e73d499b27ca.tar.gz ioquake3-aero-dfa688010700e8d1dadbe2bd6919e73d499b27ca.zip |
Add gamedirectory in .app to searchpath on MacOSX
git-svn-id: svn://svn.icculus.org/quake3/trunk@1239 edf5b092-35ff-0310-97b2-ce42778d08ea
Diffstat (limited to 'code')
-rw-r--r-- | code/qcommon/files.c | 16 | ||||
-rw-r--r-- | code/qcommon/qcommon.h | 7 | ||||
-rw-r--r-- | code/sys/sys_main.c | 10 |
3 files changed, 32 insertions, 1 deletions
diff --git a/code/qcommon/files.c b/code/qcommon/files.c index cf989c4..5d19916 100644 --- a/code/qcommon/files.c +++ b/code/qcommon/files.c @@ -234,6 +234,12 @@ typedef struct searchpath_s { static char fs_gamedir[MAX_OSPATH]; // this will be a single file name with no separators static cvar_t *fs_debug; static cvar_t *fs_homepath; + +#ifdef MACOS_X +// Also search the .app bundle for .pk3 files +static cvar_t *fs_apppath; +#endif + static cvar_t *fs_basepath; static cvar_t *fs_basegame; static cvar_t *fs_gamedirvar; @@ -2392,7 +2398,7 @@ Sets fs_gamedir, adds the directory to the head of the path, then loads the zip headers ================ */ -static void FS_AddGameDirectory( const char *path, const char *dir ) { +void FS_AddGameDirectory( const char *path, const char *dir ) { searchpath_t *sp; int i; searchpath_t *search; @@ -2723,6 +2729,14 @@ static void FS_Startup( const char *gameName ) FS_AddGameDirectory( fs_basepath->string, gameName ); } // fs_homepath is somewhat particular to *nix systems, only add if relevant + + #ifdef MACOS_X + fs_apppath = Cvar_Get ("fs_apppath", Sys_DefaultAppPath(), CVAR_INIT ); + // Make MacOSX also include the base path included with the .app bundle + if (fs_apppath->string[0]) + FS_AddGameDirectory(fs_apppath->string, gameName); + #endif + // NOTE: same filtering below for mods and basegame if (fs_homepath->string[0] && Q_stricmp(fs_homepath->string,fs_basepath->string)) { FS_AddGameDirectory ( fs_homepath->string, gameName ); diff --git a/code/qcommon/qcommon.h b/code/qcommon/qcommon.h index 916e6e5..33d3d9e 100644 --- a/code/qcommon/qcommon.h +++ b/code/qcommon/qcommon.h @@ -545,6 +545,8 @@ qboolean FS_ConditionalRestart( int checksumFeed ); void FS_Restart( int checksumFeed ); // shutdown and restart the filesystem so changes to fs_gamedir can take effect +void FS_AddGameDirectory( const char *path, const char *dir ); + char **FS_ListFiles( const char *directory, const char *extension, int *numfiles ); // directory should not have either a leading or trailing / // if extension is "/", only subdirectories will be returned @@ -1027,6 +1029,11 @@ void Sys_Mkdir( const char *path ); char *Sys_Cwd( void ); void Sys_SetDefaultInstallPath(const char *path); char *Sys_DefaultInstallPath(void); + +#ifdef MACOS_X +char *Sys_DefaultAppPath(void); +#endif + void Sys_SetDefaultHomePath(const char *path); char *Sys_DefaultHomePath(void); const char *Sys_Dirname( char *path ); diff --git a/code/sys/sys_main.c b/code/sys/sys_main.c index 4c3f703..a1a57b4 100644 --- a/code/sys/sys_main.c +++ b/code/sys/sys_main.c @@ -95,6 +95,16 @@ char *Sys_DefaultInstallPath(void) /* ================= +Sys_DefaultAppPath +================= +*/ +char *Sys_DefaultAppPath(void) +{ + return Sys_BinaryPath(); +} + +/* +================= Sys_In_Restart_f Restart the input subsystem |