1 /* libguestfs generated file
2 * WARNING: THIS FILE IS GENERATED BY 'src/generator.ml'.
3 * ANY CHANGES YOU MAKE TO THIS FILE WILL BE LOST.
5 * Copyright (C) 2009 Red Hat Inc.
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License along
18 * with this program; if not, write to the Free Software Foundation, Inc.,
19 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
22 #define _GNU_SOURCE // for strchrnul
29 #include <rpc/types.h>
33 #include "../src/guestfs_protocol.h"
36 static void mount_stub (XDR *xdr_in)
39 struct guestfs_mount_args args;
41 const char *mountpoint;
43 memset (&args, 0, sizeof args);
45 if (!xdr_guestfs_mount_args (xdr_in, &args)) {
46 reply_with_error ("%s: daemon failed to decode procedure arguments", "mount");
50 mountpoint = args.mountpoint;
52 r = do_mount (device, mountpoint);
54 /* do_mount has already called reply_with_error, so just return */
60 static void sync_stub (XDR *xdr_in)
66 /* do_sync has already called reply_with_error, so just return */
72 static void touch_stub (XDR *xdr_in)
75 struct guestfs_touch_args args;
78 memset (&args, 0, sizeof args);
80 if (!xdr_guestfs_touch_args (xdr_in, &args)) {
81 reply_with_error ("%s: daemon failed to decode procedure arguments", "touch");
88 /* do_touch has already called reply_with_error, so just return */
94 static void cat_stub (XDR *xdr_in)
97 struct guestfs_cat_args args;
100 memset (&args, 0, sizeof args);
102 if (!xdr_guestfs_cat_args (xdr_in, &args)) {
103 reply_with_error ("%s: daemon failed to decode procedure arguments", "cat");
110 /* do_cat has already called reply_with_error, so just return */
113 struct guestfs_cat_ret ret;
115 reply ((xdrproc_t) &xdr_guestfs_cat_ret, (char *) &ret);
119 static void ll_stub (XDR *xdr_in)
122 struct guestfs_ll_args args;
123 const char *directory;
125 memset (&args, 0, sizeof args);
127 if (!xdr_guestfs_ll_args (xdr_in, &args)) {
128 reply_with_error ("%s: daemon failed to decode procedure arguments", "ll");
131 directory = args.directory;
133 r = do_ll (directory);
135 /* do_ll has already called reply_with_error, so just return */
138 struct guestfs_ll_ret ret;
140 reply ((xdrproc_t) &xdr_guestfs_ll_ret, (char *) &ret);
144 static void ls_stub (XDR *xdr_in)
147 struct guestfs_ls_args args;
148 const char *directory;
150 memset (&args, 0, sizeof args);
152 if (!xdr_guestfs_ls_args (xdr_in, &args)) {
153 reply_with_error ("%s: daemon failed to decode procedure arguments", "ls");
156 directory = args.directory;
158 r = do_ls (directory);
160 /* do_ls has already called reply_with_error, so just return */
163 struct guestfs_ls_ret ret;
164 ret.listing.listing_len = count_strings (r);
165 ret.listing.listing_val = r;
166 reply ((xdrproc_t) &xdr_guestfs_ls_ret, (char *) &ret);
170 static void list_devices_stub (XDR *xdr_in)
174 r = do_list_devices ();
176 /* do_list_devices has already called reply_with_error, so just return */
179 struct guestfs_list_devices_ret ret;
180 ret.devices.devices_len = count_strings (r);
181 ret.devices.devices_val = r;
182 reply ((xdrproc_t) &xdr_guestfs_list_devices_ret, (char *) &ret);
186 static void list_partitions_stub (XDR *xdr_in)
190 r = do_list_partitions ();
192 /* do_list_partitions has already called reply_with_error, so just return */
195 struct guestfs_list_partitions_ret ret;
196 ret.partitions.partitions_len = count_strings (r);
197 ret.partitions.partitions_val = r;
198 reply ((xdrproc_t) &xdr_guestfs_list_partitions_ret, (char *) &ret);
202 static void pvs_stub (XDR *xdr_in)
208 /* do_pvs has already called reply_with_error, so just return */
211 struct guestfs_pvs_ret ret;
212 ret.physvols.physvols_len = count_strings (r);
213 ret.physvols.physvols_val = r;
214 reply ((xdrproc_t) &xdr_guestfs_pvs_ret, (char *) &ret);
218 static void vgs_stub (XDR *xdr_in)
224 /* do_vgs has already called reply_with_error, so just return */
227 struct guestfs_vgs_ret ret;
228 ret.volgroups.volgroups_len = count_strings (r);
229 ret.volgroups.volgroups_val = r;
230 reply ((xdrproc_t) &xdr_guestfs_vgs_ret, (char *) &ret);
234 static void lvs_stub (XDR *xdr_in)
240 /* do_lvs has already called reply_with_error, so just return */
243 struct guestfs_lvs_ret ret;
244 ret.logvols.logvols_len = count_strings (r);
245 ret.logvols.logvols_val = r;
246 reply ((xdrproc_t) &xdr_guestfs_lvs_ret, (char *) &ret);
250 static void pvs_full_stub (XDR *xdr_in)
252 guestfs_lvm_int_pv_list *r;
256 /* do_pvs_full has already called reply_with_error, so just return */
259 struct guestfs_pvs_full_ret ret;
261 reply ((xdrproc_t) xdr_guestfs_pvs_full_ret, (char *) &ret);
262 xdr_free ((xdrproc_t) xdr_guestfs_pvs_full_ret, (char *) &ret);
265 static void vgs_full_stub (XDR *xdr_in)
267 guestfs_lvm_int_vg_list *r;
271 /* do_vgs_full has already called reply_with_error, so just return */
274 struct guestfs_vgs_full_ret ret;
276 reply ((xdrproc_t) xdr_guestfs_vgs_full_ret, (char *) &ret);
277 xdr_free ((xdrproc_t) xdr_guestfs_vgs_full_ret, (char *) &ret);
280 static void lvs_full_stub (XDR *xdr_in)
282 guestfs_lvm_int_lv_list *r;
286 /* do_lvs_full has already called reply_with_error, so just return */
289 struct guestfs_lvs_full_ret ret;
291 reply ((xdrproc_t) xdr_guestfs_lvs_full_ret, (char *) &ret);
292 xdr_free ((xdrproc_t) xdr_guestfs_lvs_full_ret, (char *) &ret);
295 static void read_lines_stub (XDR *xdr_in)
298 struct guestfs_read_lines_args args;
301 memset (&args, 0, sizeof args);
303 if (!xdr_guestfs_read_lines_args (xdr_in, &args)) {
304 reply_with_error ("%s: daemon failed to decode procedure arguments", "read_lines");
309 r = do_read_lines (path);
311 /* do_read_lines has already called reply_with_error, so just return */
314 struct guestfs_read_lines_ret ret;
315 ret.lines.lines_len = count_strings (r);
316 ret.lines.lines_val = r;
317 reply ((xdrproc_t) &xdr_guestfs_read_lines_ret, (char *) &ret);
321 static void aug_init_stub (XDR *xdr_in)
324 struct guestfs_aug_init_args args;
328 memset (&args, 0, sizeof args);
330 if (!xdr_guestfs_aug_init_args (xdr_in, &args)) {
331 reply_with_error ("%s: daemon failed to decode procedure arguments", "aug_init");
337 r = do_aug_init (root, flags);
339 /* do_aug_init has already called reply_with_error, so just return */
345 static void aug_close_stub (XDR *xdr_in)
351 /* do_aug_close has already called reply_with_error, so just return */
357 static void aug_defvar_stub (XDR *xdr_in)
360 struct guestfs_aug_defvar_args args;
364 memset (&args, 0, sizeof args);
366 if (!xdr_guestfs_aug_defvar_args (xdr_in, &args)) {
367 reply_with_error ("%s: daemon failed to decode procedure arguments", "aug_defvar");
371 expr = args.expr ? *args.expr : NULL;
373 r = do_aug_defvar (name, expr);
375 /* do_aug_defvar has already called reply_with_error, so just return */
378 struct guestfs_aug_defvar_ret ret;
380 reply ((xdrproc_t) &xdr_guestfs_aug_defvar_ret, (char *) &ret);
383 static void aug_defnode_stub (XDR *xdr_in)
385 guestfs_aug_defnode_ret *r;
386 struct guestfs_aug_defnode_args args;
391 memset (&args, 0, sizeof args);
393 if (!xdr_guestfs_aug_defnode_args (xdr_in, &args)) {
394 reply_with_error ("%s: daemon failed to decode procedure arguments", "aug_defnode");
401 r = do_aug_defnode (name, expr, val);
403 /* do_aug_defnode has already called reply_with_error, so just return */
406 reply ((xdrproc_t) xdr_guestfs_aug_defnode_ret, (char *) r);
407 xdr_free ((xdrproc_t) xdr_guestfs_aug_defnode_ret, (char *) r);
410 static void aug_get_stub (XDR *xdr_in)
413 struct guestfs_aug_get_args args;
416 memset (&args, 0, sizeof args);
418 if (!xdr_guestfs_aug_get_args (xdr_in, &args)) {
419 reply_with_error ("%s: daemon failed to decode procedure arguments", "aug_get");
424 r = do_aug_get (path);
426 /* do_aug_get has already called reply_with_error, so just return */
429 struct guestfs_aug_get_ret ret;
431 reply ((xdrproc_t) &xdr_guestfs_aug_get_ret, (char *) &ret);
435 static void aug_set_stub (XDR *xdr_in)
438 struct guestfs_aug_set_args args;
442 memset (&args, 0, sizeof args);
444 if (!xdr_guestfs_aug_set_args (xdr_in, &args)) {
445 reply_with_error ("%s: daemon failed to decode procedure arguments", "aug_set");
451 r = do_aug_set (path, val);
453 /* do_aug_set has already called reply_with_error, so just return */
459 static void aug_insert_stub (XDR *xdr_in)
462 struct guestfs_aug_insert_args args;
467 memset (&args, 0, sizeof args);
469 if (!xdr_guestfs_aug_insert_args (xdr_in, &args)) {
470 reply_with_error ("%s: daemon failed to decode procedure arguments", "aug_insert");
475 before = args.before;
477 r = do_aug_insert (path, label, before);
479 /* do_aug_insert has already called reply_with_error, so just return */
485 static void aug_rm_stub (XDR *xdr_in)
488 struct guestfs_aug_rm_args args;
491 memset (&args, 0, sizeof args);
493 if (!xdr_guestfs_aug_rm_args (xdr_in, &args)) {
494 reply_with_error ("%s: daemon failed to decode procedure arguments", "aug_rm");
499 r = do_aug_rm (path);
501 /* do_aug_rm has already called reply_with_error, so just return */
504 struct guestfs_aug_rm_ret ret;
506 reply ((xdrproc_t) &xdr_guestfs_aug_rm_ret, (char *) &ret);
509 static void aug_mv_stub (XDR *xdr_in)
512 struct guestfs_aug_mv_args args;
516 memset (&args, 0, sizeof args);
518 if (!xdr_guestfs_aug_mv_args (xdr_in, &args)) {
519 reply_with_error ("%s: daemon failed to decode procedure arguments", "aug_mv");
525 r = do_aug_mv (src, dest);
527 /* do_aug_mv has already called reply_with_error, so just return */
533 static void aug_match_stub (XDR *xdr_in)
536 struct guestfs_aug_match_args args;
539 memset (&args, 0, sizeof args);
541 if (!xdr_guestfs_aug_match_args (xdr_in, &args)) {
542 reply_with_error ("%s: daemon failed to decode procedure arguments", "aug_match");
547 r = do_aug_match (path);
549 /* do_aug_match has already called reply_with_error, so just return */
552 struct guestfs_aug_match_ret ret;
553 ret.matches.matches_len = count_strings (r);
554 ret.matches.matches_val = r;
555 reply ((xdrproc_t) &xdr_guestfs_aug_match_ret, (char *) &ret);
559 static void aug_save_stub (XDR *xdr_in)
565 /* do_aug_save has already called reply_with_error, so just return */
571 static void aug_load_stub (XDR *xdr_in)
577 /* do_aug_load has already called reply_with_error, so just return */
583 void dispatch_incoming_message (XDR *xdr_in)
586 case GUESTFS_PROC_MOUNT:
589 case GUESTFS_PROC_SYNC:
592 case GUESTFS_PROC_TOUCH:
595 case GUESTFS_PROC_CAT:
598 case GUESTFS_PROC_LL:
601 case GUESTFS_PROC_LS:
604 case GUESTFS_PROC_LIST_DEVICES:
605 list_devices_stub (xdr_in);
607 case GUESTFS_PROC_LIST_PARTITIONS:
608 list_partitions_stub (xdr_in);
610 case GUESTFS_PROC_PVS:
613 case GUESTFS_PROC_VGS:
616 case GUESTFS_PROC_LVS:
619 case GUESTFS_PROC_PVS_FULL:
620 pvs_full_stub (xdr_in);
622 case GUESTFS_PROC_VGS_FULL:
623 vgs_full_stub (xdr_in);
625 case GUESTFS_PROC_LVS_FULL:
626 lvs_full_stub (xdr_in);
628 case GUESTFS_PROC_READ_LINES:
629 read_lines_stub (xdr_in);
631 case GUESTFS_PROC_AUG_INIT:
632 aug_init_stub (xdr_in);
634 case GUESTFS_PROC_AUG_CLOSE:
635 aug_close_stub (xdr_in);
637 case GUESTFS_PROC_AUG_DEFVAR:
638 aug_defvar_stub (xdr_in);
640 case GUESTFS_PROC_AUG_DEFNODE:
641 aug_defnode_stub (xdr_in);
643 case GUESTFS_PROC_AUG_GET:
644 aug_get_stub (xdr_in);
646 case GUESTFS_PROC_AUG_SET:
647 aug_set_stub (xdr_in);
649 case GUESTFS_PROC_AUG_INSERT:
650 aug_insert_stub (xdr_in);
652 case GUESTFS_PROC_AUG_RM:
653 aug_rm_stub (xdr_in);
655 case GUESTFS_PROC_AUG_MV:
656 aug_mv_stub (xdr_in);
658 case GUESTFS_PROC_AUG_MATCH:
659 aug_match_stub (xdr_in);
661 case GUESTFS_PROC_AUG_SAVE:
662 aug_save_stub (xdr_in);
664 case GUESTFS_PROC_AUG_LOAD:
665 aug_load_stub (xdr_in);
668 reply_with_error ("dispatch_incoming_message: unknown procedure number %d", proc_nr);
672 static const char *lvm_pv_cols = "pv_name,pv_uuid,pv_fmt,pv_size,dev_size,pv_free,pv_used,pv_attr,pv_pe_count,pv_pe_alloc_count,pv_tags,pe_start,pv_mda_count,pv_mda_free";
674 static int lvm_tokenize_pv (char *str, struct guestfs_lvm_int_pv *r)
676 char *tok, *p, *next;
680 fprintf (stderr, "%s: failed: passed a NULL string\n", __func__);
683 if (!*str || isspace (*str)) {
684 fprintf (stderr, "%s: failed: passed a empty string or one beginning with whitespace\n", __func__);
689 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "pv_name");
692 p = strchrnul (tok, ',');
693 if (*p) next = p+1; else next = NULL;
695 r->pv_name = strdup (tok);
696 if (r->pv_name == NULL) {
702 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "pv_uuid");
705 p = strchrnul (tok, ',');
706 if (*p) next = p+1; else next = NULL;
708 for (i = j = 0; i < 32; ++j) {
709 if (tok[j] == '\0') {
710 fprintf (stderr, "%s: failed to parse UUID from '%s'\n", __func__, tok);
712 } else if (tok[j] != '-')
713 r->pv_uuid[i++] = tok[j];
717 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "pv_fmt");
720 p = strchrnul (tok, ',');
721 if (*p) next = p+1; else next = NULL;
723 r->pv_fmt = strdup (tok);
724 if (r->pv_fmt == NULL) {
730 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "pv_size");
733 p = strchrnul (tok, ',');
734 if (*p) next = p+1; else next = NULL;
736 if (sscanf (tok, "%"SCNu64, &r->pv_size) != 1) {
737 fprintf (stderr, "%s: failed to parse size '%s' from token %s\n", __func__, tok, "pv_size");
742 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "dev_size");
745 p = strchrnul (tok, ',');
746 if (*p) next = p+1; else next = NULL;
748 if (sscanf (tok, "%"SCNu64, &r->dev_size) != 1) {
749 fprintf (stderr, "%s: failed to parse size '%s' from token %s\n", __func__, tok, "dev_size");
754 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "pv_free");
757 p = strchrnul (tok, ',');
758 if (*p) next = p+1; else next = NULL;
760 if (sscanf (tok, "%"SCNu64, &r->pv_free) != 1) {
761 fprintf (stderr, "%s: failed to parse size '%s' from token %s\n", __func__, tok, "pv_free");
766 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "pv_used");
769 p = strchrnul (tok, ',');
770 if (*p) next = p+1; else next = NULL;
772 if (sscanf (tok, "%"SCNu64, &r->pv_used) != 1) {
773 fprintf (stderr, "%s: failed to parse size '%s' from token %s\n", __func__, tok, "pv_used");
778 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "pv_attr");
781 p = strchrnul (tok, ',');
782 if (*p) next = p+1; else next = NULL;
784 r->pv_attr = strdup (tok);
785 if (r->pv_attr == NULL) {
791 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "pv_pe_count");
794 p = strchrnul (tok, ',');
795 if (*p) next = p+1; else next = NULL;
797 if (sscanf (tok, "%"SCNi64, &r->pv_pe_count) != 1) {
798 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "pv_pe_count");
803 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "pv_pe_alloc_count");
806 p = strchrnul (tok, ',');
807 if (*p) next = p+1; else next = NULL;
809 if (sscanf (tok, "%"SCNi64, &r->pv_pe_alloc_count) != 1) {
810 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "pv_pe_alloc_count");
815 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "pv_tags");
818 p = strchrnul (tok, ',');
819 if (*p) next = p+1; else next = NULL;
821 r->pv_tags = strdup (tok);
822 if (r->pv_tags == NULL) {
828 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "pe_start");
831 p = strchrnul (tok, ',');
832 if (*p) next = p+1; else next = NULL;
834 if (sscanf (tok, "%"SCNu64, &r->pe_start) != 1) {
835 fprintf (stderr, "%s: failed to parse size '%s' from token %s\n", __func__, tok, "pe_start");
840 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "pv_mda_count");
843 p = strchrnul (tok, ',');
844 if (*p) next = p+1; else next = NULL;
846 if (sscanf (tok, "%"SCNi64, &r->pv_mda_count) != 1) {
847 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "pv_mda_count");
852 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "pv_mda_free");
855 p = strchrnul (tok, ',');
856 if (*p) next = p+1; else next = NULL;
858 if (sscanf (tok, "%"SCNu64, &r->pv_mda_free) != 1) {
859 fprintf (stderr, "%s: failed to parse size '%s' from token %s\n", __func__, tok, "pv_mda_free");
864 fprintf (stderr, "%s: failed: extra tokens at end of string\n", __func__);
870 guestfs_lvm_int_pv_list *
871 parse_command_line_pvs (void)
876 guestfs_lvm_int_pv_list *ret;
879 ret = malloc (sizeof *ret);
881 reply_with_perror ("malloc");
885 ret->guestfs_lvm_int_pv_list_len = 0;
886 ret->guestfs_lvm_int_pv_list_val = NULL;
888 r = command (&out, &err,
890 "-o", lvm_pv_cols, "--unbuffered", "--noheadings",
891 "--nosuffix", "--separator", ",", "--units", "b", NULL);
893 reply_with_error ("%s", err);
901 /* Tokenize each line of the output. */
905 pend = strchr (p, '\n'); /* Get the next line of output. */
911 while (*p && isspace (*p)) /* Skip any leading whitespace. */
914 if (!*p) { /* Empty line? Skip it. */
919 /* Allocate some space to store this next entry. */
920 newp = realloc (ret->guestfs_lvm_int_pv_list_val,
921 sizeof (guestfs_lvm_int_pv) * (i+1));
923 reply_with_perror ("realloc");
924 free (ret->guestfs_lvm_int_pv_list_val);
929 ret->guestfs_lvm_int_pv_list_val = newp;
931 /* Tokenize the next entry. */
932 r = lvm_tokenize_pv (p, &ret->guestfs_lvm_int_pv_list_val[i]);
934 reply_with_error ("failed to parse output of 'pvs' command");
935 free (ret->guestfs_lvm_int_pv_list_val);
945 ret->guestfs_lvm_int_pv_list_len = i;
950 static const char *lvm_vg_cols = "vg_name,vg_uuid,vg_fmt,vg_attr,vg_size,vg_free,vg_sysid,vg_extent_size,vg_extent_count,vg_free_count,max_lv,max_pv,pv_count,lv_count,snap_count,vg_seqno,vg_tags,vg_mda_count,vg_mda_free";
952 static int lvm_tokenize_vg (char *str, struct guestfs_lvm_int_vg *r)
954 char *tok, *p, *next;
958 fprintf (stderr, "%s: failed: passed a NULL string\n", __func__);
961 if (!*str || isspace (*str)) {
962 fprintf (stderr, "%s: failed: passed a empty string or one beginning with whitespace\n", __func__);
967 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "vg_name");
970 p = strchrnul (tok, ',');
971 if (*p) next = p+1; else next = NULL;
973 r->vg_name = strdup (tok);
974 if (r->vg_name == NULL) {
980 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "vg_uuid");
983 p = strchrnul (tok, ',');
984 if (*p) next = p+1; else next = NULL;
986 for (i = j = 0; i < 32; ++j) {
987 if (tok[j] == '\0') {
988 fprintf (stderr, "%s: failed to parse UUID from '%s'\n", __func__, tok);
990 } else if (tok[j] != '-')
991 r->vg_uuid[i++] = tok[j];
995 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "vg_fmt");
998 p = strchrnul (tok, ',');
999 if (*p) next = p+1; else next = NULL;
1001 r->vg_fmt = strdup (tok);
1002 if (r->vg_fmt == NULL) {
1008 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "vg_attr");
1011 p = strchrnul (tok, ',');
1012 if (*p) next = p+1; else next = NULL;
1014 r->vg_attr = strdup (tok);
1015 if (r->vg_attr == NULL) {
1021 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "vg_size");
1024 p = strchrnul (tok, ',');
1025 if (*p) next = p+1; else next = NULL;
1027 if (sscanf (tok, "%"SCNu64, &r->vg_size) != 1) {
1028 fprintf (stderr, "%s: failed to parse size '%s' from token %s\n", __func__, tok, "vg_size");
1033 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "vg_free");
1036 p = strchrnul (tok, ',');
1037 if (*p) next = p+1; else next = NULL;
1039 if (sscanf (tok, "%"SCNu64, &r->vg_free) != 1) {
1040 fprintf (stderr, "%s: failed to parse size '%s' from token %s\n", __func__, tok, "vg_free");
1045 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "vg_sysid");
1048 p = strchrnul (tok, ',');
1049 if (*p) next = p+1; else next = NULL;
1051 r->vg_sysid = strdup (tok);
1052 if (r->vg_sysid == NULL) {
1058 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "vg_extent_size");
1061 p = strchrnul (tok, ',');
1062 if (*p) next = p+1; else next = NULL;
1064 if (sscanf (tok, "%"SCNu64, &r->vg_extent_size) != 1) {
1065 fprintf (stderr, "%s: failed to parse size '%s' from token %s\n", __func__, tok, "vg_extent_size");
1070 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "vg_extent_count");
1073 p = strchrnul (tok, ',');
1074 if (*p) next = p+1; else next = NULL;
1076 if (sscanf (tok, "%"SCNi64, &r->vg_extent_count) != 1) {
1077 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "vg_extent_count");
1082 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "vg_free_count");
1085 p = strchrnul (tok, ',');
1086 if (*p) next = p+1; else next = NULL;
1088 if (sscanf (tok, "%"SCNi64, &r->vg_free_count) != 1) {
1089 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "vg_free_count");
1094 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "max_lv");
1097 p = strchrnul (tok, ',');
1098 if (*p) next = p+1; else next = NULL;
1100 if (sscanf (tok, "%"SCNi64, &r->max_lv) != 1) {
1101 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "max_lv");
1106 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "max_pv");
1109 p = strchrnul (tok, ',');
1110 if (*p) next = p+1; else next = NULL;
1112 if (sscanf (tok, "%"SCNi64, &r->max_pv) != 1) {
1113 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "max_pv");
1118 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "pv_count");
1121 p = strchrnul (tok, ',');
1122 if (*p) next = p+1; else next = NULL;
1124 if (sscanf (tok, "%"SCNi64, &r->pv_count) != 1) {
1125 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "pv_count");
1130 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "lv_count");
1133 p = strchrnul (tok, ',');
1134 if (*p) next = p+1; else next = NULL;
1136 if (sscanf (tok, "%"SCNi64, &r->lv_count) != 1) {
1137 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "lv_count");
1142 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "snap_count");
1145 p = strchrnul (tok, ',');
1146 if (*p) next = p+1; else next = NULL;
1148 if (sscanf (tok, "%"SCNi64, &r->snap_count) != 1) {
1149 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "snap_count");
1154 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "vg_seqno");
1157 p = strchrnul (tok, ',');
1158 if (*p) next = p+1; else next = NULL;
1160 if (sscanf (tok, "%"SCNi64, &r->vg_seqno) != 1) {
1161 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "vg_seqno");
1166 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "vg_tags");
1169 p = strchrnul (tok, ',');
1170 if (*p) next = p+1; else next = NULL;
1172 r->vg_tags = strdup (tok);
1173 if (r->vg_tags == NULL) {
1179 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "vg_mda_count");
1182 p = strchrnul (tok, ',');
1183 if (*p) next = p+1; else next = NULL;
1185 if (sscanf (tok, "%"SCNi64, &r->vg_mda_count) != 1) {
1186 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "vg_mda_count");
1191 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "vg_mda_free");
1194 p = strchrnul (tok, ',');
1195 if (*p) next = p+1; else next = NULL;
1197 if (sscanf (tok, "%"SCNu64, &r->vg_mda_free) != 1) {
1198 fprintf (stderr, "%s: failed to parse size '%s' from token %s\n", __func__, tok, "vg_mda_free");
1203 fprintf (stderr, "%s: failed: extra tokens at end of string\n", __func__);
1209 guestfs_lvm_int_vg_list *
1210 parse_command_line_vgs (void)
1215 guestfs_lvm_int_vg_list *ret;
1218 ret = malloc (sizeof *ret);
1220 reply_with_perror ("malloc");
1224 ret->guestfs_lvm_int_vg_list_len = 0;
1225 ret->guestfs_lvm_int_vg_list_val = NULL;
1227 r = command (&out, &err,
1229 "-o", lvm_vg_cols, "--unbuffered", "--noheadings",
1230 "--nosuffix", "--separator", ",", "--units", "b", NULL);
1232 reply_with_error ("%s", err);
1240 /* Tokenize each line of the output. */
1244 pend = strchr (p, '\n'); /* Get the next line of output. */
1250 while (*p && isspace (*p)) /* Skip any leading whitespace. */
1253 if (!*p) { /* Empty line? Skip it. */
1258 /* Allocate some space to store this next entry. */
1259 newp = realloc (ret->guestfs_lvm_int_vg_list_val,
1260 sizeof (guestfs_lvm_int_vg) * (i+1));
1262 reply_with_perror ("realloc");
1263 free (ret->guestfs_lvm_int_vg_list_val);
1268 ret->guestfs_lvm_int_vg_list_val = newp;
1270 /* Tokenize the next entry. */
1271 r = lvm_tokenize_vg (p, &ret->guestfs_lvm_int_vg_list_val[i]);
1273 reply_with_error ("failed to parse output of 'vgs' command");
1274 free (ret->guestfs_lvm_int_vg_list_val);
1284 ret->guestfs_lvm_int_vg_list_len = i;
1289 static const char *lvm_lv_cols = "lv_name,lv_uuid,lv_attr,lv_major,lv_minor,lv_kernel_major,lv_kernel_minor,lv_size,seg_count,origin,snap_percent,copy_percent,move_pv,lv_tags,mirror_log,modules";
1291 static int lvm_tokenize_lv (char *str, struct guestfs_lvm_int_lv *r)
1293 char *tok, *p, *next;
1297 fprintf (stderr, "%s: failed: passed a NULL string\n", __func__);
1300 if (!*str || isspace (*str)) {
1301 fprintf (stderr, "%s: failed: passed a empty string or one beginning with whitespace\n", __func__);
1306 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "lv_name");
1309 p = strchrnul (tok, ',');
1310 if (*p) next = p+1; else next = NULL;
1312 r->lv_name = strdup (tok);
1313 if (r->lv_name == NULL) {
1319 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "lv_uuid");
1322 p = strchrnul (tok, ',');
1323 if (*p) next = p+1; else next = NULL;
1325 for (i = j = 0; i < 32; ++j) {
1326 if (tok[j] == '\0') {
1327 fprintf (stderr, "%s: failed to parse UUID from '%s'\n", __func__, tok);
1329 } else if (tok[j] != '-')
1330 r->lv_uuid[i++] = tok[j];
1334 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "lv_attr");
1337 p = strchrnul (tok, ',');
1338 if (*p) next = p+1; else next = NULL;
1340 r->lv_attr = strdup (tok);
1341 if (r->lv_attr == NULL) {
1347 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "lv_major");
1350 p = strchrnul (tok, ',');
1351 if (*p) next = p+1; else next = NULL;
1353 if (sscanf (tok, "%"SCNi64, &r->lv_major) != 1) {
1354 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "lv_major");
1359 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "lv_minor");
1362 p = strchrnul (tok, ',');
1363 if (*p) next = p+1; else next = NULL;
1365 if (sscanf (tok, "%"SCNi64, &r->lv_minor) != 1) {
1366 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "lv_minor");
1371 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "lv_kernel_major");
1374 p = strchrnul (tok, ',');
1375 if (*p) next = p+1; else next = NULL;
1377 if (sscanf (tok, "%"SCNi64, &r->lv_kernel_major) != 1) {
1378 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "lv_kernel_major");
1383 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "lv_kernel_minor");
1386 p = strchrnul (tok, ',');
1387 if (*p) next = p+1; else next = NULL;
1389 if (sscanf (tok, "%"SCNi64, &r->lv_kernel_minor) != 1) {
1390 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "lv_kernel_minor");
1395 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "lv_size");
1398 p = strchrnul (tok, ',');
1399 if (*p) next = p+1; else next = NULL;
1401 if (sscanf (tok, "%"SCNu64, &r->lv_size) != 1) {
1402 fprintf (stderr, "%s: failed to parse size '%s' from token %s\n", __func__, tok, "lv_size");
1407 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "seg_count");
1410 p = strchrnul (tok, ',');
1411 if (*p) next = p+1; else next = NULL;
1413 if (sscanf (tok, "%"SCNi64, &r->seg_count) != 1) {
1414 fprintf (stderr, "%s: failed to parse int '%s' from token %s\n", __func__, tok, "seg_count");
1419 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "origin");
1422 p = strchrnul (tok, ',');
1423 if (*p) next = p+1; else next = NULL;
1425 r->origin = strdup (tok);
1426 if (r->origin == NULL) {
1432 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "snap_percent");
1435 p = strchrnul (tok, ',');
1436 if (*p) next = p+1; else next = NULL;
1439 r->snap_percent = -1;
1440 else if (sscanf (tok, "%f", &r->snap_percent) != 1) {
1441 fprintf (stderr, "%s: failed to parse float '%s' from token %s\n", __func__, tok, "snap_percent");
1446 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "copy_percent");
1449 p = strchrnul (tok, ',');
1450 if (*p) next = p+1; else next = NULL;
1453 r->copy_percent = -1;
1454 else if (sscanf (tok, "%f", &r->copy_percent) != 1) {
1455 fprintf (stderr, "%s: failed to parse float '%s' from token %s\n", __func__, tok, "copy_percent");
1460 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "move_pv");
1463 p = strchrnul (tok, ',');
1464 if (*p) next = p+1; else next = NULL;
1466 r->move_pv = strdup (tok);
1467 if (r->move_pv == NULL) {
1473 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "lv_tags");
1476 p = strchrnul (tok, ',');
1477 if (*p) next = p+1; else next = NULL;
1479 r->lv_tags = strdup (tok);
1480 if (r->lv_tags == NULL) {
1486 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "mirror_log");
1489 p = strchrnul (tok, ',');
1490 if (*p) next = p+1; else next = NULL;
1492 r->mirror_log = strdup (tok);
1493 if (r->mirror_log == NULL) {
1499 fprintf (stderr, "%s: failed: string finished early, around token %s\n", __func__, "modules");
1502 p = strchrnul (tok, ',');
1503 if (*p) next = p+1; else next = NULL;
1505 r->modules = strdup (tok);
1506 if (r->modules == NULL) {
1512 fprintf (stderr, "%s: failed: extra tokens at end of string\n", __func__);
1518 guestfs_lvm_int_lv_list *
1519 parse_command_line_lvs (void)
1524 guestfs_lvm_int_lv_list *ret;
1527 ret = malloc (sizeof *ret);
1529 reply_with_perror ("malloc");
1533 ret->guestfs_lvm_int_lv_list_len = 0;
1534 ret->guestfs_lvm_int_lv_list_val = NULL;
1536 r = command (&out, &err,
1538 "-o", lvm_lv_cols, "--unbuffered", "--noheadings",
1539 "--nosuffix", "--separator", ",", "--units", "b", NULL);
1541 reply_with_error ("%s", err);
1549 /* Tokenize each line of the output. */
1553 pend = strchr (p, '\n'); /* Get the next line of output. */
1559 while (*p && isspace (*p)) /* Skip any leading whitespace. */
1562 if (!*p) { /* Empty line? Skip it. */
1567 /* Allocate some space to store this next entry. */
1568 newp = realloc (ret->guestfs_lvm_int_lv_list_val,
1569 sizeof (guestfs_lvm_int_lv) * (i+1));
1571 reply_with_perror ("realloc");
1572 free (ret->guestfs_lvm_int_lv_list_val);
1577 ret->guestfs_lvm_int_lv_list_val = newp;
1579 /* Tokenize the next entry. */
1580 r = lvm_tokenize_lv (p, &ret->guestfs_lvm_int_lv_list_val[i]);
1582 reply_with_error ("failed to parse output of 'lvs' command");
1583 free (ret->guestfs_lvm_int_lv_list_val);
1593 ret->guestfs_lvm_int_lv_list_len = i;