summaryrefslogtreecommitdiffstats
path: root/daemon/lvm.c
diff options
context:
space:
mode:
authorRichard Jones <rjones@redhat.com>2009-04-07 10:25:46 +0100
committerRichard Jones <rjones@redhat.com>2009-04-07 10:25:46 +0100
commit6085137e65cb63aaf725207f2929a571d1149420 (patch)
tree95b1346a4be550a8c18c8123986fe549390618a0 /daemon/lvm.c
parent7ea56c8d0bca01a602df8e87e52d90c5b44e2cc2 (diff)
downloadlibguestfs-6085137e65cb63aaf725207f2929a571d1149420.tar.gz
libguestfs-6085137e65cb63aaf725207f2929a571d1149420.tar.xz
libguestfs-6085137e65cb63aaf725207f2929a571d1149420.zip
Implement simple lvs/vgs/pvs commands.
Diffstat (limited to 'daemon/lvm.c')
-rw-r--r--daemon/lvm.c115
1 files changed, 115 insertions, 0 deletions
diff --git a/daemon/lvm.c b/daemon/lvm.c
index 43f5cd1c..bc385474 100644
--- a/daemon/lvm.c
+++ b/daemon/lvm.c
@@ -31,6 +31,121 @@
* of writing it hasn't progressed very far.
*/
+static char **
+convert_lvm_output (char *out, char *prefix)
+{
+ char *p, *pend;
+ char **r = NULL;
+ int size = 0, alloc = 0;
+ char buf[256];
+ char *str;
+
+ p = out;
+ while (p) {
+ pend = strchr (p, '\n'); /* Get the next line of output. */
+ if (pend) {
+ *pend = '\0';
+ pend++;
+ }
+
+ while (*p && isspace (*p)) /* Skip any leading whitespace. */
+ p++;
+
+ if (!*p) { /* Empty line? Skip it. */
+ p = pend;
+ continue;
+ }
+
+ /* Prefix? */
+ if (prefix) {
+ snprintf (buf, sizeof buf, "%s%s", prefix, p);
+ str = buf;
+ } else
+ str = p;
+
+ if (add_string (&r, &size, &alloc, str) == -1) {
+ free (out);
+ return NULL;
+ }
+
+ p = pend;
+ }
+
+ free (out);
+
+ if (add_string (&r, &size, &alloc, NULL) == -1)
+ return NULL;
+
+ sort_strings (r, size-1);
+ return r;
+}
+
+char **
+do_pvs (void)
+{
+ char *out, *err;
+ int r;
+
+ r = command (&out, &err,
+ "/sbin/lvm", "pvs", "-o", "pv_name", "--noheadings", NULL);
+ if (r == -1) {
+ reply_with_error ("%s", err);
+ free (out);
+ free (err);
+ return NULL;
+ }
+
+ free (err);
+
+ return convert_lvm_output (out, NULL);
+}
+
+char **
+do_vgs (void)
+{
+ char *out, *err;
+ int r;
+
+ r = command (&out, &err,
+ "/sbin/lvm", "vgs", "-o", "vg_name", "--noheadings", NULL);
+ if (r == -1) {
+ reply_with_error ("%s", err);
+ free (out);
+ free (err);
+ return NULL;
+ }
+
+ free (err);
+
+ return convert_lvm_output (out, NULL);
+}
+
+char **
+do_lvs (void)
+{
+ char *out, *err;
+ int r;
+
+ r = command (&out, &err,
+ "/sbin/lvm", "lvs",
+ "-o", "vg_name,lv_name", "--noheadings",
+ "--separator", "/", NULL);
+ if (r == -1) {
+ reply_with_error ("%s", err);
+ free (out);
+ free (err);
+ return NULL;
+ }
+
+ free (err);
+
+ return convert_lvm_output (out, "/dev/");
+}
+
+/* These were so complex to implement that I ended up auto-generating
+ * the code. That code is in stubs.c, and it is generated as usual
+ * by generator.ml.
+ */
guestfs_lvm_int_pv_list *
do_pvs_full (void)
{