X-Git-Url: http://git.annexia.org/?p=libguestfs.git;a=blobdiff_plain;f=daemon%2Fls.c;h=261bc96481f2e97b7ec93a31ac44590af3f12746;hp=1bea5f14e2b202df35213320415d34dd651c3f71;hb=e118c14b9552de311cbc1734e03a3226b484c1e8;hpb=843514eef9dc6d04d71e031ba9ddb16e2beb9a04 diff --git a/daemon/ls.c b/daemon/ls.c index 1bea5f1..261bc96 100644 --- a/daemon/ls.c +++ b/daemon/ls.c @@ -23,6 +23,7 @@ #include #include #include +#include #include #include "daemon.h" @@ -31,8 +32,46 @@ char ** do_ls (const char *path) { - reply_with_error ("ls command is not yet implemented"); - return NULL; + char **r = NULL; + int size = 0, alloc = 0; + DIR *dir; + struct dirent *d; + + NEED_ROOT (NULL); + ABS_PATH (path, NULL); + + CHROOT_IN; + dir = opendir (path); + CHROOT_OUT; + + if (!dir) { + reply_with_perror ("opendir: %s", path); + return NULL; + } + + while ((d = readdir (dir)) != NULL) { + if (strcmp (d->d_name, ".") == 0 || strcmp (d->d_name, "..") == 0) + continue; + + if (add_string (&r, &size, &alloc, d->d_name) == -1) { + closedir (dir); + return NULL; + } + } + + if (add_string (&r, &size, &alloc, NULL) == -1) { + closedir (dir); + return NULL; + } + + if (closedir (dir) == -1) { + reply_with_perror ("closedir: %s", path); + free_strings (r); + return NULL; + } + + sort_strings (r, size-1); + return r; } char * @@ -42,10 +81,8 @@ do_ll (const char *path) char *out, *err; char *spath; - if (path[0] != '/') { - reply_with_error ("ll: path must start with a / character"); - return NULL; - } + //NEED_ROOT + ABS_PATH (path, NULL); /* This exposes the /sysroot, because we can't chroot and run the ls * command (since 'ls' won't necessarily exist in the chroot). This