Skip to content
Permalink
Browse files
PHYSFS_getRealDir() can't report a path for things that aren't real f…
…iles.
  • Loading branch information
icculus committed Aug 30, 2010
1 parent 5ff1a2a commit d9e98704f77dea99dcb326fa3f8430df780b8654
Showing with 12 additions and 1 deletion.
  1. +7 −1 src/physfs.c
  2. +5 −0 src/physfs.h
@@ -1828,15 +1828,21 @@ const char *PHYSFS_getRealDir(const char *_fname)
{
DirHandle *i;
__PHYSFS_platformGrabMutex(stateLock);
for (i = searchPath; ((i != NULL) && (retval == NULL)); i = i->next)
for (i = searchPath; i != NULL; i = i->next)
{
char *arcfname = fname;
if (partOfMountPoint(i, arcfname))
{
retval = i->dirName;
break;
} /* if */
else if (verifyPath(i, &arcfname, 0))
{
if (i->funcs->exists(i->opaque, arcfname))
{
retval = i->dirName;
break;
} /* if */
} /* if */
} /* for */
__PHYSFS_platformReleaseMutex(stateLock);
@@ -1020,6 +1020,11 @@ PHYSFS_DECL int PHYSFS_delete(const char *filename);
* be associated with the first archive mounted there, even though that
* directory isn't necessarily contained in a real archive.
*
* \warning This will return NULL if there is no real directory associated
* with (filename). Specifically, PHYSFS_mountIo(),
* PHYSFS_mountMemory(), and PHYSFS_mountHandle() will return NULL
* even if the filename is found in the search path. Plan accordingly.
*
* \param filename file to look for.
* \return READ ONLY string of element of search path containing the
* the file in question. NULL if not found.

0 comments on commit d9e9870

Please sign in to comment.