Add resolve_path() to utils
This commit is contained in:
parent
bcf9338ce7
commit
c9694ee63d
2 changed files with 49 additions and 0 deletions
|
@ -1,3 +1,7 @@
|
|||
#define _XOPEN_SOURCE 500
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
#include <unistd.h>
|
||||
#include <math.h>
|
||||
#include <stdint.h>
|
||||
#include <stdio.h>
|
||||
|
@ -118,3 +122,40 @@ uint32_t parse_color(const char *color) {
|
|||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
char* resolve_path(const char* path) {
|
||||
struct stat sb;
|
||||
ssize_t r;
|
||||
int i;
|
||||
char *current = NULL;
|
||||
char *resolved = NULL;
|
||||
|
||||
if(!(current = strdup(path))) {
|
||||
return NULL;
|
||||
}
|
||||
for (i = 0; i < 16; ++i) {
|
||||
if (lstat(current, &sb) == -1) {
|
||||
goto failed;
|
||||
}
|
||||
if((sb.st_mode & S_IFMT) != S_IFLNK) {
|
||||
return current;
|
||||
}
|
||||
if (!(resolved = malloc(sb.st_size + 1))) {
|
||||
goto failed;
|
||||
}
|
||||
r = readlink(current, resolved, sb.st_size);
|
||||
if (r == -1 || r > sb.st_size) {
|
||||
goto failed;
|
||||
}
|
||||
resolved[r] = '\0';
|
||||
free(current);
|
||||
current = strdup(resolved);
|
||||
free(resolved);
|
||||
resolved = NULL;
|
||||
}
|
||||
|
||||
failed:
|
||||
free(resolved);
|
||||
free(current);
|
||||
return NULL;
|
||||
}
|
|
@ -49,4 +49,12 @@ pid_t get_parent_pid(pid_t pid);
|
|||
*/
|
||||
uint32_t parse_color(const char *color);
|
||||
|
||||
/**
|
||||
* Given a path string, recurseively resolves any symlinks to their targets
|
||||
* (which may be a file, directory) and returns the result.
|
||||
* argument is returned. Caller must free the returned buffer.
|
||||
* If an error occures, if the path does not exist or if the path corresponds
|
||||
* to a dangling symlink, NULL is returned.
|
||||
*/
|
||||
char* resolve_path(const char* path);
|
||||
#endif
|
||||
|
|
Loading…
Add table
Reference in a new issue