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.
30 void list_commands (void)
32 printf (" %-16s %s\n", "Command", "Description");
33 list_builtin_commands ();
34 printf ("%-20s %s\n", "add-cdrom", "add a CD-ROM disk image to examine");
35 printf ("%-20s %s\n", "add-drive", "add an image to examine or modify");
36 printf ("%-20s %s\n", "aug-close", "close the current Augeas handle");
37 printf ("%-20s %s\n", "aug-defnode", "define an Augeas node");
38 printf ("%-20s %s\n", "aug-defvar", "define an Augeas variable");
39 printf ("%-20s %s\n", "aug-get", "look up the value of an Augeas path");
40 printf ("%-20s %s\n", "aug-init", "create a new Augeas handle");
41 printf ("%-20s %s\n", "aug-insert", "insert a sibling Augeas node");
42 printf ("%-20s %s\n", "aug-load", "load files into the tree");
43 printf ("%-20s %s\n", "aug-ls", "list Augeas nodes under a path");
44 printf ("%-20s %s\n", "aug-match", "return Augeas nodes which match path");
45 printf ("%-20s %s\n", "aug-mv", "move Augeas node");
46 printf ("%-20s %s\n", "aug-rm", "remove an Augeas path");
47 printf ("%-20s %s\n", "aug-save", "write all pending Augeas changes to disk");
48 printf ("%-20s %s\n", "aug-set", "set Augeas path to value");
49 printf ("%-20s %s\n", "blockdev-flushbufs", "flush device buffers");
50 printf ("%-20s %s\n", "blockdev-getbsz", "get blocksize of block device");
51 printf ("%-20s %s\n", "blockdev-getro", "is block device set to read-only");
52 printf ("%-20s %s\n", "blockdev-getsize64", "get total size of device in bytes");
53 printf ("%-20s %s\n", "blockdev-getss", "get sectorsize of block device");
54 printf ("%-20s %s\n", "blockdev-getsz", "get total size of device in 512-byte sectors");
55 printf ("%-20s %s\n", "blockdev-rereadpt", "reread partition table");
56 printf ("%-20s %s\n", "blockdev-setbsz", "set blocksize of block device");
57 printf ("%-20s %s\n", "blockdev-setro", "set block device to read-only");
58 printf ("%-20s %s\n", "blockdev-setrw", "set block device to read-write");
59 printf ("%-20s %s\n", "cat", "list the contents of a file");
60 printf ("%-20s %s\n", "checksum", "compute MD5, SHAx or CRC checksum of file");
61 printf ("%-20s %s\n", "chmod", "change file mode");
62 printf ("%-20s %s\n", "chown", "change file owner and group");
63 printf ("%-20s %s\n", "command", "run a command from the guest filesystem");
64 printf ("%-20s %s\n", "command-lines", "run a command, returning lines");
65 printf ("%-20s %s\n", "config", "add qemu parameters");
66 printf ("%-20s %s\n", "cp", "copy a file");
67 printf ("%-20s %s\n", "cp-a", "copy a file or directory recursively");
68 printf ("%-20s %s\n", "debug", "debugging and internals");
69 printf ("%-20s %s\n", "dmesg", "return kernel messages");
70 printf ("%-20s %s\n", "download", "download a file to the local machine");
71 printf ("%-20s %s\n", "drop-caches", "drop kernel page cache, dentries and inodes");
72 printf ("%-20s %s\n", "equal", "test if two files have equal contents");
73 printf ("%-20s %s\n", "exists", "test if file or directory exists");
74 printf ("%-20s %s\n", "file", "determine file type");
75 printf ("%-20s %s\n", "fsck", "run the filesystem checker");
76 printf ("%-20s %s\n", "get-append", "get the additional kernel options");
77 printf ("%-20s %s\n", "get-autosync", "get autosync mode");
78 printf ("%-20s %s\n", "get-e2label", "get the ext2/3/4 filesystem label");
79 printf ("%-20s %s\n", "get-e2uuid", "get the ext2/3/4 filesystem UUID");
80 printf ("%-20s %s\n", "get-path", "get the search path");
81 printf ("%-20s %s\n", "get-qemu", "get the qemu binary");
82 printf ("%-20s %s\n", "get-state", "get the current state");
83 printf ("%-20s %s\n", "get-verbose", "get verbose mode");
84 printf ("%-20s %s\n", "grub-install", "install GRUB");
85 printf ("%-20s %s\n", "hexdump", "dump a file in hexadecimal");
86 printf ("%-20s %s\n", "is-busy", "is busy processing a command");
87 printf ("%-20s %s\n", "is-config", "is in configuration state");
88 printf ("%-20s %s\n", "is-dir", "test if file exists");
89 printf ("%-20s %s\n", "is-file", "test if file exists");
90 printf ("%-20s %s\n", "is-launching", "is launching subprocess");
91 printf ("%-20s %s\n", "is-ready", "is ready to accept commands");
92 printf ("%-20s %s\n", "kill-subprocess", "kill the qemu subprocess");
93 printf ("%-20s %s\n", "launch", "launch the qemu subprocess");
94 printf ("%-20s %s\n", "list-devices", "list the block devices");
95 printf ("%-20s %s\n", "list-partitions", "list the partitions");
96 printf ("%-20s %s\n", "ll", "list the files in a directory (long format)");
97 printf ("%-20s %s\n", "ls", "list the files in a directory");
98 printf ("%-20s %s\n", "lstat", "get file information for a symbolic link");
99 printf ("%-20s %s\n", "lvcreate", "create an LVM volume group");
100 printf ("%-20s %s\n", "lvm-remove-all", "remove all LVM LVs, VGs and PVs");
101 printf ("%-20s %s\n", "lvremove", "remove an LVM logical volume");
102 printf ("%-20s %s\n", "lvresize", "resize an LVM logical volume");
103 printf ("%-20s %s\n", "lvs", "list the LVM logical volumes (LVs)");
104 printf ("%-20s %s\n", "lvs-full", "list the LVM logical volumes (LVs)");
105 printf ("%-20s %s\n", "mkdir", "create a directory");
106 printf ("%-20s %s\n", "mkdir-p", "create a directory and parents");
107 printf ("%-20s %s\n", "mkfs", "make a filesystem");
108 printf ("%-20s %s\n", "mount", "mount a guest disk at a position in the filesystem");
109 printf ("%-20s %s\n", "mount-options", "mount a guest disk with mount options");
110 printf ("%-20s %s\n", "mount-ro", "mount a guest disk, read-only");
111 printf ("%-20s %s\n", "mount-vfs", "mount a guest disk with mount options and vfstype");
112 printf ("%-20s %s\n", "mounts", "show mounted filesystems");
113 printf ("%-20s %s\n", "mv", "move a file");
114 printf ("%-20s %s\n", "ping-daemon", "ping the guest daemon");
115 printf ("%-20s %s\n", "pvcreate", "create an LVM physical volume");
116 printf ("%-20s %s\n", "pvremove", "remove an LVM physical volume");
117 printf ("%-20s %s\n", "pvresize", "resize an LVM physical volume");
118 printf ("%-20s %s\n", "pvs", "list the LVM physical volumes (PVs)");
119 printf ("%-20s %s\n", "pvs-full", "list the LVM physical volumes (PVs)");
120 printf ("%-20s %s\n", "read-lines", "read file as lines");
121 printf ("%-20s %s\n", "resize2fs", "resize an ext2/ext3 filesystem");
122 printf ("%-20s %s\n", "rm", "remove a file");
123 printf ("%-20s %s\n", "rm-rf", "remove a file or directory recursively");
124 printf ("%-20s %s\n", "rmdir", "remove a directory");
125 printf ("%-20s %s\n", "set-append", "add options to kernel command line");
126 printf ("%-20s %s\n", "set-autosync", "set autosync mode");
127 printf ("%-20s %s\n", "set-e2label", "set the ext2/3/4 filesystem label");
128 printf ("%-20s %s\n", "set-e2uuid", "set the ext2/3/4 filesystem UUID");
129 printf ("%-20s %s\n", "set-path", "set the search path");
130 printf ("%-20s %s\n", "set-qemu", "set the qemu binary");
131 printf ("%-20s %s\n", "set-verbose", "set verbose mode");
132 printf ("%-20s %s\n", "sfdisk", "create partitions on a block device");
133 printf ("%-20s %s\n", "sfdisk-N", "modify a single partition on a block device");
134 printf ("%-20s %s\n", "sfdisk-disk-geometry", "display the disk geometry from the partition table");
135 printf ("%-20s %s\n", "sfdisk-kernel-geometry", "display the kernel geometry");
136 printf ("%-20s %s\n", "sfdisk-l", "display the partition table");
137 printf ("%-20s %s\n", "stat", "get file information");
138 printf ("%-20s %s\n", "statvfs", "get file system statistics");
139 printf ("%-20s %s\n", "strings", "print the printable strings in a file");
140 printf ("%-20s %s\n", "strings-e", "print the printable strings in a file");
141 printf ("%-20s %s\n", "sync", "sync disks, writes are flushed through to the disk image");
142 printf ("%-20s %s\n", "tar-in", "unpack tarfile to directory");
143 printf ("%-20s %s\n", "tar-out", "pack directory into tarfile");
144 printf ("%-20s %s\n", "tgz-in", "unpack compressed tarball to directory");
145 printf ("%-20s %s\n", "tgz-out", "pack directory into compressed tarball");
146 printf ("%-20s %s\n", "touch", "update file timestamps or create a new file");
147 printf ("%-20s %s\n", "tune2fs-l", "get ext2/ext3/ext4 superblock details");
148 printf ("%-20s %s\n", "umount", "unmount a filesystem");
149 printf ("%-20s %s\n", "umount-all", "unmount all filesystems");
150 printf ("%-20s %s\n", "upload", "upload a file from the local machine");
151 printf ("%-20s %s\n", "vg-activate", "activate or deactivate some volume groups");
152 printf ("%-20s %s\n", "vg-activate-all", "activate or deactivate all volume groups");
153 printf ("%-20s %s\n", "vgcreate", "create an LVM volume group");
154 printf ("%-20s %s\n", "vgremove", "remove an LVM volume group");
155 printf ("%-20s %s\n", "vgs", "list the LVM volume groups (VGs)");
156 printf ("%-20s %s\n", "vgs-full", "list the LVM volume groups (VGs)");
157 printf ("%-20s %s\n", "write-file", "create a file");
158 printf ("%-20s %s\n", "zero", "write zeroes to the device");
159 printf ("%-20s %s\n", "zerofree", "zero unused inodes and disk blocks on ext2/3 filesystem");
160 printf (" Use -h <cmd> / help <cmd> to show detailed help for a command.\n");
163 void display_command (const char *cmd)
165 if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
166 pod2text ("launch - launch the qemu subprocess", " launch\n\nInternally libguestfs is implemented by running a virtual machine\nusing L<qemu(1)>.\n\nYou should call this after configuring the handle\n(eg. adding drives) but before performing any actions.\n\nYou can use 'run' as an alias for this command.");
168 if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
169 pod2text ("kill-subprocess - kill the qemu subprocess", " kill-subprocess\n\nThis kills the qemu subprocess. You should never need to call this.");
171 if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
172 pod2text ("add-drive - add an image to examine or modify", " add-drive <filename>\n\nThis function adds a virtual machine disk image C<filename> to the\nguest. The first time you call this function, the disk appears as IDE\ndisk 0 (C</dev/sda>) in the guest, the second time as C</dev/sdb>, and\nso on.\n\nYou don't necessarily need to be root when using libguestfs. However\nyou obviously do need sufficient permissions to access the filename\nfor whatever operations you want to perform (ie. read access if you\njust want to read the image or write access if you want to modify the\nimage).\n\nThis is equivalent to the qemu parameter C<-drive file=filename>.\n\nYou can use 'add' as an alias for this command.");
174 if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
175 pod2text ("add-cdrom - add a CD-ROM disk image to examine", " add-cdrom <filename>\n\nThis function adds a virtual CD-ROM disk image to the guest.\n\nThis is equivalent to the qemu parameter C<-cdrom filename>.\n\nYou can use 'cdrom' as an alias for this command.");
177 if (strcasecmp (cmd, "config") == 0)
178 pod2text ("config - add qemu parameters", " config <qemuparam> <qemuvalue>\n\nThis can be used to add arbitrary qemu command line parameters\nof the form C<-param value>. Actually it's not quite arbitrary - we\nprevent you from setting some parameters which would interfere with\nparameters that we use.\n\nThe first character of C<param> string must be a C<-> (dash).\n\nC<value> can be NULL.");
180 if (strcasecmp (cmd, "set_qemu") == 0 || strcasecmp (cmd, "set-qemu") == 0 || strcasecmp (cmd, "qemu") == 0)
181 pod2text ("set-qemu - set the qemu binary", " set-qemu <qemu>\n\nSet the qemu binary that we will use.\n\nThe default is chosen when the library was compiled by the\nconfigure script.\n\nYou can also override this by setting the C<LIBGUESTFS_QEMU>\nenvironment variable.\n\nSetting C<qemu> to C<NULL> restores the default qemu binary.\n\nYou can use 'qemu' as an alias for this command.");
183 if (strcasecmp (cmd, "get_qemu") == 0 || strcasecmp (cmd, "get-qemu") == 0)
184 pod2text ("get-qemu - get the qemu binary", " get-qemu\n\nReturn the current qemu binary.\n\nThis is always non-NULL. If it wasn't set already, then this will\nreturn the default qemu binary name.");
186 if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
187 pod2text ("set-path - set the search path", " set-path <path>\n\nSet the path that libguestfs searches for kernel and initrd.img.\n\nThe default is C<$libdir/guestfs> unless overridden by setting\nC<LIBGUESTFS_PATH> environment variable.\n\nSetting C<path> to C<NULL> restores the default path.\n\nYou can use 'path' as an alias for this command.");
189 if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
190 pod2text ("get-path - get the search path", " get-path\n\nReturn the current search path.\n\nThis is always non-NULL. If it wasn't set already, then this will\nreturn the default path.");
192 if (strcasecmp (cmd, "set_append") == 0 || strcasecmp (cmd, "set-append") == 0 || strcasecmp (cmd, "append") == 0)
193 pod2text ("set-append - add options to kernel command line", " set-append <append>\n\nThis function is used to add additional options to the\nguest kernel command line.\n\nThe default is C<NULL> unless overridden by setting\nC<LIBGUESTFS_APPEND> environment variable.\n\nSetting C<append> to C<NULL> means I<no> additional options\nare passed (libguestfs always adds a few of its own).\n\nYou can use 'append' as an alias for this command.");
195 if (strcasecmp (cmd, "get_append") == 0 || strcasecmp (cmd, "get-append") == 0)
196 pod2text ("get-append - get the additional kernel options", " get-append\n\nReturn the additional kernel options which are added to the\nguest kernel command line.\n\nIf C<NULL> then no options are added.");
198 if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
199 pod2text ("set-autosync - set autosync mode", " set-autosync <autosync>\n\nIf C<autosync> is true, this enables autosync. Libguestfs will make a\nbest effort attempt to run C<umount_all> followed by\nC<sync> when the handle is closed\n(also if the program exits without closing handles).\n\nThis is disabled by default (except in guestfish where it is\nenabled by default).\n\nYou can use 'autosync' as an alias for this command.");
201 if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
202 pod2text ("get-autosync - get autosync mode", " get-autosync\n\nGet the autosync flag.");
204 if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
205 pod2text ("set-verbose - set verbose mode", " set-verbose <verbose>\n\nIf C<verbose> is true, this turns on verbose messages (to C<stderr>).\n\nVerbose messages are disabled unless the environment variable\nC<LIBGUESTFS_DEBUG> is defined and set to C<1>.\n\nYou can use 'verbose' as an alias for this command.");
207 if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
208 pod2text ("get-verbose - get verbose mode", " get-verbose\n\nThis returns the verbose messages flag.");
210 if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
211 pod2text ("is-ready - is ready to accept commands", " is-ready\n\nThis returns true iff this handle is ready to accept commands\n(in the C<READY> state).\n\nFor more information on states, see L<guestfs(3)>.");
213 if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
214 pod2text ("is-config - is in configuration state", " is-config\n\nThis returns true iff this handle is being configured\n(in the C<CONFIG> state).\n\nFor more information on states, see L<guestfs(3)>.");
216 if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
217 pod2text ("is-launching - is launching subprocess", " is-launching\n\nThis returns true iff this handle is launching the subprocess\n(in the C<LAUNCHING> state).\n\nFor more information on states, see L<guestfs(3)>.");
219 if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
220 pod2text ("is-busy - is busy processing a command", " is-busy\n\nThis returns true iff this handle is busy processing a command\n(in the C<BUSY> state).\n\nFor more information on states, see L<guestfs(3)>.");
222 if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
223 pod2text ("get-state - get the current state", " get-state\n\nThis returns the current state as an opaque integer. This is\nonly useful for printing debug and internal error messages.\n\nFor more information on states, see L<guestfs(3)>.");
225 if (strcasecmp (cmd, "mount") == 0)
226 pod2text ("mount - mount a guest disk at a position in the filesystem", " mount <device> <mountpoint>\n\nMount a guest disk at a position in the filesystem. Block devices\nare named C</dev/sda>, C</dev/sdb> and so on, as they were added to\nthe guest. If those block devices contain partitions, they will have\nthe usual names (eg. C</dev/sda1>). Also LVM C</dev/VG/LV>-style\nnames can be used.\n\nThe rules are the same as for L<mount(2)>: A filesystem must\nfirst be mounted on C</> before others can be mounted. Other\nfilesystems can only be mounted on directories which already\nexist.\n\nThe mounted filesystem is writable, if we have sufficient permissions\non the underlying device.\n\nThe filesystem options C<sync> and C<noatime> are set with this\ncall, in order to improve reliability.");
228 if (strcasecmp (cmd, "sync") == 0)
229 pod2text ("sync - sync disks, writes are flushed through to the disk image", " sync\n\nThis syncs the disk, so that any writes are flushed through to the\nunderlying disk image.\n\nYou should always call this if you have modified a disk image, before\nclosing the handle.");
231 if (strcasecmp (cmd, "touch") == 0)
232 pod2text ("touch - update file timestamps or create a new file", " touch <path>\n\nTouch acts like the L<touch(1)> command. It can be used to\nupdate the timestamps on a file, or, if the file does not exist,\nto create a new zero-length file.");
234 if (strcasecmp (cmd, "cat") == 0)
235 pod2text ("cat - list the contents of a file", " cat <path>\n\nReturn the contents of the file named C<path>.\n\nNote that this function cannot correctly handle binary files\n(specifically, files containing C<\\0> character which is treated\nas end of string). For those you need to use the C<download>\nfunction which has a more complex interface.\n\nBecause of the message protocol, there is a transfer limit \nof somewhere between 2MB and 4MB. To transfer large files you should use\nFTP.");
237 if (strcasecmp (cmd, "ll") == 0)
238 pod2text ("ll - list the files in a directory (long format)", " ll <directory>\n\nList the files in C<directory> (relative to the root directory,\nthere is no cwd) in the format of 'ls -la'.\n\nThis command is mostly useful for interactive sessions. It\nis I<not> intended that you try to parse the output string.");
240 if (strcasecmp (cmd, "ls") == 0)
241 pod2text ("ls - list the files in a directory", " ls <directory>\n\nList the files in C<directory> (relative to the root directory,\nthere is no cwd). The '.' and '..' entries are not returned, but\nhidden files are shown.\n\nThis command is mostly useful for interactive sessions. Programs\nshould probably use C<readdir> instead.");
243 if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
244 pod2text ("list-devices - list the block devices", " list-devices\n\nList all the block devices.\n\nThe full block device names are returned, eg. C</dev/sda>");
246 if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
247 pod2text ("list-partitions - list the partitions", " list-partitions\n\nList all the partitions detected on all block devices.\n\nThe full partition device names are returned, eg. C</dev/sda1>\n\nThis does not return logical volumes. For that you will need to\ncall C<lvs>.");
249 if (strcasecmp (cmd, "pvs") == 0)
250 pod2text ("pvs - list the LVM physical volumes (PVs)", " pvs\n\nList all the physical volumes detected. This is the equivalent\nof the L<pvs(8)> command.\n\nThis returns a list of just the device names that contain\nPVs (eg. C</dev/sda2>).\n\nSee also C<pvs_full>.");
252 if (strcasecmp (cmd, "vgs") == 0)
253 pod2text ("vgs - list the LVM volume groups (VGs)", " vgs\n\nList all the volumes groups detected. This is the equivalent\nof the L<vgs(8)> command.\n\nThis returns a list of just the volume group names that were\ndetected (eg. C<VolGroup00>).\n\nSee also C<vgs_full>.");
255 if (strcasecmp (cmd, "lvs") == 0)
256 pod2text ("lvs - list the LVM logical volumes (LVs)", " lvs\n\nList all the logical volumes detected. This is the equivalent\nof the L<lvs(8)> command.\n\nThis returns a list of the logical volume device names\n(eg. C</dev/VolGroup00/LogVol00>).\n\nSee also C<lvs_full>.");
258 if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
259 pod2text ("pvs-full - list the LVM physical volumes (PVs)", " pvs-full\n\nList all the physical volumes detected. This is the equivalent\nof the L<pvs(8)> command. The \"full\" version includes all fields.");
261 if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
262 pod2text ("vgs-full - list the LVM volume groups (VGs)", " vgs-full\n\nList all the volumes groups detected. This is the equivalent\nof the L<vgs(8)> command. The \"full\" version includes all fields.");
264 if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
265 pod2text ("lvs-full - list the LVM logical volumes (LVs)", " lvs-full\n\nList all the logical volumes detected. This is the equivalent\nof the L<lvs(8)> command. The \"full\" version includes all fields.");
267 if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
268 pod2text ("read-lines - read file as lines", " read-lines <path>\n\nReturn the contents of the file named C<path>.\n\nThe file contents are returned as a list of lines. Trailing\nC<LF> and C<CRLF> character sequences are I<not> returned.\n\nNote that this function cannot correctly handle binary files\n(specifically, files containing C<\\0> character which is treated\nas end of line). For those you need to use the C<read_file>\nfunction which has a more complex interface.");
270 if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
271 pod2text ("aug-init - create a new Augeas handle", " aug-init <root> <flags>\n\nCreate a new Augeas handle for editing configuration files.\nIf there was any previous Augeas handle associated with this\nguestfs session, then it is closed.\n\nYou must call this before using any other C<aug_*>\ncommands.\n\nC<root> is the filesystem root. C<root> must not be NULL,\nuse C</> instead.\n\nThe flags are the same as the flags defined in\nE<lt>augeas.hE<gt>, the logical I<or> of the following\nintegers:\n\n=over 4\n\n=item C<AUG_SAVE_BACKUP> = 1\n\nKeep the original file with a C<.augsave> extension.\n\n=item C<AUG_SAVE_NEWFILE> = 2\n\nSave changes into a file with extension C<.augnew>, and\ndo not overwrite original. Overrides C<AUG_SAVE_BACKUP>.\n\n=item C<AUG_TYPE_CHECK> = 4\n\nTypecheck lenses (can be expensive).\n\n=item C<AUG_NO_STDINC> = 8\n\nDo not use standard load path for modules.\n\n=item C<AUG_SAVE_NOOP> = 16\n\nMake save a no-op, just record what would have been changed.\n\n=item C<AUG_NO_LOAD> = 32\n\nDo not load the tree in C<aug_init>.\n\n=back\n\nTo close the handle, you can call C<aug_close>.\n\nTo find out more about Augeas, see L<http://augeas.net/>.");
273 if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
274 pod2text ("aug-close - close the current Augeas handle", " aug-close\n\nClose the current Augeas handle and free up any resources\nused by it. After calling this, you have to call\nC<aug_init> again before you can use any other\nAugeas functions.");
276 if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
277 pod2text ("aug-defvar - define an Augeas variable", " aug-defvar <name> <expr>\n\nDefines an Augeas variable C<name> whose value is the result\nof evaluating C<expr>. If C<expr> is NULL, then C<name> is\nundefined.\n\nOn success this returns the number of nodes in C<expr>, or\nC<0> if C<expr> evaluates to something which is not a nodeset.");
279 if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
280 pod2text ("aug-defnode - define an Augeas node", " aug-defnode <name> <expr> <val>\n\nDefines a variable C<name> whose value is the result of\nevaluating C<expr>.\n\nIf C<expr> evaluates to an empty nodeset, a node is created,\nequivalent to calling C<aug_set> C<expr>, C<value>.\nC<name> will be the nodeset containing that single node.\n\nOn success this returns a pair containing the\nnumber of nodes in the nodeset, and a boolean flag\nif a node was created.");
282 if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
283 pod2text ("aug-get - look up the value of an Augeas path", " aug-get <path>\n\nLook up the value associated with C<path>. If C<path>\nmatches exactly one node, the C<value> is returned.");
285 if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
286 pod2text ("aug-set - set Augeas path to value", " aug-set <path> <val>\n\nSet the value associated with C<path> to C<value>.");
288 if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
289 pod2text ("aug-insert - insert a sibling Augeas node", " aug-insert <path> <label> <before>\n\nCreate a new sibling C<label> for C<path>, inserting it into\nthe tree before or after C<path> (depending on the boolean\nflag C<before>).\n\nC<path> must match exactly one existing node in the tree, and\nC<label> must be a label, ie. not contain C</>, C<*> or end\nwith a bracketed index C<[N]>.");
291 if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
292 pod2text ("aug-rm - remove an Augeas path", " aug-rm <path>\n\nRemove C<path> and all of its children.\n\nOn success this returns the number of entries which were removed.");
294 if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
295 pod2text ("aug-mv - move Augeas node", " aug-mv <src> <dest>\n\nMove the node C<src> to C<dest>. C<src> must match exactly\none node. C<dest> is overwritten if it exists.");
297 if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
298 pod2text ("aug-match - return Augeas nodes which match path", " aug-match <path>\n\nReturns a list of paths which match the path expression C<path>.\nThe returned paths are sufficiently qualified so that they match\nexactly one node in the current tree.");
300 if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
301 pod2text ("aug-save - write all pending Augeas changes to disk", " aug-save\n\nThis writes all pending changes to disk.\n\nThe flags which were passed to C<aug_init> affect exactly\nhow files are saved.");
303 if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
304 pod2text ("aug-load - load files into the tree", " aug-load\n\nLoad files into the tree.\n\nSee C<aug_load> in the Augeas documentation for the full gory\ndetails.");
306 if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
307 pod2text ("aug-ls - list Augeas nodes under a path", " aug-ls <path>\n\nThis is just a shortcut for listing C<aug_match>\nC<path/*> and sorting the resulting nodes into alphabetical order.");
309 if (strcasecmp (cmd, "rm") == 0)
310 pod2text ("rm - remove a file", " rm <path>\n\nRemove the single file C<path>.");
312 if (strcasecmp (cmd, "rmdir") == 0)
313 pod2text ("rmdir - remove a directory", " rmdir <path>\n\nRemove the single directory C<path>.");
315 if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
316 pod2text ("rm-rf - remove a file or directory recursively", " rm-rf <path>\n\nRemove the file or directory C<path>, recursively removing the\ncontents if its a directory. This is like the C<rm -rf> shell\ncommand.");
318 if (strcasecmp (cmd, "mkdir") == 0)
319 pod2text ("mkdir - create a directory", " mkdir <path>\n\nCreate a directory named C<path>.");
321 if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
322 pod2text ("mkdir-p - create a directory and parents", " mkdir-p <path>\n\nCreate a directory named C<path>, creating any parent directories\nas necessary. This is like the C<mkdir -p> shell command.");
324 if (strcasecmp (cmd, "chmod") == 0)
325 pod2text ("chmod - change file mode", " chmod <mode> <path>\n\nChange the mode (permissions) of C<path> to C<mode>. Only\nnumeric modes are supported.");
327 if (strcasecmp (cmd, "chown") == 0)
328 pod2text ("chown - change file owner and group", " chown <owner> <group> <path>\n\nChange the file owner to C<owner> and group to C<group>.\n\nOnly numeric uid and gid are supported. If you want to use\nnames, you will need to locate and parse the password file\nyourself (Augeas support makes this relatively easy).");
330 if (strcasecmp (cmd, "exists") == 0)
331 pod2text ("exists - test if file or directory exists", " exists <path>\n\nThis returns C<true> if and only if there is a file, directory\n(or anything) with the given C<path> name.\n\nSee also C<is_file>, C<is_dir>, C<stat>.");
333 if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
334 pod2text ("is-file - test if file exists", " is-file <path>\n\nThis returns C<true> if and only if there is a file\nwith the given C<path> name. Note that it returns false for\nother objects like directories.\n\nSee also C<stat>.");
336 if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
337 pod2text ("is-dir - test if file exists", " is-dir <path>\n\nThis returns C<true> if and only if there is a directory\nwith the given C<path> name. Note that it returns false for\nother objects like files.\n\nSee also C<stat>.");
339 if (strcasecmp (cmd, "pvcreate") == 0)
340 pod2text ("pvcreate - create an LVM physical volume", " pvcreate <device>\n\nThis creates an LVM physical volume on the named C<device>,\nwhere C<device> should usually be a partition name such\nas C</dev/sda1>.");
342 if (strcasecmp (cmd, "vgcreate") == 0)
343 pod2text ("vgcreate - create an LVM volume group", " vgcreate <volgroup> <physvols>\n\nThis creates an LVM volume group called C<volgroup>\nfrom the non-empty list of physical volumes C<physvols>.");
345 if (strcasecmp (cmd, "lvcreate") == 0)
346 pod2text ("lvcreate - create an LVM volume group", " lvcreate <logvol> <volgroup> <mbytes>\n\nThis creates an LVM volume group called C<logvol>\non the volume group C<volgroup>, with C<size> megabytes.");
348 if (strcasecmp (cmd, "mkfs") == 0)
349 pod2text ("mkfs - make a filesystem", " mkfs <fstype> <device>\n\nThis creates a filesystem on C<device> (usually a partition\nor LVM logical volume). The filesystem type is C<fstype>, for\nexample C<ext3>.");
351 if (strcasecmp (cmd, "sfdisk") == 0)
352 pod2text ("sfdisk - create partitions on a block device", " sfdisk <device> <cyls> <heads> <sectors> <lines>\n\nThis is a direct interface to the L<sfdisk(8)> program for creating\npartitions on block devices.\n\nC<device> should be a block device, for example C</dev/sda>.\n\nC<cyls>, C<heads> and C<sectors> are the number of cylinders, heads\nand sectors on the device, which are passed directly to sfdisk as\nthe I<-C>, I<-H> and I<-S> parameters. If you pass C<0> for any\nof these, then the corresponding parameter is omitted. Usually for\n'large' disks, you can just pass C<0> for these, but for small\n(floppy-sized) disks, sfdisk (or rather, the kernel) cannot work\nout the right geometry and you will need to tell it.\n\nC<lines> is a list of lines that we feed to C<sfdisk>. For more\ninformation refer to the L<sfdisk(8)> manpage.\n\nTo create a single partition occupying the whole disk, you would\npass C<lines> as a single element list, when the single element being\nthe string C<,> (comma).\n\nSee also: C<sfdisk_l>, C<sfdisk_N>\n\nB<This command is dangerous. Without careful use you\ncan easily destroy all your data>.");
354 if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
355 pod2text ("write-file - create a file", " write-file <path> <content> <size>\n\nThis call creates a file called C<path>. The contents of the\nfile is the string C<content> (which can contain any 8 bit data),\nwith length C<size>.\n\nAs a special case, if C<size> is C<0>\nthen the length is calculated using C<strlen> (so in this case\nthe content cannot contain embedded ASCII NULs).\n\nI<NB.> Owing to a bug, writing content containing ASCII NUL\ncharacters does I<not> work, even if the length is specified.\nWe hope to resolve this bug in a future version. In the meantime\nuse C<upload>.\n\nBecause of the message protocol, there is a transfer limit \nof somewhere between 2MB and 4MB. To transfer large files you should use\nFTP.");
357 if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
358 pod2text ("umount - unmount a filesystem", " umount <pathordevice>\n\nThis unmounts the given filesystem. The filesystem may be\nspecified either by its mountpoint (path) or the device which\ncontains the filesystem.\n\nYou can use 'unmount' as an alias for this command.");
360 if (strcasecmp (cmd, "mounts") == 0)
361 pod2text ("mounts - show mounted filesystems", " mounts\n\nThis returns the list of currently mounted filesystems. It returns\nthe list of devices (eg. C</dev/sda1>, C</dev/VG/LV>).\n\nSome internal mounts are not shown.");
363 if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
364 pod2text ("umount-all - unmount all filesystems", " umount-all\n\nThis unmounts all mounted filesystems.\n\nSome internal mounts are not unmounted by this call.\n\nYou can use 'unmount-all' as an alias for this command.");
366 if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
367 pod2text ("lvm-remove-all - remove all LVM LVs, VGs and PVs", " lvm-remove-all\n\nThis command removes all LVM logical volumes, volume groups\nand physical volumes.\n\nB<This command is dangerous. Without careful use you\ncan easily destroy all your data>.");
369 if (strcasecmp (cmd, "file") == 0)
370 pod2text ("file - determine file type", " file <path>\n\nThis call uses the standard L<file(1)> command to determine\nthe type or contents of the file. This also works on devices,\nfor example to find out whether a partition contains a filesystem.\n\nThe exact command which runs is C<file -bsL path>. Note in\nparticular that the filename is not prepended to the output\n(the C<-b> option).");
372 if (strcasecmp (cmd, "command") == 0)
373 pod2text ("command - run a command from the guest filesystem", " command <arguments>\n\nThis call runs a command from the guest filesystem. The\nfilesystem must be mounted, and must contain a compatible\noperating system (ie. something Linux, with the same\nor compatible processor architecture).\n\nThe single parameter is an argv-style list of arguments.\nThe first element is the name of the program to run.\nSubsequent elements are parameters. The list must be\nnon-empty (ie. must contain a program name).\n\nThe return value is anything printed to I<stdout> by\nthe command.\n\nIf the command returns a non-zero exit status, then\nthis function returns an error message. The error message\nstring is the content of I<stderr> from the command.\n\nThe C<$PATH> environment variable will contain at least\nC</usr/bin> and C</bin>. If you require a program from\nanother location, you should provide the full path in the\nfirst parameter.\n\nShared libraries and data files required by the program\nmust be available on filesystems which are mounted in the\ncorrect places. It is the caller's responsibility to ensure\nall filesystems that are needed are mounted at the right\nlocations.\n\nBecause of the message protocol, there is a transfer limit \nof somewhere between 2MB and 4MB. To transfer large files you should use\nFTP.");
375 if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
376 pod2text ("command-lines - run a command, returning lines", " command-lines <arguments>\n\nThis is the same as C<command>, but splits the\nresult into a list of lines.\n\nBecause of the message protocol, there is a transfer limit \nof somewhere between 2MB and 4MB. To transfer large files you should use\nFTP.");
378 if (strcasecmp (cmd, "stat") == 0)
379 pod2text ("stat - get file information", " stat <path>\n\nReturns file information for the given C<path>.\n\nThis is the same as the C<stat(2)> system call.");
381 if (strcasecmp (cmd, "lstat") == 0)
382 pod2text ("lstat - get file information for a symbolic link", " lstat <path>\n\nReturns file information for the given C<path>.\n\nThis is the same as C<stat> except that if C<path>\nis a symbolic link, then the link is stat-ed, not the file it\nrefers to.\n\nThis is the same as the C<lstat(2)> system call.");
384 if (strcasecmp (cmd, "statvfs") == 0)
385 pod2text ("statvfs - get file system statistics", " statvfs <path>\n\nReturns file system statistics for any mounted file system.\nC<path> should be a file or directory in the mounted file system\n(typically it is the mount point itself, but it doesn't need to be).\n\nThis is the same as the C<statvfs(2)> system call.");
387 if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
388 pod2text ("tune2fs-l - get ext2/ext3/ext4 superblock details", " tune2fs-l <device>\n\nThis returns the contents of the ext2, ext3 or ext4 filesystem\nsuperblock on C<device>.\n\nIt is the same as running C<tune2fs -l device>. See L<tune2fs(8)>\nmanpage for more details. The list of fields returned isn't\nclearly defined, and depends on both the version of C<tune2fs>\nthat libguestfs was built against, and the filesystem itself.");
390 if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
391 pod2text ("blockdev-setro - set block device to read-only", " blockdev-setro <device>\n\nSets the block device named C<device> to read-only.\n\nThis uses the L<blockdev(8)> command.");
393 if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
394 pod2text ("blockdev-setrw - set block device to read-write", " blockdev-setrw <device>\n\nSets the block device named C<device> to read-write.\n\nThis uses the L<blockdev(8)> command.");
396 if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
397 pod2text ("blockdev-getro - is block device set to read-only", " blockdev-getro <device>\n\nReturns a boolean indicating if the block device is read-only\n(true if read-only, false if not).\n\nThis uses the L<blockdev(8)> command.");
399 if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
400 pod2text ("blockdev-getss - get sectorsize of block device", " blockdev-getss <device>\n\nThis returns the size of sectors on a block device.\nUsually 512, but can be larger for modern devices.\n\n(Note, this is not the size in sectors, use C<blockdev_getsz>\nfor that).\n\nThis uses the L<blockdev(8)> command.");
402 if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
403 pod2text ("blockdev-getbsz - get blocksize of block device", " blockdev-getbsz <device>\n\nThis returns the block size of a device.\n\n(Note this is different from both I<size in blocks> and\nI<filesystem block size>).\n\nThis uses the L<blockdev(8)> command.");
405 if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
406 pod2text ("blockdev-setbsz - set blocksize of block device", " blockdev-setbsz <device> <blocksize>\n\nThis sets the block size of a device.\n\n(Note this is different from both I<size in blocks> and\nI<filesystem block size>).\n\nThis uses the L<blockdev(8)> command.");
408 if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
409 pod2text ("blockdev-getsz - get total size of device in 512-byte sectors", " blockdev-getsz <device>\n\nThis returns the size of the device in units of 512-byte sectors\n(even if the sectorsize isn't 512 bytes ... weird).\n\nSee also C<blockdev_getss> for the real sector size of\nthe device, and C<blockdev_getsize64> for the more\nuseful I<size in bytes>.\n\nThis uses the L<blockdev(8)> command.");
411 if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
412 pod2text ("blockdev-getsize64 - get total size of device in bytes", " blockdev-getsize64 <device>\n\nThis returns the size of the device in bytes.\n\nSee also C<blockdev_getsz>.\n\nThis uses the L<blockdev(8)> command.");
414 if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
415 pod2text ("blockdev-flushbufs - flush device buffers", " blockdev-flushbufs <device>\n\nThis tells the kernel to flush internal buffers associated\nwith C<device>.\n\nThis uses the L<blockdev(8)> command.");
417 if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
418 pod2text ("blockdev-rereadpt - reread partition table", " blockdev-rereadpt <device>\n\nReread the partition table on C<device>.\n\nThis uses the L<blockdev(8)> command.");
420 if (strcasecmp (cmd, "upload") == 0)
421 pod2text ("upload - upload a file from the local machine", " upload <filename> <remotefilename>\n\nUpload local file C<filename> to C<remotefilename> on the\nfilesystem.\n\nC<filename> can also be a named pipe.\n\nSee also C<download>.");
423 if (strcasecmp (cmd, "download") == 0)
424 pod2text ("download - download a file to the local machine", " download <remotefilename> <filename>\n\nDownload file C<remotefilename> and save it as C<filename>\non the local machine.\n\nC<filename> can also be a named pipe.\n\nSee also C<upload>, C<cat>.");
426 if (strcasecmp (cmd, "checksum") == 0)
427 pod2text ("checksum - compute MD5, SHAx or CRC checksum of file", " checksum <csumtype> <path>\n\nThis call computes the MD5, SHAx or CRC checksum of the\nfile named C<path>.\n\nThe type of checksum to compute is given by the C<csumtype>\nparameter which must have one of the following values:\n\n=over 4\n\n=item C<crc>\n\nCompute the cyclic redundancy check (CRC) specified by POSIX\nfor the C<cksum> command.\n\n=item C<md5>\n\nCompute the MD5 hash (using the C<md5sum> program).\n\n=item C<sha1>\n\nCompute the SHA1 hash (using the C<sha1sum> program).\n\n=item C<sha224>\n\nCompute the SHA224 hash (using the C<sha224sum> program).\n\n=item C<sha256>\n\nCompute the SHA256 hash (using the C<sha256sum> program).\n\n=item C<sha384>\n\nCompute the SHA384 hash (using the C<sha384sum> program).\n\n=item C<sha512>\n\nCompute the SHA512 hash (using the C<sha512sum> program).\n\n=back\n\nThe checksum is returned as a printable string.");
429 if (strcasecmp (cmd, "tar_in") == 0 || strcasecmp (cmd, "tar-in") == 0)
430 pod2text ("tar-in - unpack tarfile to directory", " tar-in <tarfile> <directory>\n\nThis command uploads and unpacks local file C<tarfile> (an\nI<uncompressed> tar file) into C<directory>.\n\nTo upload a compressed tarball, use C<tgz_in>.");
432 if (strcasecmp (cmd, "tar_out") == 0 || strcasecmp (cmd, "tar-out") == 0)
433 pod2text ("tar-out - pack directory into tarfile", " tar-out <directory> <tarfile>\n\nThis command packs the contents of C<directory> and downloads\nit to local file C<tarfile>.\n\nTo download a compressed tarball, use C<tgz_out>.");
435 if (strcasecmp (cmd, "tgz_in") == 0 || strcasecmp (cmd, "tgz-in") == 0)
436 pod2text ("tgz-in - unpack compressed tarball to directory", " tgz-in <tarball> <directory>\n\nThis command uploads and unpacks local file C<tarball> (a\nI<gzip compressed> tar file) into C<directory>.\n\nTo upload an uncompressed tarball, use C<tar_in>.");
438 if (strcasecmp (cmd, "tgz_out") == 0 || strcasecmp (cmd, "tgz-out") == 0)
439 pod2text ("tgz-out - pack directory into compressed tarball", " tgz-out <directory> <tarball>\n\nThis command packs the contents of C<directory> and downloads\nit to local file C<tarball>.\n\nTo download an uncompressed tarball, use C<tar_out>.");
441 if (strcasecmp (cmd, "mount_ro") == 0 || strcasecmp (cmd, "mount-ro") == 0)
442 pod2text ("mount-ro - mount a guest disk, read-only", " mount-ro <device> <mountpoint>\n\nThis is the same as the C<mount> command, but it\nmounts the filesystem with the read-only (I<-o ro>) flag.");
444 if (strcasecmp (cmd, "mount_options") == 0 || strcasecmp (cmd, "mount-options") == 0)
445 pod2text ("mount-options - mount a guest disk with mount options", " mount-options <options> <device> <mountpoint>\n\nThis is the same as the C<mount> command, but it\nallows you to set the mount options as for the\nL<mount(8)> I<-o> flag.");
447 if (strcasecmp (cmd, "mount_vfs") == 0 || strcasecmp (cmd, "mount-vfs") == 0)
448 pod2text ("mount-vfs - mount a guest disk with mount options and vfstype", " mount-vfs <options> <vfstype> <device> <mountpoint>\n\nThis is the same as the C<mount> command, but it\nallows you to set both the mount options and the vfstype\nas for the L<mount(8)> I<-o> and I<-t> flags.");
450 if (strcasecmp (cmd, "debug") == 0)
451 pod2text ("debug - debugging and internals", " debug <subcmd> <extraargs>\n\nThe C<debug> command exposes some internals of\nC<guestfsd> (the guestfs daemon) that runs inside the\nqemu subprocess.\n\nThere is no comprehensive help for this command. You have\nto look at the file C<daemon/debug.c> in the libguestfs source\nto find out what you can do.");
453 if (strcasecmp (cmd, "lvremove") == 0)
454 pod2text ("lvremove - remove an LVM logical volume", " lvremove <device>\n\nRemove an LVM logical volume C<device>, where C<device> is\nthe path to the LV, such as C</dev/VG/LV>.\n\nYou can also remove all LVs in a volume group by specifying\nthe VG name, C</dev/VG>.");
456 if (strcasecmp (cmd, "vgremove") == 0)
457 pod2text ("vgremove - remove an LVM volume group", " vgremove <vgname>\n\nRemove an LVM volume group C<vgname>, (for example C<VG>).\n\nThis also forcibly removes all logical volumes in the volume\ngroup (if any).");
459 if (strcasecmp (cmd, "pvremove") == 0)
460 pod2text ("pvremove - remove an LVM physical volume", " pvremove <device>\n\nThis wipes a physical volume C<device> so that LVM will no longer\nrecognise it.\n\nThe implementation uses the C<pvremove> command which refuses to\nwipe physical volumes that contain any volume groups, so you have\nto remove those first.");
462 if (strcasecmp (cmd, "set_e2label") == 0 || strcasecmp (cmd, "set-e2label") == 0)
463 pod2text ("set-e2label - set the ext2/3/4 filesystem label", " set-e2label <device> <label>\n\nThis sets the ext2/3/4 filesystem label of the filesystem on\nC<device> to C<label>. Filesystem labels are limited to\n16 characters.\n\nYou can use either C<tune2fs_l> or C<get_e2label>\nto return the existing label on a filesystem.");
465 if (strcasecmp (cmd, "get_e2label") == 0 || strcasecmp (cmd, "get-e2label") == 0)
466 pod2text ("get-e2label - get the ext2/3/4 filesystem label", " get-e2label <device>\n\nThis returns the ext2/3/4 filesystem label of the filesystem on\nC<device>.");
468 if (strcasecmp (cmd, "set_e2uuid") == 0 || strcasecmp (cmd, "set-e2uuid") == 0)
469 pod2text ("set-e2uuid - set the ext2/3/4 filesystem UUID", " set-e2uuid <device> <uuid>\n\nThis sets the ext2/3/4 filesystem UUID of the filesystem on\nC<device> to C<uuid>. The format of the UUID and alternatives\nsuch as C<clear>, C<random> and C<time> are described in the\nL<tune2fs(8)> manpage.\n\nYou can use either C<tune2fs_l> or C<get_e2uuid>\nto return the existing UUID of a filesystem.");
471 if (strcasecmp (cmd, "get_e2uuid") == 0 || strcasecmp (cmd, "get-e2uuid") == 0)
472 pod2text ("get-e2uuid - get the ext2/3/4 filesystem UUID", " get-e2uuid <device>\n\nThis returns the ext2/3/4 filesystem UUID of the filesystem on\nC<device>.");
474 if (strcasecmp (cmd, "fsck") == 0)
475 pod2text ("fsck - run the filesystem checker", " fsck <fstype> <device>\n\nThis runs the filesystem checker (fsck) on C<device> which\nshould have filesystem type C<fstype>.\n\nThe returned integer is the status. See L<fsck(8)> for the\nlist of status codes from C<fsck>.\n\nNotes:\n\n=over 4\n\n=item *\n\nMultiple status codes can be summed together.\n\n=item *\n\nA non-zero return code can mean \"success\", for example if\nerrors have been corrected on the filesystem.\n\n=item *\n\nChecking or repairing NTFS volumes is not supported\n(by linux-ntfs).\n\n=back\n\nThis command is entirely equivalent to running C<fsck -a -t fstype device>.");
477 if (strcasecmp (cmd, "zero") == 0)
478 pod2text ("zero - write zeroes to the device", " zero <device>\n\nThis command writes zeroes over the first few blocks of C<device>.\n\nHow many blocks are zeroed isn't specified (but it's I<not> enough\nto securely wipe the device). It should be sufficient to remove\nany partition tables, filesystem superblocks and so on.");
480 if (strcasecmp (cmd, "grub_install") == 0 || strcasecmp (cmd, "grub-install") == 0)
481 pod2text ("grub-install - install GRUB", " grub-install <root> <device>\n\nThis command installs GRUB (the Grand Unified Bootloader) on\nC<device>, with the root directory being C<root>.");
483 if (strcasecmp (cmd, "cp") == 0)
484 pod2text ("cp - copy a file", " cp <src> <dest>\n\nThis copies a file from C<src> to C<dest> where C<dest> is\neither a destination filename or destination directory.");
486 if (strcasecmp (cmd, "cp_a") == 0 || strcasecmp (cmd, "cp-a") == 0)
487 pod2text ("cp-a - copy a file or directory recursively", " cp-a <src> <dest>\n\nThis copies a file or directory from C<src> to C<dest>\nrecursively using the C<cp -a> command.");
489 if (strcasecmp (cmd, "mv") == 0)
490 pod2text ("mv - move a file", " mv <src> <dest>\n\nThis moves a file from C<src> to C<dest> where C<dest> is\neither a destination filename or destination directory.");
492 if (strcasecmp (cmd, "drop_caches") == 0 || strcasecmp (cmd, "drop-caches") == 0)
493 pod2text ("drop-caches - drop kernel page cache, dentries and inodes", " drop-caches <whattodrop>\n\nThis instructs the guest kernel to drop its page cache,\nand/or dentries and inode caches. The parameter C<whattodrop>\ntells the kernel what precisely to drop, see\nL<http://linux-mm.org/Drop_Caches>\n\nSetting C<whattodrop> to 3 should drop everything.\n\nThis automatically calls L<sync(2)> before the operation,\nso that the maximum guest memory is freed.");
495 if (strcasecmp (cmd, "dmesg") == 0)
496 pod2text ("dmesg - return kernel messages", " dmesg\n\nThis returns the kernel messages (C<dmesg> output) from\nthe guest kernel. This is sometimes useful for extended\ndebugging of problems.\n\nAnother way to get the same information is to enable\nverbose messages with C<set_verbose> or by setting\nthe environment variable C<LIBGUESTFS_DEBUG=1> before\nrunning the program.");
498 if (strcasecmp (cmd, "ping_daemon") == 0 || strcasecmp (cmd, "ping-daemon") == 0)
499 pod2text ("ping-daemon - ping the guest daemon", " ping-daemon\n\nThis is a test probe into the guestfs daemon running inside\nthe qemu subprocess. Calling this function checks that the\ndaemon responds to the ping message, without affecting the daemon\nor attached block device(s) in any other way.");
501 if (strcasecmp (cmd, "equal") == 0)
502 pod2text ("equal - test if two files have equal contents", " equal <file1> <file2>\n\nThis compares the two files C<file1> and C<file2> and returns\ntrue if their content is exactly equal, or false otherwise.\n\nThe external L<cmp(1)> program is used for the comparison.");
504 if (strcasecmp (cmd, "strings") == 0)
505 pod2text ("strings - print the printable strings in a file", " strings <path>\n\nThis runs the L<strings(1)> command on a file and returns\nthe list of printable strings found.\n\nBecause of the message protocol, there is a transfer limit \nof somewhere between 2MB and 4MB. To transfer large files you should use\nFTP.");
507 if (strcasecmp (cmd, "strings_e") == 0 || strcasecmp (cmd, "strings-e") == 0)
508 pod2text ("strings-e - print the printable strings in a file", " strings-e <encoding> <path>\n\nThis is like the C<strings> command, but allows you to\nspecify the encoding.\n\nSee the L<strings(1)> manpage for the full list of encodings.\n\nCommonly useful encodings are C<l> (lower case L) which will\nshow strings inside Windows/x86 files.\n\nThe returned strings are transcoded to UTF-8.\n\nBecause of the message protocol, there is a transfer limit \nof somewhere between 2MB and 4MB. To transfer large files you should use\nFTP.");
510 if (strcasecmp (cmd, "hexdump") == 0)
511 pod2text ("hexdump - dump a file in hexadecimal", " hexdump <path>\n\nThis runs C<hexdump -C> on the given C<path>. The result is\nthe human-readable, canonical hex dump of the file.\n\nBecause of the message protocol, there is a transfer limit \nof somewhere between 2MB and 4MB. To transfer large files you should use\nFTP.");
513 if (strcasecmp (cmd, "zerofree") == 0)
514 pod2text ("zerofree - zero unused inodes and disk blocks on ext2/3 filesystem", " zerofree <device>\n\nThis runs the I<zerofree> program on C<device>. This program\nclaims to zero unused inodes and disk blocks on an ext2/3\nfilesystem, thus making it possible to compress the filesystem\nmore effectively.\n\nYou should B<not> run this program if the filesystem is\nmounted.\n\nIt is possible that using this program can damage the filesystem\nor data on the filesystem.");
516 if (strcasecmp (cmd, "pvresize") == 0)
517 pod2text ("pvresize - resize an LVM physical volume", " pvresize <device>\n\nThis resizes (expands or shrinks) an existing LVM physical\nvolume to match the new size of the underlying device.");
519 if (strcasecmp (cmd, "sfdisk_N") == 0 || strcasecmp (cmd, "sfdisk-N") == 0)
520 pod2text ("sfdisk-N - modify a single partition on a block device", " sfdisk-N <device> <n> <cyls> <heads> <sectors> <line>\n\nThis runs L<sfdisk(8)> option to modify just the single\npartition C<n> (note: C<n> counts from 1).\n\nFor other parameters, see C<sfdisk>. You should usually\npass C<0> for the cyls/heads/sectors parameters.\n\nB<This command is dangerous. Without careful use you\ncan easily destroy all your data>.");
522 if (strcasecmp (cmd, "sfdisk_l") == 0 || strcasecmp (cmd, "sfdisk-l") == 0)
523 pod2text ("sfdisk-l - display the partition table", " sfdisk-l <device>\n\nThis displays the partition table on C<device>, in the\nhuman-readable output of the L<sfdisk(8)> command. It is\nnot intended to be parsed.");
525 if (strcasecmp (cmd, "sfdisk_kernel_geometry") == 0 || strcasecmp (cmd, "sfdisk-kernel-geometry") == 0)
526 pod2text ("sfdisk-kernel-geometry - display the kernel geometry", " sfdisk-kernel-geometry <device>\n\nThis displays the kernel's idea of the geometry of C<device>.\n\nThe result is in human-readable format, and not designed to\nbe parsed.");
528 if (strcasecmp (cmd, "sfdisk_disk_geometry") == 0 || strcasecmp (cmd, "sfdisk-disk-geometry") == 0)
529 pod2text ("sfdisk-disk-geometry - display the disk geometry from the partition table", " sfdisk-disk-geometry <device>\n\nThis displays the disk geometry of C<device> read from the\npartition table. Especially in the case where the underlying\nblock device has been resized, this can be different from the\nkernel's idea of the geometry (see C<sfdisk_kernel_geometry>).\n\nThe result is in human-readable format, and not designed to\nbe parsed.");
531 if (strcasecmp (cmd, "vg_activate_all") == 0 || strcasecmp (cmd, "vg-activate-all") == 0)
532 pod2text ("vg-activate-all - activate or deactivate all volume groups", " vg-activate-all <activate>\n\nThis command activates or (if C<activate> is false) deactivates\nall logical volumes in all volume groups.\nIf activated, then they are made known to the\nkernel, ie. they appear as C</dev/mapper> devices. If deactivated,\nthen those devices disappear.\n\nThis command is the same as running C<vgchange -a y|n>");
534 if (strcasecmp (cmd, "vg_activate") == 0 || strcasecmp (cmd, "vg-activate") == 0)
535 pod2text ("vg-activate - activate or deactivate some volume groups", " vg-activate <activate> <volgroups>\n\nThis command activates or (if C<activate> is false) deactivates\nall logical volumes in the listed volume groups C<volgroups>.\nIf activated, then they are made known to the\nkernel, ie. they appear as C</dev/mapper> devices. If deactivated,\nthen those devices disappear.\n\nThis command is the same as running C<vgchange -a y|n volgroups...>\n\nNote that if C<volgroups> is an empty list then B<all> volume groups\nare activated or deactivated.");
537 if (strcasecmp (cmd, "lvresize") == 0)
538 pod2text ("lvresize - resize an LVM logical volume", " lvresize <device> <mbytes>\n\nThis resizes (expands or shrinks) an existing LVM logical\nvolume to C<mbytes>. When reducing, data in the reduced part\nis lost.");
540 if (strcasecmp (cmd, "resize2fs") == 0)
541 pod2text ("resize2fs - resize an ext2/ext3 filesystem", " resize2fs <device>\n\nThis resizes an ext2 or ext3 filesystem to match the size of\nthe underlying device.");
543 display_builtin_command (cmd);
546 static void print_pv (struct guestfs_lvm_pv *pv)
550 printf ("pv_name: %s\n", pv->pv_name);
551 printf ("pv_uuid: ");
552 for (i = 0; i < 32; ++i)
553 printf ("%c", pv->pv_uuid[i]);
555 printf ("pv_fmt: %s\n", pv->pv_fmt);
556 printf ("pv_size: %" PRIu64 "\n", pv->pv_size);
557 printf ("dev_size: %" PRIu64 "\n", pv->dev_size);
558 printf ("pv_free: %" PRIu64 "\n", pv->pv_free);
559 printf ("pv_used: %" PRIu64 "\n", pv->pv_used);
560 printf ("pv_attr: %s\n", pv->pv_attr);
561 printf ("pv_pe_count: %" PRIi64 "\n", pv->pv_pe_count);
562 printf ("pv_pe_alloc_count: %" PRIi64 "\n", pv->pv_pe_alloc_count);
563 printf ("pv_tags: %s\n", pv->pv_tags);
564 printf ("pe_start: %" PRIu64 "\n", pv->pe_start);
565 printf ("pv_mda_count: %" PRIi64 "\n", pv->pv_mda_count);
566 printf ("pv_mda_free: %" PRIu64 "\n", pv->pv_mda_free);
569 static void print_pv_list (struct guestfs_lvm_pv_list *pvs)
573 for (i = 0; i < pvs->len; ++i)
574 print_pv (&pvs->val[i]);
577 static void print_vg (struct guestfs_lvm_vg *vg)
581 printf ("vg_name: %s\n", vg->vg_name);
582 printf ("vg_uuid: ");
583 for (i = 0; i < 32; ++i)
584 printf ("%c", vg->vg_uuid[i]);
586 printf ("vg_fmt: %s\n", vg->vg_fmt);
587 printf ("vg_attr: %s\n", vg->vg_attr);
588 printf ("vg_size: %" PRIu64 "\n", vg->vg_size);
589 printf ("vg_free: %" PRIu64 "\n", vg->vg_free);
590 printf ("vg_sysid: %s\n", vg->vg_sysid);
591 printf ("vg_extent_size: %" PRIu64 "\n", vg->vg_extent_size);
592 printf ("vg_extent_count: %" PRIi64 "\n", vg->vg_extent_count);
593 printf ("vg_free_count: %" PRIi64 "\n", vg->vg_free_count);
594 printf ("max_lv: %" PRIi64 "\n", vg->max_lv);
595 printf ("max_pv: %" PRIi64 "\n", vg->max_pv);
596 printf ("pv_count: %" PRIi64 "\n", vg->pv_count);
597 printf ("lv_count: %" PRIi64 "\n", vg->lv_count);
598 printf ("snap_count: %" PRIi64 "\n", vg->snap_count);
599 printf ("vg_seqno: %" PRIi64 "\n", vg->vg_seqno);
600 printf ("vg_tags: %s\n", vg->vg_tags);
601 printf ("vg_mda_count: %" PRIi64 "\n", vg->vg_mda_count);
602 printf ("vg_mda_free: %" PRIu64 "\n", vg->vg_mda_free);
605 static void print_vg_list (struct guestfs_lvm_vg_list *vgs)
609 for (i = 0; i < vgs->len; ++i)
610 print_vg (&vgs->val[i]);
613 static void print_lv (struct guestfs_lvm_lv *lv)
617 printf ("lv_name: %s\n", lv->lv_name);
618 printf ("lv_uuid: ");
619 for (i = 0; i < 32; ++i)
620 printf ("%c", lv->lv_uuid[i]);
622 printf ("lv_attr: %s\n", lv->lv_attr);
623 printf ("lv_major: %" PRIi64 "\n", lv->lv_major);
624 printf ("lv_minor: %" PRIi64 "\n", lv->lv_minor);
625 printf ("lv_kernel_major: %" PRIi64 "\n", lv->lv_kernel_major);
626 printf ("lv_kernel_minor: %" PRIi64 "\n", lv->lv_kernel_minor);
627 printf ("lv_size: %" PRIu64 "\n", lv->lv_size);
628 printf ("seg_count: %" PRIi64 "\n", lv->seg_count);
629 printf ("origin: %s\n", lv->origin);
630 if (lv->snap_percent >= 0) printf ("snap_percent: %g %%\n", lv->snap_percent);
631 else printf ("snap_percent: \n");
632 if (lv->copy_percent >= 0) printf ("copy_percent: %g %%\n", lv->copy_percent);
633 else printf ("copy_percent: \n");
634 printf ("move_pv: %s\n", lv->move_pv);
635 printf ("lv_tags: %s\n", lv->lv_tags);
636 printf ("mirror_log: %s\n", lv->mirror_log);
637 printf ("modules: %s\n", lv->modules);
640 static void print_lv_list (struct guestfs_lvm_lv_list *lvs)
644 for (i = 0; i < lvs->len; ++i)
645 print_lv (&lvs->val[i]);
648 static void print_stat (struct guestfs_stat *stat)
650 printf ("dev: %" PRIi64 "\n", stat->dev);
651 printf ("ino: %" PRIi64 "\n", stat->ino);
652 printf ("mode: %" PRIi64 "\n", stat->mode);
653 printf ("nlink: %" PRIi64 "\n", stat->nlink);
654 printf ("uid: %" PRIi64 "\n", stat->uid);
655 printf ("gid: %" PRIi64 "\n", stat->gid);
656 printf ("rdev: %" PRIi64 "\n", stat->rdev);
657 printf ("size: %" PRIi64 "\n", stat->size);
658 printf ("blksize: %" PRIi64 "\n", stat->blksize);
659 printf ("blocks: %" PRIi64 "\n", stat->blocks);
660 printf ("atime: %" PRIi64 "\n", stat->atime);
661 printf ("mtime: %" PRIi64 "\n", stat->mtime);
662 printf ("ctime: %" PRIi64 "\n", stat->ctime);
665 static void print_statvfs (struct guestfs_statvfs *statvfs)
667 printf ("bsize: %" PRIi64 "\n", statvfs->bsize);
668 printf ("frsize: %" PRIi64 "\n", statvfs->frsize);
669 printf ("blocks: %" PRIi64 "\n", statvfs->blocks);
670 printf ("bfree: %" PRIi64 "\n", statvfs->bfree);
671 printf ("bavail: %" PRIi64 "\n", statvfs->bavail);
672 printf ("files: %" PRIi64 "\n", statvfs->files);
673 printf ("ffree: %" PRIi64 "\n", statvfs->ffree);
674 printf ("favail: %" PRIi64 "\n", statvfs->favail);
675 printf ("fsid: %" PRIi64 "\n", statvfs->fsid);
676 printf ("flag: %" PRIi64 "\n", statvfs->flag);
677 printf ("namemax: %" PRIi64 "\n", statvfs->namemax);
680 static int run_launch (const char *cmd, int argc, char *argv[])
684 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
685 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
692 static int run_kill_subprocess (const char *cmd, int argc, char *argv[])
696 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
697 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
700 r = guestfs_kill_subprocess (g);
704 static int run_add_drive (const char *cmd, int argc, char *argv[])
707 const char *filename;
709 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
710 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
714 r = guestfs_add_drive (g, filename);
718 static int run_add_cdrom (const char *cmd, int argc, char *argv[])
721 const char *filename;
723 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
724 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
728 r = guestfs_add_cdrom (g, filename);
732 static int run_config (const char *cmd, int argc, char *argv[])
735 const char *qemuparam;
736 const char *qemuvalue;
738 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
739 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
743 qemuvalue = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
744 r = guestfs_config (g, qemuparam, qemuvalue);
748 static int run_set_qemu (const char *cmd, int argc, char *argv[])
753 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
754 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
758 r = guestfs_set_qemu (g, qemu);
762 static int run_get_qemu (const char *cmd, int argc, char *argv[])
766 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
767 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
770 r = guestfs_get_qemu (g);
771 if (r == NULL) return -1;
776 static int run_set_path (const char *cmd, int argc, char *argv[])
781 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
782 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
786 r = guestfs_set_path (g, path);
790 static int run_get_path (const char *cmd, int argc, char *argv[])
794 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
795 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
798 r = guestfs_get_path (g);
799 if (r == NULL) return -1;
804 static int run_set_append (const char *cmd, int argc, char *argv[])
809 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
810 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
814 r = guestfs_set_append (g, append);
818 static int run_get_append (const char *cmd, int argc, char *argv[])
822 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
823 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
826 r = guestfs_get_append (g);
827 if (r == NULL) return -1;
832 static int run_set_autosync (const char *cmd, int argc, char *argv[])
837 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
838 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
841 autosync = is_true (argv[0]) ? 1 : 0;
842 r = guestfs_set_autosync (g, autosync);
846 static int run_get_autosync (const char *cmd, int argc, char *argv[])
850 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
851 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
854 r = guestfs_get_autosync (g);
855 if (r == -1) return -1;
856 if (r) printf ("true\n"); else printf ("false\n");
860 static int run_set_verbose (const char *cmd, int argc, char *argv[])
865 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
866 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
869 verbose = is_true (argv[0]) ? 1 : 0;
870 r = guestfs_set_verbose (g, verbose);
874 static int run_get_verbose (const char *cmd, int argc, char *argv[])
878 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
879 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
882 r = guestfs_get_verbose (g);
883 if (r == -1) return -1;
884 if (r) printf ("true\n"); else printf ("false\n");
888 static int run_is_ready (const char *cmd, int argc, char *argv[])
892 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
893 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
896 r = guestfs_is_ready (g);
897 if (r == -1) return -1;
898 if (r) printf ("true\n"); else printf ("false\n");
902 static int run_is_config (const char *cmd, int argc, char *argv[])
906 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
907 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
910 r = guestfs_is_config (g);
911 if (r == -1) return -1;
912 if (r) printf ("true\n"); else printf ("false\n");
916 static int run_is_launching (const char *cmd, int argc, char *argv[])
920 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
921 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
924 r = guestfs_is_launching (g);
925 if (r == -1) return -1;
926 if (r) printf ("true\n"); else printf ("false\n");
930 static int run_is_busy (const char *cmd, int argc, char *argv[])
934 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
935 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
938 r = guestfs_is_busy (g);
939 if (r == -1) return -1;
940 if (r) printf ("true\n"); else printf ("false\n");
944 static int run_get_state (const char *cmd, int argc, char *argv[])
948 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
949 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
952 r = guestfs_get_state (g);
953 if (r == -1) return -1;
958 static int run_mount (const char *cmd, int argc, char *argv[])
962 const char *mountpoint;
964 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
965 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
969 mountpoint = argv[1];
970 r = guestfs_mount (g, device, mountpoint);
974 static int run_sync (const char *cmd, int argc, char *argv[])
978 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
979 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
982 r = guestfs_sync (g);
986 static int run_touch (const char *cmd, int argc, char *argv[])
991 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
992 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
996 r = guestfs_touch (g, path);
1000 static int run_cat (const char *cmd, int argc, char *argv[])
1005 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1006 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1010 r = guestfs_cat (g, path);
1011 if (r == NULL) return -1;
1017 static int run_ll (const char *cmd, int argc, char *argv[])
1020 const char *directory;
1022 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1023 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1026 directory = argv[0];
1027 r = guestfs_ll (g, directory);
1028 if (r == NULL) return -1;
1034 static int run_ls (const char *cmd, int argc, char *argv[])
1037 const char *directory;
1039 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1040 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1043 directory = argv[0];
1044 r = guestfs_ls (g, directory);
1045 if (r == NULL) return -1;
1051 static int run_list_devices (const char *cmd, int argc, char *argv[])
1055 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1056 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1059 r = guestfs_list_devices (g);
1060 if (r == NULL) return -1;
1066 static int run_list_partitions (const char *cmd, int argc, char *argv[])
1070 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1071 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1074 r = guestfs_list_partitions (g);
1075 if (r == NULL) return -1;
1081 static int run_pvs (const char *cmd, int argc, char *argv[])
1085 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1086 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1089 r = guestfs_pvs (g);
1090 if (r == NULL) return -1;
1096 static int run_vgs (const char *cmd, int argc, char *argv[])
1100 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1101 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1104 r = guestfs_vgs (g);
1105 if (r == NULL) return -1;
1111 static int run_lvs (const char *cmd, int argc, char *argv[])
1115 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1116 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1119 r = guestfs_lvs (g);
1120 if (r == NULL) return -1;
1126 static int run_pvs_full (const char *cmd, int argc, char *argv[])
1128 struct guestfs_lvm_pv_list *r;
1130 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1131 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1134 r = guestfs_pvs_full (g);
1135 if (r == NULL) return -1;
1137 guestfs_free_lvm_pv_list (r);
1141 static int run_vgs_full (const char *cmd, int argc, char *argv[])
1143 struct guestfs_lvm_vg_list *r;
1145 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1146 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1149 r = guestfs_vgs_full (g);
1150 if (r == NULL) return -1;
1152 guestfs_free_lvm_vg_list (r);
1156 static int run_lvs_full (const char *cmd, int argc, char *argv[])
1158 struct guestfs_lvm_lv_list *r;
1160 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1161 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1164 r = guestfs_lvs_full (g);
1165 if (r == NULL) return -1;
1167 guestfs_free_lvm_lv_list (r);
1171 static int run_read_lines (const char *cmd, int argc, char *argv[])
1176 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1177 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1181 r = guestfs_read_lines (g, path);
1182 if (r == NULL) return -1;
1188 static int run_aug_init (const char *cmd, int argc, char *argv[])
1194 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1195 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1199 flags = atoi (argv[1]);
1200 r = guestfs_aug_init (g, root, flags);
1204 static int run_aug_close (const char *cmd, int argc, char *argv[])
1208 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1209 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1212 r = guestfs_aug_close (g);
1216 static int run_aug_defvar (const char *cmd, int argc, char *argv[])
1222 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1223 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1227 expr = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
1228 r = guestfs_aug_defvar (g, name, expr);
1229 if (r == -1) return -1;
1234 static int run_aug_defnode (const char *cmd, int argc, char *argv[])
1236 struct guestfs_int_bool *r;
1241 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1242 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1248 r = guestfs_aug_defnode (g, name, expr, val);
1249 if (r == NULL) return -1;
1250 printf ("%d, %s\n", r->i,
1251 r->b ? "true" : "false");
1252 guestfs_free_int_bool (r);
1256 static int run_aug_get (const char *cmd, int argc, char *argv[])
1261 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1262 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1266 r = guestfs_aug_get (g, path);
1267 if (r == NULL) return -1;
1273 static int run_aug_set (const char *cmd, int argc, char *argv[])
1279 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1280 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1285 r = guestfs_aug_set (g, path, val);
1289 static int run_aug_insert (const char *cmd, int argc, char *argv[])
1296 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1297 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1302 before = is_true (argv[2]) ? 1 : 0;
1303 r = guestfs_aug_insert (g, path, label, before);
1307 static int run_aug_rm (const char *cmd, int argc, char *argv[])
1312 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1313 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1317 r = guestfs_aug_rm (g, path);
1318 if (r == -1) return -1;
1323 static int run_aug_mv (const char *cmd, int argc, char *argv[])
1329 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1330 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1335 r = guestfs_aug_mv (g, src, dest);
1339 static int run_aug_match (const char *cmd, int argc, char *argv[])
1344 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1345 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1349 r = guestfs_aug_match (g, path);
1350 if (r == NULL) return -1;
1356 static int run_aug_save (const char *cmd, int argc, char *argv[])
1360 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1361 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1364 r = guestfs_aug_save (g);
1368 static int run_aug_load (const char *cmd, int argc, char *argv[])
1372 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1373 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1376 r = guestfs_aug_load (g);
1380 static int run_aug_ls (const char *cmd, int argc, char *argv[])
1385 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1386 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1390 r = guestfs_aug_ls (g, path);
1391 if (r == NULL) return -1;
1397 static int run_rm (const char *cmd, int argc, char *argv[])
1402 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1403 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1407 r = guestfs_rm (g, path);
1411 static int run_rmdir (const char *cmd, int argc, char *argv[])
1416 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1417 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1421 r = guestfs_rmdir (g, path);
1425 static int run_rm_rf (const char *cmd, int argc, char *argv[])
1430 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1431 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1435 r = guestfs_rm_rf (g, path);
1439 static int run_mkdir (const char *cmd, int argc, char *argv[])
1444 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1445 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1449 r = guestfs_mkdir (g, path);
1453 static int run_mkdir_p (const char *cmd, int argc, char *argv[])
1458 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1459 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1463 r = guestfs_mkdir_p (g, path);
1467 static int run_chmod (const char *cmd, int argc, char *argv[])
1473 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1474 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1477 mode = atoi (argv[0]);
1479 r = guestfs_chmod (g, mode, path);
1483 static int run_chown (const char *cmd, int argc, char *argv[])
1490 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1491 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1494 owner = atoi (argv[0]);
1495 group = atoi (argv[1]);
1497 r = guestfs_chown (g, owner, group, path);
1501 static int run_exists (const char *cmd, int argc, char *argv[])
1506 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1507 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1511 r = guestfs_exists (g, path);
1512 if (r == -1) return -1;
1513 if (r) printf ("true\n"); else printf ("false\n");
1517 static int run_is_file (const char *cmd, int argc, char *argv[])
1522 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1523 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1527 r = guestfs_is_file (g, path);
1528 if (r == -1) return -1;
1529 if (r) printf ("true\n"); else printf ("false\n");
1533 static int run_is_dir (const char *cmd, int argc, char *argv[])
1538 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1539 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1543 r = guestfs_is_dir (g, path);
1544 if (r == -1) return -1;
1545 if (r) printf ("true\n"); else printf ("false\n");
1549 static int run_pvcreate (const char *cmd, int argc, char *argv[])
1554 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1555 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1559 r = guestfs_pvcreate (g, device);
1563 static int run_vgcreate (const char *cmd, int argc, char *argv[])
1566 const char *volgroup;
1569 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1570 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1574 physvols = parse_string_list (argv[1]);
1575 r = guestfs_vgcreate (g, volgroup, physvols);
1579 static int run_lvcreate (const char *cmd, int argc, char *argv[])
1583 const char *volgroup;
1586 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1587 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1592 mbytes = atoi (argv[2]);
1593 r = guestfs_lvcreate (g, logvol, volgroup, mbytes);
1597 static int run_mkfs (const char *cmd, int argc, char *argv[])
1603 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1604 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1609 r = guestfs_mkfs (g, fstype, device);
1613 static int run_sfdisk (const char *cmd, int argc, char *argv[])
1622 fprintf (stderr, "%s should have 5 parameter(s)\n", cmd);
1623 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1627 cyls = atoi (argv[1]);
1628 heads = atoi (argv[2]);
1629 sectors = atoi (argv[3]);
1630 lines = parse_string_list (argv[4]);
1631 r = guestfs_sfdisk (g, device, cyls, heads, sectors, lines);
1635 static int run_write_file (const char *cmd, int argc, char *argv[])
1639 const char *content;
1642 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1643 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1648 size = atoi (argv[2]);
1649 r = guestfs_write_file (g, path, content, size);
1653 static int run_umount (const char *cmd, int argc, char *argv[])
1656 const char *pathordevice;
1658 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1659 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1662 pathordevice = argv[0];
1663 r = guestfs_umount (g, pathordevice);
1667 static int run_mounts (const char *cmd, int argc, char *argv[])
1671 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1672 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1675 r = guestfs_mounts (g);
1676 if (r == NULL) return -1;
1682 static int run_umount_all (const char *cmd, int argc, char *argv[])
1686 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1687 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1690 r = guestfs_umount_all (g);
1694 static int run_lvm_remove_all (const char *cmd, int argc, char *argv[])
1698 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1699 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1702 r = guestfs_lvm_remove_all (g);
1706 static int run_file (const char *cmd, int argc, char *argv[])
1711 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1712 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1716 r = guestfs_file (g, path);
1717 if (r == NULL) return -1;
1723 static int run_command (const char *cmd, int argc, char *argv[])
1728 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1729 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1732 arguments = parse_string_list (argv[0]);
1733 r = guestfs_command (g, arguments);
1734 if (r == NULL) return -1;
1740 static int run_command_lines (const char *cmd, int argc, char *argv[])
1745 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1746 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1749 arguments = parse_string_list (argv[0]);
1750 r = guestfs_command_lines (g, arguments);
1751 if (r == NULL) return -1;
1757 static int run_stat (const char *cmd, int argc, char *argv[])
1759 struct guestfs_stat *r;
1762 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1763 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1767 r = guestfs_stat (g, path);
1768 if (r == NULL) return -1;
1774 static int run_lstat (const char *cmd, int argc, char *argv[])
1776 struct guestfs_stat *r;
1779 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1780 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1784 r = guestfs_lstat (g, path);
1785 if (r == NULL) return -1;
1791 static int run_statvfs (const char *cmd, int argc, char *argv[])
1793 struct guestfs_statvfs *r;
1796 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1797 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1801 r = guestfs_statvfs (g, path);
1802 if (r == NULL) return -1;
1808 static int run_tune2fs_l (const char *cmd, int argc, char *argv[])
1813 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1814 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1818 r = guestfs_tune2fs_l (g, device);
1819 if (r == NULL) return -1;
1825 static int run_blockdev_setro (const char *cmd, int argc, char *argv[])
1830 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1831 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1835 r = guestfs_blockdev_setro (g, device);
1839 static int run_blockdev_setrw (const char *cmd, int argc, char *argv[])
1844 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1845 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1849 r = guestfs_blockdev_setrw (g, device);
1853 static int run_blockdev_getro (const char *cmd, int argc, char *argv[])
1858 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1859 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1863 r = guestfs_blockdev_getro (g, device);
1864 if (r == -1) return -1;
1865 if (r) printf ("true\n"); else printf ("false\n");
1869 static int run_blockdev_getss (const char *cmd, int argc, char *argv[])
1874 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1875 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1879 r = guestfs_blockdev_getss (g, device);
1880 if (r == -1) return -1;
1885 static int run_blockdev_getbsz (const char *cmd, int argc, char *argv[])
1890 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1891 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1895 r = guestfs_blockdev_getbsz (g, device);
1896 if (r == -1) return -1;
1901 static int run_blockdev_setbsz (const char *cmd, int argc, char *argv[])
1907 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1908 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1912 blocksize = atoi (argv[1]);
1913 r = guestfs_blockdev_setbsz (g, device, blocksize);
1917 static int run_blockdev_getsz (const char *cmd, int argc, char *argv[])
1922 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1923 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1927 r = guestfs_blockdev_getsz (g, device);
1928 if (r == -1) return -1;
1929 printf ("%" PRIi64 "\n", r);
1933 static int run_blockdev_getsize64 (const char *cmd, int argc, char *argv[])
1938 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1939 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1943 r = guestfs_blockdev_getsize64 (g, device);
1944 if (r == -1) return -1;
1945 printf ("%" PRIi64 "\n", r);
1949 static int run_blockdev_flushbufs (const char *cmd, int argc, char *argv[])
1954 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1955 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1959 r = guestfs_blockdev_flushbufs (g, device);
1963 static int run_blockdev_rereadpt (const char *cmd, int argc, char *argv[])
1968 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1969 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1973 r = guestfs_blockdev_rereadpt (g, device);
1977 static int run_upload (const char *cmd, int argc, char *argv[])
1980 const char *filename;
1981 const char *remotefilename;
1983 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1984 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1987 filename = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
1988 remotefilename = argv[1];
1989 r = guestfs_upload (g, filename, remotefilename);
1993 static int run_download (const char *cmd, int argc, char *argv[])
1996 const char *remotefilename;
1997 const char *filename;
1999 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2000 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2003 remotefilename = argv[0];
2004 filename = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
2005 r = guestfs_download (g, remotefilename, filename);
2009 static int run_checksum (const char *cmd, int argc, char *argv[])
2012 const char *csumtype;
2015 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2016 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2021 r = guestfs_checksum (g, csumtype, path);
2022 if (r == NULL) return -1;
2028 static int run_tar_in (const char *cmd, int argc, char *argv[])
2031 const char *tarfile;
2032 const char *directory;
2034 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2035 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2038 tarfile = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
2039 directory = argv[1];
2040 r = guestfs_tar_in (g, tarfile, directory);
2044 static int run_tar_out (const char *cmd, int argc, char *argv[])
2047 const char *directory;
2048 const char *tarfile;
2050 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2051 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2054 directory = argv[0];
2055 tarfile = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
2056 r = guestfs_tar_out (g, directory, tarfile);
2060 static int run_tgz_in (const char *cmd, int argc, char *argv[])
2063 const char *tarball;
2064 const char *directory;
2066 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2067 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2070 tarball = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
2071 directory = argv[1];
2072 r = guestfs_tgz_in (g, tarball, directory);
2076 static int run_tgz_out (const char *cmd, int argc, char *argv[])
2079 const char *directory;
2080 const char *tarball;
2082 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2083 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2086 directory = argv[0];
2087 tarball = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
2088 r = guestfs_tgz_out (g, directory, tarball);
2092 static int run_mount_ro (const char *cmd, int argc, char *argv[])
2096 const char *mountpoint;
2098 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2099 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2103 mountpoint = argv[1];
2104 r = guestfs_mount_ro (g, device, mountpoint);
2108 static int run_mount_options (const char *cmd, int argc, char *argv[])
2111 const char *options;
2113 const char *mountpoint;
2115 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
2116 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2121 mountpoint = argv[2];
2122 r = guestfs_mount_options (g, options, device, mountpoint);
2126 static int run_mount_vfs (const char *cmd, int argc, char *argv[])
2129 const char *options;
2130 const char *vfstype;
2132 const char *mountpoint;
2134 fprintf (stderr, "%s should have 4 parameter(s)\n", cmd);
2135 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2141 mountpoint = argv[3];
2142 r = guestfs_mount_vfs (g, options, vfstype, device, mountpoint);
2146 static int run_debug (const char *cmd, int argc, char *argv[])
2152 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2153 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2157 extraargs = parse_string_list (argv[1]);
2158 r = guestfs_debug (g, subcmd, extraargs);
2159 if (r == NULL) return -1;
2165 static int run_lvremove (const char *cmd, int argc, char *argv[])
2170 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2171 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2175 r = guestfs_lvremove (g, device);
2179 static int run_vgremove (const char *cmd, int argc, char *argv[])
2184 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2185 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2189 r = guestfs_vgremove (g, vgname);
2193 static int run_pvremove (const char *cmd, int argc, char *argv[])
2198 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2199 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2203 r = guestfs_pvremove (g, device);
2207 static int run_set_e2label (const char *cmd, int argc, char *argv[])
2213 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2214 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2219 r = guestfs_set_e2label (g, device, label);
2223 static int run_get_e2label (const char *cmd, int argc, char *argv[])
2228 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2229 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2233 r = guestfs_get_e2label (g, device);
2234 if (r == NULL) return -1;
2240 static int run_set_e2uuid (const char *cmd, int argc, char *argv[])
2246 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2247 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2252 r = guestfs_set_e2uuid (g, device, uuid);
2256 static int run_get_e2uuid (const char *cmd, int argc, char *argv[])
2261 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2262 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2266 r = guestfs_get_e2uuid (g, device);
2267 if (r == NULL) return -1;
2273 static int run_fsck (const char *cmd, int argc, char *argv[])
2279 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2280 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2285 r = guestfs_fsck (g, fstype, device);
2286 if (r == -1) return -1;
2291 static int run_zero (const char *cmd, int argc, char *argv[])
2296 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2297 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2301 r = guestfs_zero (g, device);
2305 static int run_grub_install (const char *cmd, int argc, char *argv[])
2311 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2312 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2317 r = guestfs_grub_install (g, root, device);
2321 static int run_cp (const char *cmd, int argc, char *argv[])
2327 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2328 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2333 r = guestfs_cp (g, src, dest);
2337 static int run_cp_a (const char *cmd, int argc, char *argv[])
2343 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2344 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2349 r = guestfs_cp_a (g, src, dest);
2353 static int run_mv (const char *cmd, int argc, char *argv[])
2359 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2360 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2365 r = guestfs_mv (g, src, dest);
2369 static int run_drop_caches (const char *cmd, int argc, char *argv[])
2374 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2375 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2378 whattodrop = atoi (argv[0]);
2379 r = guestfs_drop_caches (g, whattodrop);
2383 static int run_dmesg (const char *cmd, int argc, char *argv[])
2387 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
2388 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2391 r = guestfs_dmesg (g);
2392 if (r == NULL) return -1;
2398 static int run_ping_daemon (const char *cmd, int argc, char *argv[])
2402 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
2403 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2406 r = guestfs_ping_daemon (g);
2410 static int run_equal (const char *cmd, int argc, char *argv[])
2416 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2417 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2422 r = guestfs_equal (g, file1, file2);
2423 if (r == -1) return -1;
2424 if (r) printf ("true\n"); else printf ("false\n");
2428 static int run_strings (const char *cmd, int argc, char *argv[])
2433 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2434 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2438 r = guestfs_strings (g, path);
2439 if (r == NULL) return -1;
2445 static int run_strings_e (const char *cmd, int argc, char *argv[])
2448 const char *encoding;
2451 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2452 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2457 r = guestfs_strings_e (g, encoding, path);
2458 if (r == NULL) return -1;
2464 static int run_hexdump (const char *cmd, int argc, char *argv[])
2469 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2470 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2474 r = guestfs_hexdump (g, path);
2475 if (r == NULL) return -1;
2481 static int run_zerofree (const char *cmd, int argc, char *argv[])
2486 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2487 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2491 r = guestfs_zerofree (g, device);
2495 static int run_pvresize (const char *cmd, int argc, char *argv[])
2500 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2501 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2505 r = guestfs_pvresize (g, device);
2509 static int run_sfdisk_N (const char *cmd, int argc, char *argv[])
2519 fprintf (stderr, "%s should have 6 parameter(s)\n", cmd);
2520 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2525 cyls = atoi (argv[2]);
2526 heads = atoi (argv[3]);
2527 sectors = atoi (argv[4]);
2529 r = guestfs_sfdisk_N (g, device, n, cyls, heads, sectors, line);
2533 static int run_sfdisk_l (const char *cmd, int argc, char *argv[])
2538 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2539 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2543 r = guestfs_sfdisk_l (g, device);
2544 if (r == NULL) return -1;
2550 static int run_sfdisk_kernel_geometry (const char *cmd, int argc, char *argv[])
2555 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2556 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2560 r = guestfs_sfdisk_kernel_geometry (g, device);
2561 if (r == NULL) return -1;
2567 static int run_sfdisk_disk_geometry (const char *cmd, int argc, char *argv[])
2572 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2573 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2577 r = guestfs_sfdisk_disk_geometry (g, device);
2578 if (r == NULL) return -1;
2584 static int run_vg_activate_all (const char *cmd, int argc, char *argv[])
2589 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2590 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2593 activate = is_true (argv[0]) ? 1 : 0;
2594 r = guestfs_vg_activate_all (g, activate);
2598 static int run_vg_activate (const char *cmd, int argc, char *argv[])
2604 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2605 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2608 activate = is_true (argv[0]) ? 1 : 0;
2609 volgroups = parse_string_list (argv[1]);
2610 r = guestfs_vg_activate (g, activate, volgroups);
2614 static int run_lvresize (const char *cmd, int argc, char *argv[])
2620 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2621 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2625 mbytes = atoi (argv[1]);
2626 r = guestfs_lvresize (g, device, mbytes);
2630 static int run_resize2fs (const char *cmd, int argc, char *argv[])
2635 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2636 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2640 r = guestfs_resize2fs (g, device);
2644 int run_action (const char *cmd, int argc, char *argv[])
2646 if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
2647 return run_launch (cmd, argc, argv);
2649 if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
2650 return run_kill_subprocess (cmd, argc, argv);
2652 if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
2653 return run_add_drive (cmd, argc, argv);
2655 if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
2656 return run_add_cdrom (cmd, argc, argv);
2658 if (strcasecmp (cmd, "config") == 0)
2659 return run_config (cmd, argc, argv);
2661 if (strcasecmp (cmd, "set_qemu") == 0 || strcasecmp (cmd, "set-qemu") == 0 || strcasecmp (cmd, "qemu") == 0)
2662 return run_set_qemu (cmd, argc, argv);
2664 if (strcasecmp (cmd, "get_qemu") == 0 || strcasecmp (cmd, "get-qemu") == 0)
2665 return run_get_qemu (cmd, argc, argv);
2667 if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
2668 return run_set_path (cmd, argc, argv);
2670 if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
2671 return run_get_path (cmd, argc, argv);
2673 if (strcasecmp (cmd, "set_append") == 0 || strcasecmp (cmd, "set-append") == 0 || strcasecmp (cmd, "append") == 0)
2674 return run_set_append (cmd, argc, argv);
2676 if (strcasecmp (cmd, "get_append") == 0 || strcasecmp (cmd, "get-append") == 0)
2677 return run_get_append (cmd, argc, argv);
2679 if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
2680 return run_set_autosync (cmd, argc, argv);
2682 if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
2683 return run_get_autosync (cmd, argc, argv);
2685 if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
2686 return run_set_verbose (cmd, argc, argv);
2688 if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
2689 return run_get_verbose (cmd, argc, argv);
2691 if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
2692 return run_is_ready (cmd, argc, argv);
2694 if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
2695 return run_is_config (cmd, argc, argv);
2697 if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
2698 return run_is_launching (cmd, argc, argv);
2700 if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
2701 return run_is_busy (cmd, argc, argv);
2703 if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
2704 return run_get_state (cmd, argc, argv);
2706 if (strcasecmp (cmd, "mount") == 0)
2707 return run_mount (cmd, argc, argv);
2709 if (strcasecmp (cmd, "sync") == 0)
2710 return run_sync (cmd, argc, argv);
2712 if (strcasecmp (cmd, "touch") == 0)
2713 return run_touch (cmd, argc, argv);
2715 if (strcasecmp (cmd, "cat") == 0)
2716 return run_cat (cmd, argc, argv);
2718 if (strcasecmp (cmd, "ll") == 0)
2719 return run_ll (cmd, argc, argv);
2721 if (strcasecmp (cmd, "ls") == 0)
2722 return run_ls (cmd, argc, argv);
2724 if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
2725 return run_list_devices (cmd, argc, argv);
2727 if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
2728 return run_list_partitions (cmd, argc, argv);
2730 if (strcasecmp (cmd, "pvs") == 0)
2731 return run_pvs (cmd, argc, argv);
2733 if (strcasecmp (cmd, "vgs") == 0)
2734 return run_vgs (cmd, argc, argv);
2736 if (strcasecmp (cmd, "lvs") == 0)
2737 return run_lvs (cmd, argc, argv);
2739 if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
2740 return run_pvs_full (cmd, argc, argv);
2742 if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
2743 return run_vgs_full (cmd, argc, argv);
2745 if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
2746 return run_lvs_full (cmd, argc, argv);
2748 if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
2749 return run_read_lines (cmd, argc, argv);
2751 if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
2752 return run_aug_init (cmd, argc, argv);
2754 if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
2755 return run_aug_close (cmd, argc, argv);
2757 if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
2758 return run_aug_defvar (cmd, argc, argv);
2760 if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
2761 return run_aug_defnode (cmd, argc, argv);
2763 if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
2764 return run_aug_get (cmd, argc, argv);
2766 if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
2767 return run_aug_set (cmd, argc, argv);
2769 if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
2770 return run_aug_insert (cmd, argc, argv);
2772 if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
2773 return run_aug_rm (cmd, argc, argv);
2775 if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
2776 return run_aug_mv (cmd, argc, argv);
2778 if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
2779 return run_aug_match (cmd, argc, argv);
2781 if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
2782 return run_aug_save (cmd, argc, argv);
2784 if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
2785 return run_aug_load (cmd, argc, argv);
2787 if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
2788 return run_aug_ls (cmd, argc, argv);
2790 if (strcasecmp (cmd, "rm") == 0)
2791 return run_rm (cmd, argc, argv);
2793 if (strcasecmp (cmd, "rmdir") == 0)
2794 return run_rmdir (cmd, argc, argv);
2796 if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
2797 return run_rm_rf (cmd, argc, argv);
2799 if (strcasecmp (cmd, "mkdir") == 0)
2800 return run_mkdir (cmd, argc, argv);
2802 if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
2803 return run_mkdir_p (cmd, argc, argv);
2805 if (strcasecmp (cmd, "chmod") == 0)
2806 return run_chmod (cmd, argc, argv);
2808 if (strcasecmp (cmd, "chown") == 0)
2809 return run_chown (cmd, argc, argv);
2811 if (strcasecmp (cmd, "exists") == 0)
2812 return run_exists (cmd, argc, argv);
2814 if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
2815 return run_is_file (cmd, argc, argv);
2817 if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
2818 return run_is_dir (cmd, argc, argv);
2820 if (strcasecmp (cmd, "pvcreate") == 0)
2821 return run_pvcreate (cmd, argc, argv);
2823 if (strcasecmp (cmd, "vgcreate") == 0)
2824 return run_vgcreate (cmd, argc, argv);
2826 if (strcasecmp (cmd, "lvcreate") == 0)
2827 return run_lvcreate (cmd, argc, argv);
2829 if (strcasecmp (cmd, "mkfs") == 0)
2830 return run_mkfs (cmd, argc, argv);
2832 if (strcasecmp (cmd, "sfdisk") == 0)
2833 return run_sfdisk (cmd, argc, argv);
2835 if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
2836 return run_write_file (cmd, argc, argv);
2838 if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
2839 return run_umount (cmd, argc, argv);
2841 if (strcasecmp (cmd, "mounts") == 0)
2842 return run_mounts (cmd, argc, argv);
2844 if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
2845 return run_umount_all (cmd, argc, argv);
2847 if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
2848 return run_lvm_remove_all (cmd, argc, argv);
2850 if (strcasecmp (cmd, "file") == 0)
2851 return run_file (cmd, argc, argv);
2853 if (strcasecmp (cmd, "command") == 0)
2854 return run_command (cmd, argc, argv);
2856 if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
2857 return run_command_lines (cmd, argc, argv);
2859 if (strcasecmp (cmd, "stat") == 0)
2860 return run_stat (cmd, argc, argv);
2862 if (strcasecmp (cmd, "lstat") == 0)
2863 return run_lstat (cmd, argc, argv);
2865 if (strcasecmp (cmd, "statvfs") == 0)
2866 return run_statvfs (cmd, argc, argv);
2868 if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
2869 return run_tune2fs_l (cmd, argc, argv);
2871 if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
2872 return run_blockdev_setro (cmd, argc, argv);
2874 if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
2875 return run_blockdev_setrw (cmd, argc, argv);
2877 if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
2878 return run_blockdev_getro (cmd, argc, argv);
2880 if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
2881 return run_blockdev_getss (cmd, argc, argv);
2883 if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
2884 return run_blockdev_getbsz (cmd, argc, argv);
2886 if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
2887 return run_blockdev_setbsz (cmd, argc, argv);
2889 if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
2890 return run_blockdev_getsz (cmd, argc, argv);
2892 if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
2893 return run_blockdev_getsize64 (cmd, argc, argv);
2895 if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
2896 return run_blockdev_flushbufs (cmd, argc, argv);
2898 if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
2899 return run_blockdev_rereadpt (cmd, argc, argv);
2901 if (strcasecmp (cmd, "upload") == 0)
2902 return run_upload (cmd, argc, argv);
2904 if (strcasecmp (cmd, "download") == 0)
2905 return run_download (cmd, argc, argv);
2907 if (strcasecmp (cmd, "checksum") == 0)
2908 return run_checksum (cmd, argc, argv);
2910 if (strcasecmp (cmd, "tar_in") == 0 || strcasecmp (cmd, "tar-in") == 0)
2911 return run_tar_in (cmd, argc, argv);
2913 if (strcasecmp (cmd, "tar_out") == 0 || strcasecmp (cmd, "tar-out") == 0)
2914 return run_tar_out (cmd, argc, argv);
2916 if (strcasecmp (cmd, "tgz_in") == 0 || strcasecmp (cmd, "tgz-in") == 0)
2917 return run_tgz_in (cmd, argc, argv);
2919 if (strcasecmp (cmd, "tgz_out") == 0 || strcasecmp (cmd, "tgz-out") == 0)
2920 return run_tgz_out (cmd, argc, argv);
2922 if (strcasecmp (cmd, "mount_ro") == 0 || strcasecmp (cmd, "mount-ro") == 0)
2923 return run_mount_ro (cmd, argc, argv);
2925 if (strcasecmp (cmd, "mount_options") == 0 || strcasecmp (cmd, "mount-options") == 0)
2926 return run_mount_options (cmd, argc, argv);
2928 if (strcasecmp (cmd, "mount_vfs") == 0 || strcasecmp (cmd, "mount-vfs") == 0)
2929 return run_mount_vfs (cmd, argc, argv);
2931 if (strcasecmp (cmd, "debug") == 0)
2932 return run_debug (cmd, argc, argv);
2934 if (strcasecmp (cmd, "lvremove") == 0)
2935 return run_lvremove (cmd, argc, argv);
2937 if (strcasecmp (cmd, "vgremove") == 0)
2938 return run_vgremove (cmd, argc, argv);
2940 if (strcasecmp (cmd, "pvremove") == 0)
2941 return run_pvremove (cmd, argc, argv);
2943 if (strcasecmp (cmd, "set_e2label") == 0 || strcasecmp (cmd, "set-e2label") == 0)
2944 return run_set_e2label (cmd, argc, argv);
2946 if (strcasecmp (cmd, "get_e2label") == 0 || strcasecmp (cmd, "get-e2label") == 0)
2947 return run_get_e2label (cmd, argc, argv);
2949 if (strcasecmp (cmd, "set_e2uuid") == 0 || strcasecmp (cmd, "set-e2uuid") == 0)
2950 return run_set_e2uuid (cmd, argc, argv);
2952 if (strcasecmp (cmd, "get_e2uuid") == 0 || strcasecmp (cmd, "get-e2uuid") == 0)
2953 return run_get_e2uuid (cmd, argc, argv);
2955 if (strcasecmp (cmd, "fsck") == 0)
2956 return run_fsck (cmd, argc, argv);
2958 if (strcasecmp (cmd, "zero") == 0)
2959 return run_zero (cmd, argc, argv);
2961 if (strcasecmp (cmd, "grub_install") == 0 || strcasecmp (cmd, "grub-install") == 0)
2962 return run_grub_install (cmd, argc, argv);
2964 if (strcasecmp (cmd, "cp") == 0)
2965 return run_cp (cmd, argc, argv);
2967 if (strcasecmp (cmd, "cp_a") == 0 || strcasecmp (cmd, "cp-a") == 0)
2968 return run_cp_a (cmd, argc, argv);
2970 if (strcasecmp (cmd, "mv") == 0)
2971 return run_mv (cmd, argc, argv);
2973 if (strcasecmp (cmd, "drop_caches") == 0 || strcasecmp (cmd, "drop-caches") == 0)
2974 return run_drop_caches (cmd, argc, argv);
2976 if (strcasecmp (cmd, "dmesg") == 0)
2977 return run_dmesg (cmd, argc, argv);
2979 if (strcasecmp (cmd, "ping_daemon") == 0 || strcasecmp (cmd, "ping-daemon") == 0)
2980 return run_ping_daemon (cmd, argc, argv);
2982 if (strcasecmp (cmd, "equal") == 0)
2983 return run_equal (cmd, argc, argv);
2985 if (strcasecmp (cmd, "strings") == 0)
2986 return run_strings (cmd, argc, argv);
2988 if (strcasecmp (cmd, "strings_e") == 0 || strcasecmp (cmd, "strings-e") == 0)
2989 return run_strings_e (cmd, argc, argv);
2991 if (strcasecmp (cmd, "hexdump") == 0)
2992 return run_hexdump (cmd, argc, argv);
2994 if (strcasecmp (cmd, "zerofree") == 0)
2995 return run_zerofree (cmd, argc, argv);
2997 if (strcasecmp (cmd, "pvresize") == 0)
2998 return run_pvresize (cmd, argc, argv);
3000 if (strcasecmp (cmd, "sfdisk_N") == 0 || strcasecmp (cmd, "sfdisk-N") == 0)
3001 return run_sfdisk_N (cmd, argc, argv);
3003 if (strcasecmp (cmd, "sfdisk_l") == 0 || strcasecmp (cmd, "sfdisk-l") == 0)
3004 return run_sfdisk_l (cmd, argc, argv);
3006 if (strcasecmp (cmd, "sfdisk_kernel_geometry") == 0 || strcasecmp (cmd, "sfdisk-kernel-geometry") == 0)
3007 return run_sfdisk_kernel_geometry (cmd, argc, argv);
3009 if (strcasecmp (cmd, "sfdisk_disk_geometry") == 0 || strcasecmp (cmd, "sfdisk-disk-geometry") == 0)
3010 return run_sfdisk_disk_geometry (cmd, argc, argv);
3012 if (strcasecmp (cmd, "vg_activate_all") == 0 || strcasecmp (cmd, "vg-activate-all") == 0)
3013 return run_vg_activate_all (cmd, argc, argv);
3015 if (strcasecmp (cmd, "vg_activate") == 0 || strcasecmp (cmd, "vg-activate") == 0)
3016 return run_vg_activate (cmd, argc, argv);
3018 if (strcasecmp (cmd, "lvresize") == 0)
3019 return run_lvresize (cmd, argc, argv);
3021 if (strcasecmp (cmd, "resize2fs") == 0)
3022 return run_resize2fs (cmd, argc, argv);
3025 fprintf (stderr, "%s: unknown command\n", cmd);