X-Git-Url: http://git.annexia.org/?p=libguestfs.git;a=blobdiff_plain;f=daemon%2Fdir.c;fp=daemon%2Fdir.c;h=f706466082ea9392714bdd7ff967ba5d8548cda3;hp=7892682f63476eec2eefd57b370732c842406b7f;hb=b4d2a01828e5de85e5eee3631f7fe3925a0312ca;hpb=99f68f259f92eee884c6c7396f61b9c16e2bf354 diff --git a/daemon/dir.c b/daemon/dir.c index 7892682..f706466 100644 --- a/daemon/dir.c +++ b/daemon/dir.c @@ -76,7 +76,7 @@ do_rm_rf (const char *path) snprintf (buf, len, "/sysroot%s", path); - r = command (NULL, &err, "rm", "-rf", buf); + r = command (NULL, &err, "rm", "-rf", buf, NULL); free (buf); /* rm -rf is never supposed to fail. I/O errors perhaps? */ @@ -165,3 +165,28 @@ do_mkdir_p (const char *path) return 0; } + +int +do_is_dir (const char *path) +{ + int r; + struct stat buf; + + NEED_ROOT (-1); + ABS_PATH (path, -1); + + CHROOT_IN; + r = lstat (path, &buf); + CHROOT_OUT; + + if (r == -1) { + if (errno != ENOENT && errno != ENOTDIR) { + reply_with_perror ("stat: %s", path); + return -1; + } + else + return 0; /* Not a directory. */ + } + + return S_ISDIR (buf.st_mode); +}