2006-07-03 01:17:05 +05:30
|
|
|
/* vi: set sw=4 ts=4: */
|
2001-04-30 23:47:00 +05:30
|
|
|
/*
|
2001-05-07 23:18:28 +05:30
|
|
|
* xreadlink.c - safe implementation of readlink.
|
|
|
|
* Returns a NULL on failure...
|
2001-04-30 23:47:00 +05:30
|
|
|
*/
|
|
|
|
|
2007-01-04 23:29:59 +05:30
|
|
|
#include "libbb.h"
|
2001-04-30 23:47:00 +05:30
|
|
|
|
|
|
|
/*
|
|
|
|
* NOTE: This function returns a malloced char* that you will have to free
|
|
|
|
* yourself. You have been warned.
|
|
|
|
*/
|
|
|
|
|
2006-03-07 02:17:33 +05:30
|
|
|
char *xreadlink(const char *path)
|
2006-01-25 05:38:53 +05:30
|
|
|
{
|
2006-03-11 00:52:06 +05:30
|
|
|
enum { GROWBY = 80 }; /* how large we will grow strings by */
|
2001-04-30 23:47:00 +05:30
|
|
|
|
2004-03-15 13:59:22 +05:30
|
|
|
char *buf = NULL;
|
2001-04-30 23:47:00 +05:30
|
|
|
int bufsize = 0, readsize = 0;
|
|
|
|
|
|
|
|
do {
|
|
|
|
buf = xrealloc(buf, bufsize += GROWBY);
|
|
|
|
readsize = readlink(path, buf, bufsize); /* 1st try */
|
2001-05-07 23:18:28 +05:30
|
|
|
if (readsize == -1) {
|
2004-08-11 09:20:30 +05:30
|
|
|
bb_perror_msg("%s", path);
|
|
|
|
free(buf);
|
|
|
|
return NULL;
|
2001-05-07 23:18:28 +05:30
|
|
|
}
|
2004-03-15 13:59:22 +05:30
|
|
|
}
|
2001-04-30 23:47:00 +05:30
|
|
|
while (bufsize < readsize + 1);
|
|
|
|
|
|
|
|
buf[readsize] = '\0';
|
|
|
|
|
|
|
|
return buf;
|
2004-03-15 13:59:22 +05:30
|
|
|
}
|
2007-01-04 23:29:59 +05:30
|
|
|
|
|
|
|
char *xmalloc_realpath(const char *path)
|
|
|
|
{
|
2007-01-25 03:32:01 +05:30
|
|
|
#if defined(__GLIBC__) && !defined(__UCLIBC__)
|
2007-01-04 23:29:59 +05:30
|
|
|
/* glibc provides a non-standard extension */
|
|
|
|
return realpath(path, NULL);
|
|
|
|
#else
|
|
|
|
char buf[PATH_MAX+1];
|
|
|
|
|
|
|
|
/* on error returns NULL (xstrdup(NULL) ==NULL) */
|
|
|
|
return xstrdup(realpath(path, buf));
|
|
|
|
#endif
|
|
|
|
}
|