summaryrefslogtreecommitdiffstats
path: root/daemon
diff options
context:
space:
mode:
authorRichard W.M. Jones <rjones@redhat.com>2011-07-20 14:25:32 +0100
committerRichard W.M. Jones <rjones@redhat.com>2011-07-20 15:57:56 +0100
commit168fd4ad5d1e5da93e11388095d41aaa8f804ceb (patch)
treebaca1b79ff1412dfcc7b32502b4566927b3bdad0 /daemon
parent764e4e2aa289b645b64feff454d376a86486d219 (diff)
downloadlibguestfs-168fd4ad5d1e5da93e11388095d41aaa8f804ceb.tar.gz
libguestfs-168fd4ad5d1e5da93e11388095d41aaa8f804ceb.tar.xz
libguestfs-168fd4ad5d1e5da93e11388095d41aaa8f804ceb.zip
blkid: Detect when value not found and return empty string.
If the blkid command returns 2, that means the value was not found. Note that this changes the output of the vfs-type API when the filesystem has no type (eg when it is empty). Previously this would return an error. Now it returns empty string "". We did not document this either way. Making it return empty string is consistent with vfs-label and vfs-uuid. This change broke list-filesystems, since that code was assuming that vfs-type could only return a filesystem type or an error.
Diffstat (limited to 'daemon')
-rw-r--r--daemon/blkid.c19
1 files changed, 15 insertions, 4 deletions
diff --git a/daemon/blkid.c b/daemon/blkid.c
index 2885a8f3..f6310611 100644
--- a/daemon/blkid.c
+++ b/daemon/blkid.c
@@ -41,10 +41,13 @@ get_blkid_tag (const char *device, const char *tag)
unlink ("/etc/blkid/blkid.tab"); /* Red Hat, Fedora */
unlink ("/etc/blkid.tab"); /* Debian */
- r = command (&out, &err,
- "blkid", "-o", "value", "-s", tag, device, NULL);
- if (r == -1) {
- reply_with_error ("%s: %s", device, err);
+ r = commandr (&out, &err,
+ "blkid", "-o", "value", "-s", tag, device, NULL);
+ if (r != 0 && r != 2) {
+ if (r >= 0)
+ reply_with_error ("%s: %s (blkid returned %d)", device, err, r);
+ else
+ reply_with_error ("%s: %s", device, err);
free (out);
free (err);
return NULL;
@@ -52,6 +55,14 @@ get_blkid_tag (const char *device, const char *tag)
free (err);
+ if (r == 2) { /* means UUID etc not found */
+ free (out);
+ out = strdup ("");
+ if (out == NULL)
+ reply_with_perror ("strdup");
+ return out;
+ }
+
/* Trim trailing \n if present. */
size_t len = strlen (out);
if (len > 0 && out[len-1] == '\n')