Darwin support by Patrick Stein.

This commit is contained in:
Ryan C. Gordon 2002-03-05 19:16:38 +00:00
parent 7484d7ccb1
commit cb2a15d302
1 changed files with 61 additions and 1 deletions

View File

@ -6,6 +6,12 @@
* This file written by Ryan C. Gordon. * This file written by Ryan C. Gordon.
*/ */
#if ((defined __APPLE__) && (defined __MACH__))
# if (!defined __DARWIN__)
# define __DARWIN__
# endif
#endif
#if (defined __STRICT_ANSI__) #if (defined __STRICT_ANSI__)
#define __PHYSFS_DOING_STRICT_ANSI__ #define __PHYSFS_DOING_STRICT_ANSI__
#endif #endif
@ -40,6 +46,11 @@
#include <time.h> #include <time.h>
#include <errno.h> #include <errno.h>
#include <mntent.h> #include <mntent.h>
#include <sys/mount.h>
#if (defined __DARWIN__)
#include <sys/ucred.h>
#endif
#define __PHYSICSFS_INTERNAL__ #define __PHYSICSFS_INTERNAL__
#include "physfs_internal.h" #include "physfs_internal.h"
@ -47,6 +58,53 @@
const char *__PHYSFS_platformDirSeparator = "/"; const char *__PHYSFS_platformDirSeparator = "/";
#if (defined __DARWIN__)
char **__PHYSFS_platformDetectAvailableCDs(void)
{
char **retval = (char **) malloc(sizeof (char *));
int cd_count = 1; /* We count the NULL entry. */
struct statfs* mntbufp = NULL;
int mounts;
int ii;
mounts = getmntinfo( &mntbufp, MNT_WAIT );
for ( ii=0; ii < mounts; ++ii ) {
int add_it = 0;
if ( strcmp( mntbufp[ii].f_fstypename, "iso9660") == 0 )
add_it = 1;
/* !!! other mount types? */
if (add_it)
{
char **tmp = realloc(retval, sizeof (char *) * cd_count + 1);
if (tmp)
{
retval = tmp;
retval[cd_count-1] = (char *)
malloc(strlen(mntbufp[ ii ].f_mntonname) + 1);
if (retval[cd_count-1])
{
strcpy(retval[cd_count-1], mntbufp[ ii ].f_mntonname);
cd_count++;
} /* if */
} /* if */
} /* if */
}
free( mntbufp );
retval[cd_count - 1] = NULL;
return(retval);
} /* __PHYSFS_platformDetectAvailableCDs */
#else /* non-Darwin implementation... */
char **__PHYSFS_platformDetectAvailableCDs(void) char **__PHYSFS_platformDetectAvailableCDs(void)
{ {
char **retval = (char **) malloc(sizeof (char *)); char **retval = (char **) malloc(sizeof (char *));
@ -85,7 +143,9 @@ char **__PHYSFS_platformDetectAvailableCDs(void)
retval[cd_count - 1] = NULL; retval[cd_count - 1] = NULL;
return(retval); return(retval);
} /* __PHYSFS_detectAvailableCDs */ } /* __PHYSFS_platformDetectAvailableCDs */
#endif
static char *copyEnvironmentVariable(const char *varname) static char *copyEnvironmentVariable(const char *varname)