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", "add-drive-ro", "add a drive in snapshot mode (read-only)");
37 printf ("%-20s %s\n", "aug-close", "close the current Augeas handle");
38 printf ("%-20s %s\n", "aug-defnode", "define an Augeas node");
39 printf ("%-20s %s\n", "aug-defvar", "define an Augeas variable");
40 printf ("%-20s %s\n", "aug-get", "look up the value of an Augeas path");
41 printf ("%-20s %s\n", "aug-init", "create a new Augeas handle");
42 printf ("%-20s %s\n", "aug-insert", "insert a sibling Augeas node");
43 printf ("%-20s %s\n", "aug-load", "load files into the tree");
44 printf ("%-20s %s\n", "aug-ls", "list Augeas nodes under a path");
45 printf ("%-20s %s\n", "aug-match", "return Augeas nodes which match path");
46 printf ("%-20s %s\n", "aug-mv", "move Augeas node");
47 printf ("%-20s %s\n", "aug-rm", "remove an Augeas path");
48 printf ("%-20s %s\n", "aug-save", "write all pending Augeas changes to disk");
49 printf ("%-20s %s\n", "aug-set", "set Augeas path to value");
50 printf ("%-20s %s\n", "blockdev-flushbufs", "flush device buffers");
51 printf ("%-20s %s\n", "blockdev-getbsz", "get blocksize of block device");
52 printf ("%-20s %s\n", "blockdev-getro", "is block device set to read-only");
53 printf ("%-20s %s\n", "blockdev-getsize64", "get total size of device in bytes");
54 printf ("%-20s %s\n", "blockdev-getss", "get sectorsize of block device");
55 printf ("%-20s %s\n", "blockdev-getsz", "get total size of device in 512-byte sectors");
56 printf ("%-20s %s\n", "blockdev-rereadpt", "reread partition table");
57 printf ("%-20s %s\n", "blockdev-setbsz", "set blocksize of block device");
58 printf ("%-20s %s\n", "blockdev-setro", "set block device to read-only");
59 printf ("%-20s %s\n", "blockdev-setrw", "set block device to read-write");
60 printf ("%-20s %s\n", "cat", "list the contents of a file");
61 printf ("%-20s %s\n", "checksum", "compute MD5, SHAx or CRC checksum of file");
62 printf ("%-20s %s\n", "chmod", "change file mode");
63 printf ("%-20s %s\n", "chown", "change file owner and group");
64 printf ("%-20s %s\n", "command", "run a command from the guest filesystem");
65 printf ("%-20s %s\n", "command-lines", "run a command, returning lines");
66 printf ("%-20s %s\n", "config", "add qemu parameters");
67 printf ("%-20s %s\n", "cp", "copy a file");
68 printf ("%-20s %s\n", "cp-a", "copy a file or directory recursively");
69 printf ("%-20s %s\n", "debug", "debugging and internals");
70 printf ("%-20s %s\n", "dmesg", "return kernel messages");
71 printf ("%-20s %s\n", "download", "download a file to the local machine");
72 printf ("%-20s %s\n", "drop-caches", "drop kernel page cache, dentries and inodes");
73 printf ("%-20s %s\n", "e2fsck-f", "check an ext2/ext3 filesystem");
74 printf ("%-20s %s\n", "equal", "test if two files have equal contents");
75 printf ("%-20s %s\n", "exists", "test if file or directory exists");
76 printf ("%-20s %s\n", "file", "determine file type");
77 printf ("%-20s %s\n", "find", "find all files and directories");
78 printf ("%-20s %s\n", "fsck", "run the filesystem checker");
79 printf ("%-20s %s\n", "get-append", "get the additional kernel options");
80 printf ("%-20s %s\n", "get-autosync", "get autosync mode");
81 printf ("%-20s %s\n", "get-e2label", "get the ext2/3/4 filesystem label");
82 printf ("%-20s %s\n", "get-e2uuid", "get the ext2/3/4 filesystem UUID");
83 printf ("%-20s %s\n", "get-path", "get the search path");
84 printf ("%-20s %s\n", "get-qemu", "get the qemu binary");
85 printf ("%-20s %s\n", "get-state", "get the current state");
86 printf ("%-20s %s\n", "get-verbose", "get verbose mode");
87 printf ("%-20s %s\n", "grub-install", "install GRUB");
88 printf ("%-20s %s\n", "hexdump", "dump a file in hexadecimal");
89 printf ("%-20s %s\n", "is-busy", "is busy processing a command");
90 printf ("%-20s %s\n", "is-config", "is in configuration state");
91 printf ("%-20s %s\n", "is-dir", "test if file exists");
92 printf ("%-20s %s\n", "is-file", "test if file exists");
93 printf ("%-20s %s\n", "is-launching", "is launching subprocess");
94 printf ("%-20s %s\n", "is-ready", "is ready to accept commands");
95 printf ("%-20s %s\n", "kill-subprocess", "kill the qemu subprocess");
96 printf ("%-20s %s\n", "launch", "launch the qemu subprocess");
97 printf ("%-20s %s\n", "list-devices", "list the block devices");
98 printf ("%-20s %s\n", "list-partitions", "list the partitions");
99 printf ("%-20s %s\n", "ll", "list the files in a directory (long format)");
100 printf ("%-20s %s\n", "ls", "list the files in a directory");
101 printf ("%-20s %s\n", "lstat", "get file information for a symbolic link");
102 printf ("%-20s %s\n", "lvcreate", "create an LVM volume group");
103 printf ("%-20s %s\n", "lvm-remove-all", "remove all LVM LVs, VGs and PVs");
104 printf ("%-20s %s\n", "lvremove", "remove an LVM logical volume");
105 printf ("%-20s %s\n", "lvresize", "resize an LVM logical volume");
106 printf ("%-20s %s\n", "lvs", "list the LVM logical volumes (LVs)");
107 printf ("%-20s %s\n", "lvs-full", "list the LVM logical volumes (LVs)");
108 printf ("%-20s %s\n", "mkdir", "create a directory");
109 printf ("%-20s %s\n", "mkdir-p", "create a directory and parents");
110 printf ("%-20s %s\n", "mkfs", "make a filesystem");
111 printf ("%-20s %s\n", "mount", "mount a guest disk at a position in the filesystem");
112 printf ("%-20s %s\n", "mount-options", "mount a guest disk with mount options");
113 printf ("%-20s %s\n", "mount-ro", "mount a guest disk, read-only");
114 printf ("%-20s %s\n", "mount-vfs", "mount a guest disk with mount options and vfstype");
115 printf ("%-20s %s\n", "mounts", "show mounted filesystems");
116 printf ("%-20s %s\n", "mv", "move a file");
117 printf ("%-20s %s\n", "ping-daemon", "ping the guest daemon");
118 printf ("%-20s %s\n", "pvcreate", "create an LVM physical volume");
119 printf ("%-20s %s\n", "pvremove", "remove an LVM physical volume");
120 printf ("%-20s %s\n", "pvresize", "resize an LVM physical volume");
121 printf ("%-20s %s\n", "pvs", "list the LVM physical volumes (PVs)");
122 printf ("%-20s %s\n", "pvs-full", "list the LVM physical volumes (PVs)");
123 printf ("%-20s %s\n", "read-lines", "read file as lines");
124 printf ("%-20s %s\n", "resize2fs", "resize an ext2/ext3 filesystem");
125 printf ("%-20s %s\n", "rm", "remove a file");
126 printf ("%-20s %s\n", "rm-rf", "remove a file or directory recursively");
127 printf ("%-20s %s\n", "rmdir", "remove a directory");
128 printf ("%-20s %s\n", "set-append", "add options to kernel command line");
129 printf ("%-20s %s\n", "set-autosync", "set autosync mode");
130 printf ("%-20s %s\n", "set-e2label", "set the ext2/3/4 filesystem label");
131 printf ("%-20s %s\n", "set-e2uuid", "set the ext2/3/4 filesystem UUID");
132 printf ("%-20s %s\n", "set-path", "set the search path");
133 printf ("%-20s %s\n", "set-qemu", "set the qemu binary");
134 printf ("%-20s %s\n", "set-verbose", "set verbose mode");
135 printf ("%-20s %s\n", "sfdisk", "create partitions on a block device");
136 printf ("%-20s %s\n", "sfdisk-N", "modify a single partition on a block device");
137 printf ("%-20s %s\n", "sfdisk-disk-geometry", "display the disk geometry from the partition table");
138 printf ("%-20s %s\n", "sfdisk-kernel-geometry", "display the kernel geometry");
139 printf ("%-20s %s\n", "sfdisk-l", "display the partition table");
140 printf ("%-20s %s\n", "sleep", "sleep for some seconds");
141 printf ("%-20s %s\n", "stat", "get file information");
142 printf ("%-20s %s\n", "statvfs", "get file system statistics");
143 printf ("%-20s %s\n", "strings", "print the printable strings in a file");
144 printf ("%-20s %s\n", "strings-e", "print the printable strings in a file");
145 printf ("%-20s %s\n", "sync", "sync disks, writes are flushed through to the disk image");
146 printf ("%-20s %s\n", "tar-in", "unpack tarfile to directory");
147 printf ("%-20s %s\n", "tar-out", "pack directory into tarfile");
148 printf ("%-20s %s\n", "tgz-in", "unpack compressed tarball to directory");
149 printf ("%-20s %s\n", "tgz-out", "pack directory into compressed tarball");
150 printf ("%-20s %s\n", "touch", "update file timestamps or create a new file");
151 printf ("%-20s %s\n", "tune2fs-l", "get ext2/ext3/ext4 superblock details");
152 printf ("%-20s %s\n", "umount", "unmount a filesystem");
153 printf ("%-20s %s\n", "umount-all", "unmount all filesystems");
154 printf ("%-20s %s\n", "upload", "upload a file from the local machine");
155 printf ("%-20s %s\n", "vg-activate", "activate or deactivate some volume groups");
156 printf ("%-20s %s\n", "vg-activate-all", "activate or deactivate all volume groups");
157 printf ("%-20s %s\n", "vgcreate", "create an LVM volume group");
158 printf ("%-20s %s\n", "vgremove", "remove an LVM volume group");
159 printf ("%-20s %s\n", "vgs", "list the LVM volume groups (VGs)");
160 printf ("%-20s %s\n", "vgs-full", "list the LVM volume groups (VGs)");
161 printf ("%-20s %s\n", "write-file", "create a file");
162 printf ("%-20s %s\n", "zero", "write zeroes to the device");
163 printf ("%-20s %s\n", "zerofree", "zero unused inodes and disk blocks on ext2/3 filesystem");
164 printf (" Use -h <cmd> / help <cmd> to show detailed help for a command.\n");
167 void display_command (const char *cmd)
169 if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
170 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.");
172 if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
173 pod2text ("kill-subprocess - kill the qemu subprocess", " kill-subprocess\n\nThis kills the qemu subprocess. You should never need to call this.");
175 if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
176 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\nNote that this call checks for the existence of C<filename>. This\nstops you from specifying other types of drive which are supported\nby qemu such as C<nbd:> and C<http:> URLs. To specify those, use\nthe general C<config> call instead.\n\nYou can use 'add' as an alias for this command.");
178 if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
179 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\nNote that this call checks for the existence of C<filename>. This\nstops you from specifying other types of drive which are supported\nby qemu such as C<nbd:> and C<http:> URLs. To specify those, use\nthe general C<config> call instead.\n\nYou can use 'cdrom' as an alias for this command.");
181 if (strcasecmp (cmd, "add_drive_ro") == 0 || strcasecmp (cmd, "add-drive-ro") == 0 || strcasecmp (cmd, "add-ro") == 0)
182 pod2text ("add-drive-ro - add a drive in snapshot mode (read-only)", " add-drive-ro <filename>\n\nThis adds a drive in snapshot mode, making it effectively\nread-only.\n\nNote that writes to the device are allowed, and will be seen for\nthe duration of the guestfs handle, but they are written\nto a temporary file which is discarded as soon as the guestfs\nhandle is closed. We don't currently have any method to enable\nchanges to be committed, although qemu can support this.\n\nThis is equivalent to the qemu parameter\nC<-drive file=filename,snapshot=on>.\n\nNote that this call checks for the existence of C<filename>. This\nstops you from specifying other types of drive which are supported\nby qemu such as C<nbd:> and C<http:> URLs. To specify those, use\nthe general C<config> call instead.\n\nYou can use 'add-ro' as an alias for this command.");
184 if (strcasecmp (cmd, "config") == 0)
185 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.");
187 if (strcasecmp (cmd, "set_qemu") == 0 || strcasecmp (cmd, "set-qemu") == 0 || strcasecmp (cmd, "qemu") == 0)
188 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.");
190 if (strcasecmp (cmd, "get_qemu") == 0 || strcasecmp (cmd, "get-qemu") == 0)
191 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.");
193 if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
194 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.");
196 if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
197 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.");
199 if (strcasecmp (cmd, "set_append") == 0 || strcasecmp (cmd, "set-append") == 0 || strcasecmp (cmd, "append") == 0)
200 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.");
202 if (strcasecmp (cmd, "get_append") == 0 || strcasecmp (cmd, "get-append") == 0)
203 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.");
205 if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
206 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.");
208 if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
209 pod2text ("get-autosync - get autosync mode", " get-autosync\n\nGet the autosync flag.");
211 if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
212 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.");
214 if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
215 pod2text ("get-verbose - get verbose mode", " get-verbose\n\nThis returns the verbose messages flag.");
217 if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
218 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)>.");
220 if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
221 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)>.");
223 if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
224 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)>.");
226 if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
227 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)>.");
229 if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
230 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)>.");
232 if (strcasecmp (cmd, "mount") == 0)
233 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.");
235 if (strcasecmp (cmd, "sync") == 0)
236 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.");
238 if (strcasecmp (cmd, "touch") == 0)
239 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.");
241 if (strcasecmp (cmd, "cat") == 0)
242 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.");
244 if (strcasecmp (cmd, "ll") == 0)
245 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.");
247 if (strcasecmp (cmd, "ls") == 0)
248 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.");
250 if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
251 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>");
253 if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
254 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>.");
256 if (strcasecmp (cmd, "pvs") == 0)
257 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>.");
259 if (strcasecmp (cmd, "vgs") == 0)
260 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>.");
262 if (strcasecmp (cmd, "lvs") == 0)
263 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>.");
265 if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
266 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.");
268 if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
269 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.");
271 if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
272 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.");
274 if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
275 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.");
277 if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
278 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/>.");
280 if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
281 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.");
283 if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
284 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.");
286 if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
287 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.");
289 if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
290 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.");
292 if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
293 pod2text ("aug-set - set Augeas path to value", " aug-set <path> <val>\n\nSet the value associated with C<path> to C<value>.");
295 if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
296 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]>.");
298 if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
299 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.");
301 if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
302 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.");
304 if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
305 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.");
307 if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
308 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.");
310 if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
311 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.");
313 if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
314 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.");
316 if (strcasecmp (cmd, "rm") == 0)
317 pod2text ("rm - remove a file", " rm <path>\n\nRemove the single file C<path>.");
319 if (strcasecmp (cmd, "rmdir") == 0)
320 pod2text ("rmdir - remove a directory", " rmdir <path>\n\nRemove the single directory C<path>.");
322 if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
323 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.");
325 if (strcasecmp (cmd, "mkdir") == 0)
326 pod2text ("mkdir - create a directory", " mkdir <path>\n\nCreate a directory named C<path>.");
328 if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
329 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.");
331 if (strcasecmp (cmd, "chmod") == 0)
332 pod2text ("chmod - change file mode", " chmod <mode> <path>\n\nChange the mode (permissions) of C<path> to C<mode>. Only\nnumeric modes are supported.");
334 if (strcasecmp (cmd, "chown") == 0)
335 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).");
337 if (strcasecmp (cmd, "exists") == 0)
338 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>.");
340 if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
341 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>.");
343 if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
344 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>.");
346 if (strcasecmp (cmd, "pvcreate") == 0)
347 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>.");
349 if (strcasecmp (cmd, "vgcreate") == 0)
350 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>.");
352 if (strcasecmp (cmd, "lvcreate") == 0)
353 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.");
355 if (strcasecmp (cmd, "mkfs") == 0)
356 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>.");
358 if (strcasecmp (cmd, "sfdisk") == 0)
359 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>.");
361 if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
362 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.");
364 if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
365 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.");
367 if (strcasecmp (cmd, "mounts") == 0)
368 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.");
370 if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
371 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.");
373 if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
374 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>.");
376 if (strcasecmp (cmd, "file") == 0)
377 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).");
379 if (strcasecmp (cmd, "command") == 0)
380 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.");
382 if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
383 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.");
385 if (strcasecmp (cmd, "stat") == 0)
386 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.");
388 if (strcasecmp (cmd, "lstat") == 0)
389 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.");
391 if (strcasecmp (cmd, "statvfs") == 0)
392 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.");
394 if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
395 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.");
397 if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
398 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.");
400 if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
401 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.");
403 if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
404 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.");
406 if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
407 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.");
409 if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
410 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.");
412 if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
413 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.");
415 if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
416 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.");
418 if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
419 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.");
421 if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
422 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.");
424 if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
425 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.");
427 if (strcasecmp (cmd, "upload") == 0)
428 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>.");
430 if (strcasecmp (cmd, "download") == 0)
431 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>.");
433 if (strcasecmp (cmd, "checksum") == 0)
434 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.");
436 if (strcasecmp (cmd, "tar_in") == 0 || strcasecmp (cmd, "tar-in") == 0)
437 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>.");
439 if (strcasecmp (cmd, "tar_out") == 0 || strcasecmp (cmd, "tar-out") == 0)
440 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>.");
442 if (strcasecmp (cmd, "tgz_in") == 0 || strcasecmp (cmd, "tgz-in") == 0)
443 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>.");
445 if (strcasecmp (cmd, "tgz_out") == 0 || strcasecmp (cmd, "tgz-out") == 0)
446 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>.");
448 if (strcasecmp (cmd, "mount_ro") == 0 || strcasecmp (cmd, "mount-ro") == 0)
449 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.");
451 if (strcasecmp (cmd, "mount_options") == 0 || strcasecmp (cmd, "mount-options") == 0)
452 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.");
454 if (strcasecmp (cmd, "mount_vfs") == 0 || strcasecmp (cmd, "mount-vfs") == 0)
455 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.");
457 if (strcasecmp (cmd, "debug") == 0)
458 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.");
460 if (strcasecmp (cmd, "lvremove") == 0)
461 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>.");
463 if (strcasecmp (cmd, "vgremove") == 0)
464 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).");
466 if (strcasecmp (cmd, "pvremove") == 0)
467 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.");
469 if (strcasecmp (cmd, "set_e2label") == 0 || strcasecmp (cmd, "set-e2label") == 0)
470 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.");
472 if (strcasecmp (cmd, "get_e2label") == 0 || strcasecmp (cmd, "get-e2label") == 0)
473 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>.");
475 if (strcasecmp (cmd, "set_e2uuid") == 0 || strcasecmp (cmd, "set-e2uuid") == 0)
476 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.");
478 if (strcasecmp (cmd, "get_e2uuid") == 0 || strcasecmp (cmd, "get-e2uuid") == 0)
479 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>.");
481 if (strcasecmp (cmd, "fsck") == 0)
482 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>.");
484 if (strcasecmp (cmd, "zero") == 0)
485 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.");
487 if (strcasecmp (cmd, "grub_install") == 0 || strcasecmp (cmd, "grub-install") == 0)
488 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>.");
490 if (strcasecmp (cmd, "cp") == 0)
491 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.");
493 if (strcasecmp (cmd, "cp_a") == 0 || strcasecmp (cmd, "cp-a") == 0)
494 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.");
496 if (strcasecmp (cmd, "mv") == 0)
497 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.");
499 if (strcasecmp (cmd, "drop_caches") == 0 || strcasecmp (cmd, "drop-caches") == 0)
500 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.");
502 if (strcasecmp (cmd, "dmesg") == 0)
503 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.");
505 if (strcasecmp (cmd, "ping_daemon") == 0 || strcasecmp (cmd, "ping-daemon") == 0)
506 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.");
508 if (strcasecmp (cmd, "equal") == 0)
509 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.");
511 if (strcasecmp (cmd, "strings") == 0)
512 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.");
514 if (strcasecmp (cmd, "strings_e") == 0 || strcasecmp (cmd, "strings-e") == 0)
515 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.");
517 if (strcasecmp (cmd, "hexdump") == 0)
518 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.");
520 if (strcasecmp (cmd, "zerofree") == 0)
521 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.");
523 if (strcasecmp (cmd, "pvresize") == 0)
524 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.");
526 if (strcasecmp (cmd, "sfdisk_N") == 0 || strcasecmp (cmd, "sfdisk-N") == 0)
527 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>.");
529 if (strcasecmp (cmd, "sfdisk_l") == 0 || strcasecmp (cmd, "sfdisk-l") == 0)
530 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.");
532 if (strcasecmp (cmd, "sfdisk_kernel_geometry") == 0 || strcasecmp (cmd, "sfdisk-kernel-geometry") == 0)
533 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.");
535 if (strcasecmp (cmd, "sfdisk_disk_geometry") == 0 || strcasecmp (cmd, "sfdisk-disk-geometry") == 0)
536 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.");
538 if (strcasecmp (cmd, "vg_activate_all") == 0 || strcasecmp (cmd, "vg-activate-all") == 0)
539 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>");
541 if (strcasecmp (cmd, "vg_activate") == 0 || strcasecmp (cmd, "vg-activate") == 0)
542 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.");
544 if (strcasecmp (cmd, "lvresize") == 0)
545 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.");
547 if (strcasecmp (cmd, "resize2fs") == 0)
548 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.\n\nI<Note:> It is sometimes required that you run C<e2fsck_f>\non the C<device> before calling this command. For unknown reasons\nC<resize2fs> sometimes gives an error about this and sometimes not.\nIn any case, it is always safe to call C<e2fsck_f> before\ncalling this function.");
550 if (strcasecmp (cmd, "find") == 0)
551 pod2text ("find - find all files and directories", " find <directory>\n\nThis command lists out all files and directories, recursively,\nstarting at C<directory>. It is essentially equivalent to\nrunning the shell command C<find directory -print> but some\npost-processing happens on the output, described below.\n\nThis returns a list of strings I<without any prefix>. Thus\nif the directory structure was:\n\n /tmp/a\n /tmp/b\n /tmp/c/d\n\nthen the returned list from C<find> C</tmp> would be\n4 elements:\n\n a\n b\n c\n c/d\n\nIf C<directory> is not a directory, then this command returns\nan error.\n\nThe returned list is sorted.");
553 if (strcasecmp (cmd, "e2fsck_f") == 0 || strcasecmp (cmd, "e2fsck-f") == 0)
554 pod2text ("e2fsck-f - check an ext2/ext3 filesystem", " e2fsck-f <device>\n\nThis runs C<e2fsck -p -f device>, ie. runs the ext2/ext3\nfilesystem checker on C<device>, noninteractively (C<-p>),\neven if the filesystem appears to be clean (C<-f>).\n\nThis command is only needed because of C<resize2fs>\n(q.v.). Normally you should use C<fsck>.");
556 if (strcasecmp (cmd, "sleep") == 0)
557 pod2text ("sleep - sleep for some seconds", " sleep <secs>\n\nSleep for C<secs> seconds.");
559 display_builtin_command (cmd);
562 static void print_pv (struct guestfs_lvm_pv *pv)
566 printf ("pv_name: %s\n", pv->pv_name);
567 printf ("pv_uuid: ");
568 for (i = 0; i < 32; ++i)
569 printf ("%c", pv->pv_uuid[i]);
571 printf ("pv_fmt: %s\n", pv->pv_fmt);
572 printf ("pv_size: %" PRIu64 "\n", pv->pv_size);
573 printf ("dev_size: %" PRIu64 "\n", pv->dev_size);
574 printf ("pv_free: %" PRIu64 "\n", pv->pv_free);
575 printf ("pv_used: %" PRIu64 "\n", pv->pv_used);
576 printf ("pv_attr: %s\n", pv->pv_attr);
577 printf ("pv_pe_count: %" PRIi64 "\n", pv->pv_pe_count);
578 printf ("pv_pe_alloc_count: %" PRIi64 "\n", pv->pv_pe_alloc_count);
579 printf ("pv_tags: %s\n", pv->pv_tags);
580 printf ("pe_start: %" PRIu64 "\n", pv->pe_start);
581 printf ("pv_mda_count: %" PRIi64 "\n", pv->pv_mda_count);
582 printf ("pv_mda_free: %" PRIu64 "\n", pv->pv_mda_free);
585 static void print_pv_list (struct guestfs_lvm_pv_list *pvs)
589 for (i = 0; i < pvs->len; ++i)
590 print_pv (&pvs->val[i]);
593 static void print_vg (struct guestfs_lvm_vg *vg)
597 printf ("vg_name: %s\n", vg->vg_name);
598 printf ("vg_uuid: ");
599 for (i = 0; i < 32; ++i)
600 printf ("%c", vg->vg_uuid[i]);
602 printf ("vg_fmt: %s\n", vg->vg_fmt);
603 printf ("vg_attr: %s\n", vg->vg_attr);
604 printf ("vg_size: %" PRIu64 "\n", vg->vg_size);
605 printf ("vg_free: %" PRIu64 "\n", vg->vg_free);
606 printf ("vg_sysid: %s\n", vg->vg_sysid);
607 printf ("vg_extent_size: %" PRIu64 "\n", vg->vg_extent_size);
608 printf ("vg_extent_count: %" PRIi64 "\n", vg->vg_extent_count);
609 printf ("vg_free_count: %" PRIi64 "\n", vg->vg_free_count);
610 printf ("max_lv: %" PRIi64 "\n", vg->max_lv);
611 printf ("max_pv: %" PRIi64 "\n", vg->max_pv);
612 printf ("pv_count: %" PRIi64 "\n", vg->pv_count);
613 printf ("lv_count: %" PRIi64 "\n", vg->lv_count);
614 printf ("snap_count: %" PRIi64 "\n", vg->snap_count);
615 printf ("vg_seqno: %" PRIi64 "\n", vg->vg_seqno);
616 printf ("vg_tags: %s\n", vg->vg_tags);
617 printf ("vg_mda_count: %" PRIi64 "\n", vg->vg_mda_count);
618 printf ("vg_mda_free: %" PRIu64 "\n", vg->vg_mda_free);
621 static void print_vg_list (struct guestfs_lvm_vg_list *vgs)
625 for (i = 0; i < vgs->len; ++i)
626 print_vg (&vgs->val[i]);
629 static void print_lv (struct guestfs_lvm_lv *lv)
633 printf ("lv_name: %s\n", lv->lv_name);
634 printf ("lv_uuid: ");
635 for (i = 0; i < 32; ++i)
636 printf ("%c", lv->lv_uuid[i]);
638 printf ("lv_attr: %s\n", lv->lv_attr);
639 printf ("lv_major: %" PRIi64 "\n", lv->lv_major);
640 printf ("lv_minor: %" PRIi64 "\n", lv->lv_minor);
641 printf ("lv_kernel_major: %" PRIi64 "\n", lv->lv_kernel_major);
642 printf ("lv_kernel_minor: %" PRIi64 "\n", lv->lv_kernel_minor);
643 printf ("lv_size: %" PRIu64 "\n", lv->lv_size);
644 printf ("seg_count: %" PRIi64 "\n", lv->seg_count);
645 printf ("origin: %s\n", lv->origin);
646 if (lv->snap_percent >= 0) printf ("snap_percent: %g %%\n", lv->snap_percent);
647 else printf ("snap_percent: \n");
648 if (lv->copy_percent >= 0) printf ("copy_percent: %g %%\n", lv->copy_percent);
649 else printf ("copy_percent: \n");
650 printf ("move_pv: %s\n", lv->move_pv);
651 printf ("lv_tags: %s\n", lv->lv_tags);
652 printf ("mirror_log: %s\n", lv->mirror_log);
653 printf ("modules: %s\n", lv->modules);
656 static void print_lv_list (struct guestfs_lvm_lv_list *lvs)
660 for (i = 0; i < lvs->len; ++i)
661 print_lv (&lvs->val[i]);
664 static void print_stat (struct guestfs_stat *stat)
666 printf ("dev: %" PRIi64 "\n", stat->dev);
667 printf ("ino: %" PRIi64 "\n", stat->ino);
668 printf ("mode: %" PRIi64 "\n", stat->mode);
669 printf ("nlink: %" PRIi64 "\n", stat->nlink);
670 printf ("uid: %" PRIi64 "\n", stat->uid);
671 printf ("gid: %" PRIi64 "\n", stat->gid);
672 printf ("rdev: %" PRIi64 "\n", stat->rdev);
673 printf ("size: %" PRIi64 "\n", stat->size);
674 printf ("blksize: %" PRIi64 "\n", stat->blksize);
675 printf ("blocks: %" PRIi64 "\n", stat->blocks);
676 printf ("atime: %" PRIi64 "\n", stat->atime);
677 printf ("mtime: %" PRIi64 "\n", stat->mtime);
678 printf ("ctime: %" PRIi64 "\n", stat->ctime);
681 static void print_statvfs (struct guestfs_statvfs *statvfs)
683 printf ("bsize: %" PRIi64 "\n", statvfs->bsize);
684 printf ("frsize: %" PRIi64 "\n", statvfs->frsize);
685 printf ("blocks: %" PRIi64 "\n", statvfs->blocks);
686 printf ("bfree: %" PRIi64 "\n", statvfs->bfree);
687 printf ("bavail: %" PRIi64 "\n", statvfs->bavail);
688 printf ("files: %" PRIi64 "\n", statvfs->files);
689 printf ("ffree: %" PRIi64 "\n", statvfs->ffree);
690 printf ("favail: %" PRIi64 "\n", statvfs->favail);
691 printf ("fsid: %" PRIi64 "\n", statvfs->fsid);
692 printf ("flag: %" PRIi64 "\n", statvfs->flag);
693 printf ("namemax: %" PRIi64 "\n", statvfs->namemax);
696 static int run_launch (const char *cmd, int argc, char *argv[])
700 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
701 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
708 static int run_kill_subprocess (const char *cmd, int argc, char *argv[])
712 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
713 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
716 r = guestfs_kill_subprocess (g);
720 static int run_add_drive (const char *cmd, int argc, char *argv[])
723 const char *filename;
725 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
726 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
730 r = guestfs_add_drive (g, filename);
734 static int run_add_cdrom (const char *cmd, int argc, char *argv[])
737 const char *filename;
739 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
740 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
744 r = guestfs_add_cdrom (g, filename);
748 static int run_add_drive_ro (const char *cmd, int argc, char *argv[])
751 const char *filename;
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_add_drive_ro (g, filename);
762 static int run_config (const char *cmd, int argc, char *argv[])
765 const char *qemuparam;
766 const char *qemuvalue;
768 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
769 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
773 qemuvalue = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
774 r = guestfs_config (g, qemuparam, qemuvalue);
778 static int run_set_qemu (const char *cmd, int argc, char *argv[])
783 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
784 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
788 r = guestfs_set_qemu (g, qemu);
792 static int run_get_qemu (const char *cmd, int argc, char *argv[])
796 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
797 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
800 r = guestfs_get_qemu (g);
801 if (r == NULL) return -1;
806 static int run_set_path (const char *cmd, int argc, char *argv[])
811 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
812 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
816 r = guestfs_set_path (g, path);
820 static int run_get_path (const char *cmd, int argc, char *argv[])
824 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
825 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
828 r = guestfs_get_path (g);
829 if (r == NULL) return -1;
834 static int run_set_append (const char *cmd, int argc, char *argv[])
839 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
840 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
844 r = guestfs_set_append (g, append);
848 static int run_get_append (const char *cmd, int argc, char *argv[])
852 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
853 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
856 r = guestfs_get_append (g);
857 if (r == NULL) return -1;
862 static int run_set_autosync (const char *cmd, int argc, char *argv[])
867 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
868 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
871 autosync = is_true (argv[0]) ? 1 : 0;
872 r = guestfs_set_autosync (g, autosync);
876 static int run_get_autosync (const char *cmd, int argc, char *argv[])
880 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
881 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
884 r = guestfs_get_autosync (g);
885 if (r == -1) return -1;
886 if (r) printf ("true\n"); else printf ("false\n");
890 static int run_set_verbose (const char *cmd, int argc, char *argv[])
895 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
896 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
899 verbose = is_true (argv[0]) ? 1 : 0;
900 r = guestfs_set_verbose (g, verbose);
904 static int run_get_verbose (const char *cmd, int argc, char *argv[])
908 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
909 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
912 r = guestfs_get_verbose (g);
913 if (r == -1) return -1;
914 if (r) printf ("true\n"); else printf ("false\n");
918 static int run_is_ready (const char *cmd, int argc, char *argv[])
922 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
923 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
926 r = guestfs_is_ready (g);
927 if (r == -1) return -1;
928 if (r) printf ("true\n"); else printf ("false\n");
932 static int run_is_config (const char *cmd, int argc, char *argv[])
936 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
937 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
940 r = guestfs_is_config (g);
941 if (r == -1) return -1;
942 if (r) printf ("true\n"); else printf ("false\n");
946 static int run_is_launching (const char *cmd, int argc, char *argv[])
950 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
951 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
954 r = guestfs_is_launching (g);
955 if (r == -1) return -1;
956 if (r) printf ("true\n"); else printf ("false\n");
960 static int run_is_busy (const char *cmd, int argc, char *argv[])
964 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
965 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
968 r = guestfs_is_busy (g);
969 if (r == -1) return -1;
970 if (r) printf ("true\n"); else printf ("false\n");
974 static int run_get_state (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_get_state (g);
983 if (r == -1) return -1;
988 static int run_mount (const char *cmd, int argc, char *argv[])
992 const char *mountpoint;
994 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
995 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
999 mountpoint = argv[1];
1000 r = guestfs_mount (g, device, mountpoint);
1004 static int run_sync (const char *cmd, int argc, char *argv[])
1008 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1009 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1012 r = guestfs_sync (g);
1016 static int run_touch (const char *cmd, int argc, char *argv[])
1021 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1022 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1026 r = guestfs_touch (g, path);
1030 static int run_cat (const char *cmd, int argc, char *argv[])
1035 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1036 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1040 r = guestfs_cat (g, path);
1041 if (r == NULL) return -1;
1047 static int run_ll (const char *cmd, int argc, char *argv[])
1050 const char *directory;
1052 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1053 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1056 directory = argv[0];
1057 r = guestfs_ll (g, directory);
1058 if (r == NULL) return -1;
1064 static int run_ls (const char *cmd, int argc, char *argv[])
1067 const char *directory;
1069 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1070 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1073 directory = argv[0];
1074 r = guestfs_ls (g, directory);
1075 if (r == NULL) return -1;
1081 static int run_list_devices (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_list_devices (g);
1090 if (r == NULL) return -1;
1096 static int run_list_partitions (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_list_partitions (g);
1105 if (r == NULL) return -1;
1111 static int run_pvs (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_pvs (g);
1120 if (r == NULL) return -1;
1126 static int run_vgs (const char *cmd, int argc, char *argv[])
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_vgs (g);
1135 if (r == NULL) return -1;
1141 static int run_lvs (const char *cmd, int argc, char *argv[])
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_lvs (g);
1150 if (r == NULL) return -1;
1156 static int run_pvs_full (const char *cmd, int argc, char *argv[])
1158 struct guestfs_lvm_pv_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_pvs_full (g);
1165 if (r == NULL) return -1;
1167 guestfs_free_lvm_pv_list (r);
1171 static int run_vgs_full (const char *cmd, int argc, char *argv[])
1173 struct guestfs_lvm_vg_list *r;
1175 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1176 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1179 r = guestfs_vgs_full (g);
1180 if (r == NULL) return -1;
1182 guestfs_free_lvm_vg_list (r);
1186 static int run_lvs_full (const char *cmd, int argc, char *argv[])
1188 struct guestfs_lvm_lv_list *r;
1190 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1191 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1194 r = guestfs_lvs_full (g);
1195 if (r == NULL) return -1;
1197 guestfs_free_lvm_lv_list (r);
1201 static int run_read_lines (const char *cmd, int argc, char *argv[])
1206 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1207 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1211 r = guestfs_read_lines (g, path);
1212 if (r == NULL) return -1;
1218 static int run_aug_init (const char *cmd, int argc, char *argv[])
1224 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1225 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1229 flags = atoi (argv[1]);
1230 r = guestfs_aug_init (g, root, flags);
1234 static int run_aug_close (const char *cmd, int argc, char *argv[])
1238 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1239 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1242 r = guestfs_aug_close (g);
1246 static int run_aug_defvar (const char *cmd, int argc, char *argv[])
1252 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1253 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1257 expr = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
1258 r = guestfs_aug_defvar (g, name, expr);
1259 if (r == -1) return -1;
1264 static int run_aug_defnode (const char *cmd, int argc, char *argv[])
1266 struct guestfs_int_bool *r;
1271 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1272 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1278 r = guestfs_aug_defnode (g, name, expr, val);
1279 if (r == NULL) return -1;
1280 printf ("%d, %s\n", r->i,
1281 r->b ? "true" : "false");
1282 guestfs_free_int_bool (r);
1286 static int run_aug_get (const char *cmd, int argc, char *argv[])
1291 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1292 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1296 r = guestfs_aug_get (g, path);
1297 if (r == NULL) return -1;
1303 static int run_aug_set (const char *cmd, int argc, char *argv[])
1309 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1310 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1315 r = guestfs_aug_set (g, path, val);
1319 static int run_aug_insert (const char *cmd, int argc, char *argv[])
1326 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1327 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1332 before = is_true (argv[2]) ? 1 : 0;
1333 r = guestfs_aug_insert (g, path, label, before);
1337 static int run_aug_rm (const char *cmd, int argc, char *argv[])
1342 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1343 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1347 r = guestfs_aug_rm (g, path);
1348 if (r == -1) return -1;
1353 static int run_aug_mv (const char *cmd, int argc, char *argv[])
1359 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1360 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1365 r = guestfs_aug_mv (g, src, dest);
1369 static int run_aug_match (const char *cmd, int argc, char *argv[])
1374 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1375 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1379 r = guestfs_aug_match (g, path);
1380 if (r == NULL) return -1;
1386 static int run_aug_save (const char *cmd, int argc, char *argv[])
1390 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1391 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1394 r = guestfs_aug_save (g);
1398 static int run_aug_load (const char *cmd, int argc, char *argv[])
1402 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1403 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1406 r = guestfs_aug_load (g);
1410 static int run_aug_ls (const char *cmd, int argc, char *argv[])
1415 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1416 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1420 r = guestfs_aug_ls (g, path);
1421 if (r == NULL) return -1;
1427 static int run_rm (const char *cmd, int argc, char *argv[])
1432 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1433 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1437 r = guestfs_rm (g, path);
1441 static int run_rmdir (const char *cmd, int argc, char *argv[])
1446 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1447 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1451 r = guestfs_rmdir (g, path);
1455 static int run_rm_rf (const char *cmd, int argc, char *argv[])
1460 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1461 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1465 r = guestfs_rm_rf (g, path);
1469 static int run_mkdir (const char *cmd, int argc, char *argv[])
1474 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1475 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1479 r = guestfs_mkdir (g, path);
1483 static int run_mkdir_p (const char *cmd, int argc, char *argv[])
1488 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1489 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1493 r = guestfs_mkdir_p (g, path);
1497 static int run_chmod (const char *cmd, int argc, char *argv[])
1503 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1504 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1507 mode = atoi (argv[0]);
1509 r = guestfs_chmod (g, mode, path);
1513 static int run_chown (const char *cmd, int argc, char *argv[])
1520 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1521 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1524 owner = atoi (argv[0]);
1525 group = atoi (argv[1]);
1527 r = guestfs_chown (g, owner, group, path);
1531 static int run_exists (const char *cmd, int argc, char *argv[])
1536 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1537 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1541 r = guestfs_exists (g, path);
1542 if (r == -1) return -1;
1543 if (r) printf ("true\n"); else printf ("false\n");
1547 static int run_is_file (const char *cmd, int argc, char *argv[])
1552 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1553 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1557 r = guestfs_is_file (g, path);
1558 if (r == -1) return -1;
1559 if (r) printf ("true\n"); else printf ("false\n");
1563 static int run_is_dir (const char *cmd, int argc, char *argv[])
1568 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1569 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1573 r = guestfs_is_dir (g, path);
1574 if (r == -1) return -1;
1575 if (r) printf ("true\n"); else printf ("false\n");
1579 static int run_pvcreate (const char *cmd, int argc, char *argv[])
1584 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1585 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1589 r = guestfs_pvcreate (g, device);
1593 static int run_vgcreate (const char *cmd, int argc, char *argv[])
1596 const char *volgroup;
1599 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1600 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1604 physvols = parse_string_list (argv[1]);
1605 r = guestfs_vgcreate (g, volgroup, physvols);
1609 static int run_lvcreate (const char *cmd, int argc, char *argv[])
1613 const char *volgroup;
1616 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1617 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1622 mbytes = atoi (argv[2]);
1623 r = guestfs_lvcreate (g, logvol, volgroup, mbytes);
1627 static int run_mkfs (const char *cmd, int argc, char *argv[])
1633 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1634 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1639 r = guestfs_mkfs (g, fstype, device);
1643 static int run_sfdisk (const char *cmd, int argc, char *argv[])
1652 fprintf (stderr, "%s should have 5 parameter(s)\n", cmd);
1653 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1657 cyls = atoi (argv[1]);
1658 heads = atoi (argv[2]);
1659 sectors = atoi (argv[3]);
1660 lines = parse_string_list (argv[4]);
1661 r = guestfs_sfdisk (g, device, cyls, heads, sectors, lines);
1665 static int run_write_file (const char *cmd, int argc, char *argv[])
1669 const char *content;
1672 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1673 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1678 size = atoi (argv[2]);
1679 r = guestfs_write_file (g, path, content, size);
1683 static int run_umount (const char *cmd, int argc, char *argv[])
1686 const char *pathordevice;
1688 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1689 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1692 pathordevice = argv[0];
1693 r = guestfs_umount (g, pathordevice);
1697 static int run_mounts (const char *cmd, int argc, char *argv[])
1701 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1702 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1705 r = guestfs_mounts (g);
1706 if (r == NULL) return -1;
1712 static int run_umount_all (const char *cmd, int argc, char *argv[])
1716 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1717 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1720 r = guestfs_umount_all (g);
1724 static int run_lvm_remove_all (const char *cmd, int argc, char *argv[])
1728 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1729 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1732 r = guestfs_lvm_remove_all (g);
1736 static int run_file (const char *cmd, int argc, char *argv[])
1741 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1742 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1746 r = guestfs_file (g, path);
1747 if (r == NULL) return -1;
1753 static int run_command (const char *cmd, int argc, char *argv[])
1758 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1759 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1762 arguments = parse_string_list (argv[0]);
1763 r = guestfs_command (g, arguments);
1764 if (r == NULL) return -1;
1770 static int run_command_lines (const char *cmd, int argc, char *argv[])
1775 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1776 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1779 arguments = parse_string_list (argv[0]);
1780 r = guestfs_command_lines (g, arguments);
1781 if (r == NULL) return -1;
1787 static int run_stat (const char *cmd, int argc, char *argv[])
1789 struct guestfs_stat *r;
1792 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1793 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1797 r = guestfs_stat (g, path);
1798 if (r == NULL) return -1;
1804 static int run_lstat (const char *cmd, int argc, char *argv[])
1806 struct guestfs_stat *r;
1809 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1810 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1814 r = guestfs_lstat (g, path);
1815 if (r == NULL) return -1;
1821 static int run_statvfs (const char *cmd, int argc, char *argv[])
1823 struct guestfs_statvfs *r;
1826 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1827 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1831 r = guestfs_statvfs (g, path);
1832 if (r == NULL) return -1;
1838 static int run_tune2fs_l (const char *cmd, int argc, char *argv[])
1843 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1844 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1848 r = guestfs_tune2fs_l (g, device);
1849 if (r == NULL) return -1;
1855 static int run_blockdev_setro (const char *cmd, int argc, char *argv[])
1860 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1861 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1865 r = guestfs_blockdev_setro (g, device);
1869 static int run_blockdev_setrw (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_setrw (g, device);
1883 static int run_blockdev_getro (const char *cmd, int argc, char *argv[])
1888 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1889 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1893 r = guestfs_blockdev_getro (g, device);
1894 if (r == -1) return -1;
1895 if (r) printf ("true\n"); else printf ("false\n");
1899 static int run_blockdev_getss (const char *cmd, int argc, char *argv[])
1904 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1905 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1909 r = guestfs_blockdev_getss (g, device);
1910 if (r == -1) return -1;
1915 static int run_blockdev_getbsz (const char *cmd, int argc, char *argv[])
1920 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1921 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1925 r = guestfs_blockdev_getbsz (g, device);
1926 if (r == -1) return -1;
1931 static int run_blockdev_setbsz (const char *cmd, int argc, char *argv[])
1937 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1938 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1942 blocksize = atoi (argv[1]);
1943 r = guestfs_blockdev_setbsz (g, device, blocksize);
1947 static int run_blockdev_getsz (const char *cmd, int argc, char *argv[])
1952 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1953 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1957 r = guestfs_blockdev_getsz (g, device);
1958 if (r == -1) return -1;
1959 printf ("%" PRIi64 "\n", r);
1963 static int run_blockdev_getsize64 (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_getsize64 (g, device);
1974 if (r == -1) return -1;
1975 printf ("%" PRIi64 "\n", r);
1979 static int run_blockdev_flushbufs (const char *cmd, int argc, char *argv[])
1984 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1985 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1989 r = guestfs_blockdev_flushbufs (g, device);
1993 static int run_blockdev_rereadpt (const char *cmd, int argc, char *argv[])
1998 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1999 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2003 r = guestfs_blockdev_rereadpt (g, device);
2007 static int run_upload (const char *cmd, int argc, char *argv[])
2010 const char *filename;
2011 const char *remotefilename;
2013 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2014 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2017 filename = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
2018 remotefilename = argv[1];
2019 r = guestfs_upload (g, filename, remotefilename);
2023 static int run_download (const char *cmd, int argc, char *argv[])
2026 const char *remotefilename;
2027 const char *filename;
2029 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2030 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2033 remotefilename = argv[0];
2034 filename = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
2035 r = guestfs_download (g, remotefilename, filename);
2039 static int run_checksum (const char *cmd, int argc, char *argv[])
2042 const char *csumtype;
2045 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2046 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2051 r = guestfs_checksum (g, csumtype, path);
2052 if (r == NULL) return -1;
2058 static int run_tar_in (const char *cmd, int argc, char *argv[])
2061 const char *tarfile;
2062 const char *directory;
2064 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2065 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2068 tarfile = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
2069 directory = argv[1];
2070 r = guestfs_tar_in (g, tarfile, directory);
2074 static int run_tar_out (const char *cmd, int argc, char *argv[])
2077 const char *directory;
2078 const char *tarfile;
2080 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2081 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2084 directory = argv[0];
2085 tarfile = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
2086 r = guestfs_tar_out (g, directory, tarfile);
2090 static int run_tgz_in (const char *cmd, int argc, char *argv[])
2093 const char *tarball;
2094 const char *directory;
2096 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2097 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2100 tarball = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
2101 directory = argv[1];
2102 r = guestfs_tgz_in (g, tarball, directory);
2106 static int run_tgz_out (const char *cmd, int argc, char *argv[])
2109 const char *directory;
2110 const char *tarball;
2112 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2113 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2116 directory = argv[0];
2117 tarball = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
2118 r = guestfs_tgz_out (g, directory, tarball);
2122 static int run_mount_ro (const char *cmd, int argc, char *argv[])
2126 const char *mountpoint;
2128 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2129 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2133 mountpoint = argv[1];
2134 r = guestfs_mount_ro (g, device, mountpoint);
2138 static int run_mount_options (const char *cmd, int argc, char *argv[])
2141 const char *options;
2143 const char *mountpoint;
2145 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
2146 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2151 mountpoint = argv[2];
2152 r = guestfs_mount_options (g, options, device, mountpoint);
2156 static int run_mount_vfs (const char *cmd, int argc, char *argv[])
2159 const char *options;
2160 const char *vfstype;
2162 const char *mountpoint;
2164 fprintf (stderr, "%s should have 4 parameter(s)\n", cmd);
2165 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2171 mountpoint = argv[3];
2172 r = guestfs_mount_vfs (g, options, vfstype, device, mountpoint);
2176 static int run_debug (const char *cmd, int argc, char *argv[])
2182 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2183 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2187 extraargs = parse_string_list (argv[1]);
2188 r = guestfs_debug (g, subcmd, extraargs);
2189 if (r == NULL) return -1;
2195 static int run_lvremove (const char *cmd, int argc, char *argv[])
2200 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2201 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2205 r = guestfs_lvremove (g, device);
2209 static int run_vgremove (const char *cmd, int argc, char *argv[])
2214 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2215 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2219 r = guestfs_vgremove (g, vgname);
2223 static int run_pvremove (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_pvremove (g, device);
2237 static int run_set_e2label (const char *cmd, int argc, char *argv[])
2243 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2244 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2249 r = guestfs_set_e2label (g, device, label);
2253 static int run_get_e2label (const char *cmd, int argc, char *argv[])
2258 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2259 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2263 r = guestfs_get_e2label (g, device);
2264 if (r == NULL) return -1;
2270 static int run_set_e2uuid (const char *cmd, int argc, char *argv[])
2276 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2277 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2282 r = guestfs_set_e2uuid (g, device, uuid);
2286 static int run_get_e2uuid (const char *cmd, int argc, char *argv[])
2291 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2292 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2296 r = guestfs_get_e2uuid (g, device);
2297 if (r == NULL) return -1;
2303 static int run_fsck (const char *cmd, int argc, char *argv[])
2309 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2310 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2315 r = guestfs_fsck (g, fstype, device);
2316 if (r == -1) return -1;
2321 static int run_zero (const char *cmd, int argc, char *argv[])
2326 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2327 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2331 r = guestfs_zero (g, device);
2335 static int run_grub_install (const char *cmd, int argc, char *argv[])
2341 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2342 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2347 r = guestfs_grub_install (g, root, device);
2351 static int run_cp (const char *cmd, int argc, char *argv[])
2357 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2358 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2363 r = guestfs_cp (g, src, dest);
2367 static int run_cp_a (const char *cmd, int argc, char *argv[])
2373 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2374 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2379 r = guestfs_cp_a (g, src, dest);
2383 static int run_mv (const char *cmd, int argc, char *argv[])
2389 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2390 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2395 r = guestfs_mv (g, src, dest);
2399 static int run_drop_caches (const char *cmd, int argc, char *argv[])
2404 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2405 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2408 whattodrop = atoi (argv[0]);
2409 r = guestfs_drop_caches (g, whattodrop);
2413 static int run_dmesg (const char *cmd, int argc, char *argv[])
2417 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
2418 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2421 r = guestfs_dmesg (g);
2422 if (r == NULL) return -1;
2428 static int run_ping_daemon (const char *cmd, int argc, char *argv[])
2432 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
2433 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2436 r = guestfs_ping_daemon (g);
2440 static int run_equal (const char *cmd, int argc, char *argv[])
2446 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2447 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2452 r = guestfs_equal (g, file1, file2);
2453 if (r == -1) return -1;
2454 if (r) printf ("true\n"); else printf ("false\n");
2458 static int run_strings (const char *cmd, int argc, char *argv[])
2463 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2464 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2468 r = guestfs_strings (g, path);
2469 if (r == NULL) return -1;
2475 static int run_strings_e (const char *cmd, int argc, char *argv[])
2478 const char *encoding;
2481 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2482 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2487 r = guestfs_strings_e (g, encoding, path);
2488 if (r == NULL) return -1;
2494 static int run_hexdump (const char *cmd, int argc, char *argv[])
2499 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2500 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2504 r = guestfs_hexdump (g, path);
2505 if (r == NULL) return -1;
2511 static int run_zerofree (const char *cmd, int argc, char *argv[])
2516 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2517 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2521 r = guestfs_zerofree (g, device);
2525 static int run_pvresize (const char *cmd, int argc, char *argv[])
2530 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2531 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2535 r = guestfs_pvresize (g, device);
2539 static int run_sfdisk_N (const char *cmd, int argc, char *argv[])
2549 fprintf (stderr, "%s should have 6 parameter(s)\n", cmd);
2550 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2555 cyls = atoi (argv[2]);
2556 heads = atoi (argv[3]);
2557 sectors = atoi (argv[4]);
2559 r = guestfs_sfdisk_N (g, device, n, cyls, heads, sectors, line);
2563 static int run_sfdisk_l (const char *cmd, int argc, char *argv[])
2568 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2569 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2573 r = guestfs_sfdisk_l (g, device);
2574 if (r == NULL) return -1;
2580 static int run_sfdisk_kernel_geometry (const char *cmd, int argc, char *argv[])
2585 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2586 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2590 r = guestfs_sfdisk_kernel_geometry (g, device);
2591 if (r == NULL) return -1;
2597 static int run_sfdisk_disk_geometry (const char *cmd, int argc, char *argv[])
2602 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2603 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2607 r = guestfs_sfdisk_disk_geometry (g, device);
2608 if (r == NULL) return -1;
2614 static int run_vg_activate_all (const char *cmd, int argc, char *argv[])
2619 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2620 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2623 activate = is_true (argv[0]) ? 1 : 0;
2624 r = guestfs_vg_activate_all (g, activate);
2628 static int run_vg_activate (const char *cmd, int argc, char *argv[])
2634 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2635 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2638 activate = is_true (argv[0]) ? 1 : 0;
2639 volgroups = parse_string_list (argv[1]);
2640 r = guestfs_vg_activate (g, activate, volgroups);
2644 static int run_lvresize (const char *cmd, int argc, char *argv[])
2650 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2651 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2655 mbytes = atoi (argv[1]);
2656 r = guestfs_lvresize (g, device, mbytes);
2660 static int run_resize2fs (const char *cmd, int argc, char *argv[])
2665 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2666 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2670 r = guestfs_resize2fs (g, device);
2674 static int run_find (const char *cmd, int argc, char *argv[])
2677 const char *directory;
2679 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2680 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2683 directory = argv[0];
2684 r = guestfs_find (g, directory);
2685 if (r == NULL) return -1;
2691 static int run_e2fsck_f (const char *cmd, int argc, char *argv[])
2696 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2697 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2701 r = guestfs_e2fsck_f (g, device);
2705 static int run_sleep (const char *cmd, int argc, char *argv[])
2710 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2711 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2714 secs = atoi (argv[0]);
2715 r = guestfs_sleep (g, secs);
2719 int run_action (const char *cmd, int argc, char *argv[])
2721 if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
2722 return run_launch (cmd, argc, argv);
2724 if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
2725 return run_kill_subprocess (cmd, argc, argv);
2727 if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
2728 return run_add_drive (cmd, argc, argv);
2730 if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
2731 return run_add_cdrom (cmd, argc, argv);
2733 if (strcasecmp (cmd, "add_drive_ro") == 0 || strcasecmp (cmd, "add-drive-ro") == 0 || strcasecmp (cmd, "add-ro") == 0)
2734 return run_add_drive_ro (cmd, argc, argv);
2736 if (strcasecmp (cmd, "config") == 0)
2737 return run_config (cmd, argc, argv);
2739 if (strcasecmp (cmd, "set_qemu") == 0 || strcasecmp (cmd, "set-qemu") == 0 || strcasecmp (cmd, "qemu") == 0)
2740 return run_set_qemu (cmd, argc, argv);
2742 if (strcasecmp (cmd, "get_qemu") == 0 || strcasecmp (cmd, "get-qemu") == 0)
2743 return run_get_qemu (cmd, argc, argv);
2745 if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
2746 return run_set_path (cmd, argc, argv);
2748 if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
2749 return run_get_path (cmd, argc, argv);
2751 if (strcasecmp (cmd, "set_append") == 0 || strcasecmp (cmd, "set-append") == 0 || strcasecmp (cmd, "append") == 0)
2752 return run_set_append (cmd, argc, argv);
2754 if (strcasecmp (cmd, "get_append") == 0 || strcasecmp (cmd, "get-append") == 0)
2755 return run_get_append (cmd, argc, argv);
2757 if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
2758 return run_set_autosync (cmd, argc, argv);
2760 if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
2761 return run_get_autosync (cmd, argc, argv);
2763 if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
2764 return run_set_verbose (cmd, argc, argv);
2766 if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
2767 return run_get_verbose (cmd, argc, argv);
2769 if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
2770 return run_is_ready (cmd, argc, argv);
2772 if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
2773 return run_is_config (cmd, argc, argv);
2775 if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
2776 return run_is_launching (cmd, argc, argv);
2778 if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
2779 return run_is_busy (cmd, argc, argv);
2781 if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
2782 return run_get_state (cmd, argc, argv);
2784 if (strcasecmp (cmd, "mount") == 0)
2785 return run_mount (cmd, argc, argv);
2787 if (strcasecmp (cmd, "sync") == 0)
2788 return run_sync (cmd, argc, argv);
2790 if (strcasecmp (cmd, "touch") == 0)
2791 return run_touch (cmd, argc, argv);
2793 if (strcasecmp (cmd, "cat") == 0)
2794 return run_cat (cmd, argc, argv);
2796 if (strcasecmp (cmd, "ll") == 0)
2797 return run_ll (cmd, argc, argv);
2799 if (strcasecmp (cmd, "ls") == 0)
2800 return run_ls (cmd, argc, argv);
2802 if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
2803 return run_list_devices (cmd, argc, argv);
2805 if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
2806 return run_list_partitions (cmd, argc, argv);
2808 if (strcasecmp (cmd, "pvs") == 0)
2809 return run_pvs (cmd, argc, argv);
2811 if (strcasecmp (cmd, "vgs") == 0)
2812 return run_vgs (cmd, argc, argv);
2814 if (strcasecmp (cmd, "lvs") == 0)
2815 return run_lvs (cmd, argc, argv);
2817 if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
2818 return run_pvs_full (cmd, argc, argv);
2820 if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
2821 return run_vgs_full (cmd, argc, argv);
2823 if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
2824 return run_lvs_full (cmd, argc, argv);
2826 if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
2827 return run_read_lines (cmd, argc, argv);
2829 if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
2830 return run_aug_init (cmd, argc, argv);
2832 if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
2833 return run_aug_close (cmd, argc, argv);
2835 if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
2836 return run_aug_defvar (cmd, argc, argv);
2838 if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
2839 return run_aug_defnode (cmd, argc, argv);
2841 if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
2842 return run_aug_get (cmd, argc, argv);
2844 if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
2845 return run_aug_set (cmd, argc, argv);
2847 if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
2848 return run_aug_insert (cmd, argc, argv);
2850 if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
2851 return run_aug_rm (cmd, argc, argv);
2853 if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
2854 return run_aug_mv (cmd, argc, argv);
2856 if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
2857 return run_aug_match (cmd, argc, argv);
2859 if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
2860 return run_aug_save (cmd, argc, argv);
2862 if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
2863 return run_aug_load (cmd, argc, argv);
2865 if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
2866 return run_aug_ls (cmd, argc, argv);
2868 if (strcasecmp (cmd, "rm") == 0)
2869 return run_rm (cmd, argc, argv);
2871 if (strcasecmp (cmd, "rmdir") == 0)
2872 return run_rmdir (cmd, argc, argv);
2874 if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
2875 return run_rm_rf (cmd, argc, argv);
2877 if (strcasecmp (cmd, "mkdir") == 0)
2878 return run_mkdir (cmd, argc, argv);
2880 if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
2881 return run_mkdir_p (cmd, argc, argv);
2883 if (strcasecmp (cmd, "chmod") == 0)
2884 return run_chmod (cmd, argc, argv);
2886 if (strcasecmp (cmd, "chown") == 0)
2887 return run_chown (cmd, argc, argv);
2889 if (strcasecmp (cmd, "exists") == 0)
2890 return run_exists (cmd, argc, argv);
2892 if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
2893 return run_is_file (cmd, argc, argv);
2895 if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
2896 return run_is_dir (cmd, argc, argv);
2898 if (strcasecmp (cmd, "pvcreate") == 0)
2899 return run_pvcreate (cmd, argc, argv);
2901 if (strcasecmp (cmd, "vgcreate") == 0)
2902 return run_vgcreate (cmd, argc, argv);
2904 if (strcasecmp (cmd, "lvcreate") == 0)
2905 return run_lvcreate (cmd, argc, argv);
2907 if (strcasecmp (cmd, "mkfs") == 0)
2908 return run_mkfs (cmd, argc, argv);
2910 if (strcasecmp (cmd, "sfdisk") == 0)
2911 return run_sfdisk (cmd, argc, argv);
2913 if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
2914 return run_write_file (cmd, argc, argv);
2916 if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
2917 return run_umount (cmd, argc, argv);
2919 if (strcasecmp (cmd, "mounts") == 0)
2920 return run_mounts (cmd, argc, argv);
2922 if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
2923 return run_umount_all (cmd, argc, argv);
2925 if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
2926 return run_lvm_remove_all (cmd, argc, argv);
2928 if (strcasecmp (cmd, "file") == 0)
2929 return run_file (cmd, argc, argv);
2931 if (strcasecmp (cmd, "command") == 0)
2932 return run_command (cmd, argc, argv);
2934 if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
2935 return run_command_lines (cmd, argc, argv);
2937 if (strcasecmp (cmd, "stat") == 0)
2938 return run_stat (cmd, argc, argv);
2940 if (strcasecmp (cmd, "lstat") == 0)
2941 return run_lstat (cmd, argc, argv);
2943 if (strcasecmp (cmd, "statvfs") == 0)
2944 return run_statvfs (cmd, argc, argv);
2946 if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
2947 return run_tune2fs_l (cmd, argc, argv);
2949 if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
2950 return run_blockdev_setro (cmd, argc, argv);
2952 if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
2953 return run_blockdev_setrw (cmd, argc, argv);
2955 if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
2956 return run_blockdev_getro (cmd, argc, argv);
2958 if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
2959 return run_blockdev_getss (cmd, argc, argv);
2961 if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
2962 return run_blockdev_getbsz (cmd, argc, argv);
2964 if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
2965 return run_blockdev_setbsz (cmd, argc, argv);
2967 if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
2968 return run_blockdev_getsz (cmd, argc, argv);
2970 if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
2971 return run_blockdev_getsize64 (cmd, argc, argv);
2973 if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
2974 return run_blockdev_flushbufs (cmd, argc, argv);
2976 if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
2977 return run_blockdev_rereadpt (cmd, argc, argv);
2979 if (strcasecmp (cmd, "upload") == 0)
2980 return run_upload (cmd, argc, argv);
2982 if (strcasecmp (cmd, "download") == 0)
2983 return run_download (cmd, argc, argv);
2985 if (strcasecmp (cmd, "checksum") == 0)
2986 return run_checksum (cmd, argc, argv);
2988 if (strcasecmp (cmd, "tar_in") == 0 || strcasecmp (cmd, "tar-in") == 0)
2989 return run_tar_in (cmd, argc, argv);
2991 if (strcasecmp (cmd, "tar_out") == 0 || strcasecmp (cmd, "tar-out") == 0)
2992 return run_tar_out (cmd, argc, argv);
2994 if (strcasecmp (cmd, "tgz_in") == 0 || strcasecmp (cmd, "tgz-in") == 0)
2995 return run_tgz_in (cmd, argc, argv);
2997 if (strcasecmp (cmd, "tgz_out") == 0 || strcasecmp (cmd, "tgz-out") == 0)
2998 return run_tgz_out (cmd, argc, argv);
3000 if (strcasecmp (cmd, "mount_ro") == 0 || strcasecmp (cmd, "mount-ro") == 0)
3001 return run_mount_ro (cmd, argc, argv);
3003 if (strcasecmp (cmd, "mount_options") == 0 || strcasecmp (cmd, "mount-options") == 0)
3004 return run_mount_options (cmd, argc, argv);
3006 if (strcasecmp (cmd, "mount_vfs") == 0 || strcasecmp (cmd, "mount-vfs") == 0)
3007 return run_mount_vfs (cmd, argc, argv);
3009 if (strcasecmp (cmd, "debug") == 0)
3010 return run_debug (cmd, argc, argv);
3012 if (strcasecmp (cmd, "lvremove") == 0)
3013 return run_lvremove (cmd, argc, argv);
3015 if (strcasecmp (cmd, "vgremove") == 0)
3016 return run_vgremove (cmd, argc, argv);
3018 if (strcasecmp (cmd, "pvremove") == 0)
3019 return run_pvremove (cmd, argc, argv);
3021 if (strcasecmp (cmd, "set_e2label") == 0 || strcasecmp (cmd, "set-e2label") == 0)
3022 return run_set_e2label (cmd, argc, argv);
3024 if (strcasecmp (cmd, "get_e2label") == 0 || strcasecmp (cmd, "get-e2label") == 0)
3025 return run_get_e2label (cmd, argc, argv);
3027 if (strcasecmp (cmd, "set_e2uuid") == 0 || strcasecmp (cmd, "set-e2uuid") == 0)
3028 return run_set_e2uuid (cmd, argc, argv);
3030 if (strcasecmp (cmd, "get_e2uuid") == 0 || strcasecmp (cmd, "get-e2uuid") == 0)
3031 return run_get_e2uuid (cmd, argc, argv);
3033 if (strcasecmp (cmd, "fsck") == 0)
3034 return run_fsck (cmd, argc, argv);
3036 if (strcasecmp (cmd, "zero") == 0)
3037 return run_zero (cmd, argc, argv);
3039 if (strcasecmp (cmd, "grub_install") == 0 || strcasecmp (cmd, "grub-install") == 0)
3040 return run_grub_install (cmd, argc, argv);
3042 if (strcasecmp (cmd, "cp") == 0)
3043 return run_cp (cmd, argc, argv);
3045 if (strcasecmp (cmd, "cp_a") == 0 || strcasecmp (cmd, "cp-a") == 0)
3046 return run_cp_a (cmd, argc, argv);
3048 if (strcasecmp (cmd, "mv") == 0)
3049 return run_mv (cmd, argc, argv);
3051 if (strcasecmp (cmd, "drop_caches") == 0 || strcasecmp (cmd, "drop-caches") == 0)
3052 return run_drop_caches (cmd, argc, argv);
3054 if (strcasecmp (cmd, "dmesg") == 0)
3055 return run_dmesg (cmd, argc, argv);
3057 if (strcasecmp (cmd, "ping_daemon") == 0 || strcasecmp (cmd, "ping-daemon") == 0)
3058 return run_ping_daemon (cmd, argc, argv);
3060 if (strcasecmp (cmd, "equal") == 0)
3061 return run_equal (cmd, argc, argv);
3063 if (strcasecmp (cmd, "strings") == 0)
3064 return run_strings (cmd, argc, argv);
3066 if (strcasecmp (cmd, "strings_e") == 0 || strcasecmp (cmd, "strings-e") == 0)
3067 return run_strings_e (cmd, argc, argv);
3069 if (strcasecmp (cmd, "hexdump") == 0)
3070 return run_hexdump (cmd, argc, argv);
3072 if (strcasecmp (cmd, "zerofree") == 0)
3073 return run_zerofree (cmd, argc, argv);
3075 if (strcasecmp (cmd, "pvresize") == 0)
3076 return run_pvresize (cmd, argc, argv);
3078 if (strcasecmp (cmd, "sfdisk_N") == 0 || strcasecmp (cmd, "sfdisk-N") == 0)
3079 return run_sfdisk_N (cmd, argc, argv);
3081 if (strcasecmp (cmd, "sfdisk_l") == 0 || strcasecmp (cmd, "sfdisk-l") == 0)
3082 return run_sfdisk_l (cmd, argc, argv);
3084 if (strcasecmp (cmd, "sfdisk_kernel_geometry") == 0 || strcasecmp (cmd, "sfdisk-kernel-geometry") == 0)
3085 return run_sfdisk_kernel_geometry (cmd, argc, argv);
3087 if (strcasecmp (cmd, "sfdisk_disk_geometry") == 0 || strcasecmp (cmd, "sfdisk-disk-geometry") == 0)
3088 return run_sfdisk_disk_geometry (cmd, argc, argv);
3090 if (strcasecmp (cmd, "vg_activate_all") == 0 || strcasecmp (cmd, "vg-activate-all") == 0)
3091 return run_vg_activate_all (cmd, argc, argv);
3093 if (strcasecmp (cmd, "vg_activate") == 0 || strcasecmp (cmd, "vg-activate") == 0)
3094 return run_vg_activate (cmd, argc, argv);
3096 if (strcasecmp (cmd, "lvresize") == 0)
3097 return run_lvresize (cmd, argc, argv);
3099 if (strcasecmp (cmd, "resize2fs") == 0)
3100 return run_resize2fs (cmd, argc, argv);
3102 if (strcasecmp (cmd, "find") == 0)
3103 return run_find (cmd, argc, argv);
3105 if (strcasecmp (cmd, "e2fsck_f") == 0 || strcasecmp (cmd, "e2fsck-f") == 0)
3106 return run_e2fsck_f (cmd, argc, argv);
3108 if (strcasecmp (cmd, "sleep") == 0)
3109 return run_sleep (cmd, argc, argv);
3112 fprintf (stderr, "%s: unknown command\n", cmd);