Add support for zerofree command.
[libguestfs.git] / fish / cmds.c
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.
4  *
5  * Copyright (C) 2009 Red Hat Inc.
6  *
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.
11  *
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.
16  *
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.
20  */
21
22 #include <stdio.h>
23 #include <stdlib.h>
24 #include <string.h>
25 #include <inttypes.h>
26
27 #include <guestfs.h>
28 #include "fish.h"
29
30 void list_commands (void)
31 {
32   printf ("    %-16s     %s\n", "Command", "Description");
33   list_builtin_commands ();
34   printf ("%-20s %s\n", "add-cdrom", "add a CD-ROM disk image to examine");
35   printf ("%-20s %s\n", "add-drive", "add an image to examine or modify");
36   printf ("%-20s %s\n", "aug-close", "close the current Augeas handle");
37   printf ("%-20s %s\n", "aug-defnode", "define an Augeas node");
38   printf ("%-20s %s\n", "aug-defvar", "define an Augeas variable");
39   printf ("%-20s %s\n", "aug-get", "look up the value of an Augeas path");
40   printf ("%-20s %s\n", "aug-init", "create a new Augeas handle");
41   printf ("%-20s %s\n", "aug-insert", "insert a sibling Augeas node");
42   printf ("%-20s %s\n", "aug-load", "load files into the tree");
43   printf ("%-20s %s\n", "aug-ls", "list Augeas nodes under a path");
44   printf ("%-20s %s\n", "aug-match", "return Augeas nodes which match path");
45   printf ("%-20s %s\n", "aug-mv", "move Augeas node");
46   printf ("%-20s %s\n", "aug-rm", "remove an Augeas path");
47   printf ("%-20s %s\n", "aug-save", "write all pending Augeas changes to disk");
48   printf ("%-20s %s\n", "aug-set", "set Augeas path to value");
49   printf ("%-20s %s\n", "blockdev-flushbufs", "flush device buffers");
50   printf ("%-20s %s\n", "blockdev-getbsz", "get blocksize of block device");
51   printf ("%-20s %s\n", "blockdev-getro", "is block device set to read-only");
52   printf ("%-20s %s\n", "blockdev-getsize64", "get total size of device in bytes");
53   printf ("%-20s %s\n", "blockdev-getss", "get sectorsize of block device");
54   printf ("%-20s %s\n", "blockdev-getsz", "get total size of device in 512-byte sectors");
55   printf ("%-20s %s\n", "blockdev-rereadpt", "reread partition table");
56   printf ("%-20s %s\n", "blockdev-setbsz", "set blocksize of block device");
57   printf ("%-20s %s\n", "blockdev-setro", "set block device to read-only");
58   printf ("%-20s %s\n", "blockdev-setrw", "set block device to read-write");
59   printf ("%-20s %s\n", "cat", "list the contents of a file");
60   printf ("%-20s %s\n", "checksum", "compute MD5, SHAx or CRC checksum of file");
61   printf ("%-20s %s\n", "chmod", "change file mode");
62   printf ("%-20s %s\n", "chown", "change file owner and group");
63   printf ("%-20s %s\n", "command", "run a command from the guest filesystem");
64   printf ("%-20s %s\n", "command-lines", "run a command, returning lines");
65   printf ("%-20s %s\n", "config", "add qemu parameters");
66   printf ("%-20s %s\n", "cp", "copy a file");
67   printf ("%-20s %s\n", "cp-a", "copy a file or directory recursively");
68   printf ("%-20s %s\n", "debug", "debugging and internals");
69   printf ("%-20s %s\n", "dmesg", "return kernel messages");
70   printf ("%-20s %s\n", "download", "download a file to the local machine");
71   printf ("%-20s %s\n", "drop-caches", "drop kernel page cache, dentries and inodes");
72   printf ("%-20s %s\n", "equal", "test if two files have equal contents");
73   printf ("%-20s %s\n", "exists", "test if file or directory exists");
74   printf ("%-20s %s\n", "file", "determine file type");
75   printf ("%-20s %s\n", "fsck", "run the filesystem checker");
76   printf ("%-20s %s\n", "get-append", "get the additional kernel options");
77   printf ("%-20s %s\n", "get-autosync", "get autosync mode");
78   printf ("%-20s %s\n", "get-e2label", "get the ext2/3/4 filesystem label");
79   printf ("%-20s %s\n", "get-e2uuid", "get the ext2/3/4 filesystem UUID");
80   printf ("%-20s %s\n", "get-path", "get the search path");
81   printf ("%-20s %s\n", "get-qemu", "get the qemu binary");
82   printf ("%-20s %s\n", "get-state", "get the current state");
83   printf ("%-20s %s\n", "get-verbose", "get verbose mode");
84   printf ("%-20s %s\n", "grub-install", "install GRUB");
85   printf ("%-20s %s\n", "hexdump", "dump a file in hexadecimal");
86   printf ("%-20s %s\n", "is-busy", "is busy processing a command");
87   printf ("%-20s %s\n", "is-config", "is in configuration state");
88   printf ("%-20s %s\n", "is-dir", "test if file exists");
89   printf ("%-20s %s\n", "is-file", "test if file exists");
90   printf ("%-20s %s\n", "is-launching", "is launching subprocess");
91   printf ("%-20s %s\n", "is-ready", "is ready to accept commands");
92   printf ("%-20s %s\n", "kill-subprocess", "kill the qemu subprocess");
93   printf ("%-20s %s\n", "launch", "launch the qemu subprocess");
94   printf ("%-20s %s\n", "list-devices", "list the block devices");
95   printf ("%-20s %s\n", "list-partitions", "list the partitions");
96   printf ("%-20s %s\n", "ll", "list the files in a directory (long format)");
97   printf ("%-20s %s\n", "ls", "list the files in a directory");
98   printf ("%-20s %s\n", "lstat", "get file information for a symbolic link");
99   printf ("%-20s %s\n", "lvcreate", "create an LVM volume group");
100   printf ("%-20s %s\n", "lvm-remove-all", "remove all LVM LVs, VGs and PVs");
101   printf ("%-20s %s\n", "lvremove", "remove an LVM logical volume");
102   printf ("%-20s %s\n", "lvs", "list the LVM logical volumes (LVs)");
103   printf ("%-20s %s\n", "lvs-full", "list the LVM logical volumes (LVs)");
104   printf ("%-20s %s\n", "mkdir", "create a directory");
105   printf ("%-20s %s\n", "mkdir-p", "create a directory and parents");
106   printf ("%-20s %s\n", "mkfs", "make a filesystem");
107   printf ("%-20s %s\n", "mount", "mount a guest disk at a position in the filesystem");
108   printf ("%-20s %s\n", "mount-options", "mount a guest disk with mount options");
109   printf ("%-20s %s\n", "mount-ro", "mount a guest disk, read-only");
110   printf ("%-20s %s\n", "mount-vfs", "mount a guest disk with mount options and vfstype");
111   printf ("%-20s %s\n", "mounts", "show mounted filesystems");
112   printf ("%-20s %s\n", "mv", "move a file");
113   printf ("%-20s %s\n", "ping-daemon", "ping the guest daemon");
114   printf ("%-20s %s\n", "pvcreate", "create an LVM physical volume");
115   printf ("%-20s %s\n", "pvremove", "remove an LVM physical volume");
116   printf ("%-20s %s\n", "pvs", "list the LVM physical volumes (PVs)");
117   printf ("%-20s %s\n", "pvs-full", "list the LVM physical volumes (PVs)");
118   printf ("%-20s %s\n", "read-lines", "read file as lines");
119   printf ("%-20s %s\n", "rm", "remove a file");
120   printf ("%-20s %s\n", "rm-rf", "remove a file or directory recursively");
121   printf ("%-20s %s\n", "rmdir", "remove a directory");
122   printf ("%-20s %s\n", "set-append", "add options to kernel command line");
123   printf ("%-20s %s\n", "set-autosync", "set autosync mode");
124   printf ("%-20s %s\n", "set-e2label", "set the ext2/3/4 filesystem label");
125   printf ("%-20s %s\n", "set-e2uuid", "set the ext2/3/4 filesystem UUID");
126   printf ("%-20s %s\n", "set-path", "set the search path");
127   printf ("%-20s %s\n", "set-qemu", "set the qemu binary");
128   printf ("%-20s %s\n", "set-verbose", "set verbose mode");
129   printf ("%-20s %s\n", "sfdisk", "create partitions on a block device");
130   printf ("%-20s %s\n", "stat", "get file information");
131   printf ("%-20s %s\n", "statvfs", "get file system statistics");
132   printf ("%-20s %s\n", "strings", "print the printable strings in a file");
133   printf ("%-20s %s\n", "strings-e", "print the printable strings in a file");
134   printf ("%-20s %s\n", "sync", "sync disks, writes are flushed through to the disk image");
135   printf ("%-20s %s\n", "tar-in", "unpack tarfile to directory");
136   printf ("%-20s %s\n", "tar-out", "pack directory into tarfile");
137   printf ("%-20s %s\n", "tgz-in", "unpack compressed tarball to directory");
138   printf ("%-20s %s\n", "tgz-out", "pack directory into compressed tarball");
139   printf ("%-20s %s\n", "touch", "update file timestamps or create a new file");
140   printf ("%-20s %s\n", "tune2fs-l", "get ext2/ext3/ext4 superblock details");
141   printf ("%-20s %s\n", "umount", "unmount a filesystem");
142   printf ("%-20s %s\n", "umount-all", "unmount all filesystems");
143   printf ("%-20s %s\n", "upload", "upload a file from the local machine");
144   printf ("%-20s %s\n", "vgcreate", "create an LVM volume group");
145   printf ("%-20s %s\n", "vgremove", "remove an LVM volume group");
146   printf ("%-20s %s\n", "vgs", "list the LVM volume groups (VGs)");
147   printf ("%-20s %s\n", "vgs-full", "list the LVM volume groups (VGs)");
148   printf ("%-20s %s\n", "write-file", "create a file");
149   printf ("%-20s %s\n", "zero", "write zeroes to the device");
150   printf ("%-20s %s\n", "zerofree", "zero unused inodes and disk blocks on ext2/3 filesystem");
151   printf ("    Use -h <cmd> / help <cmd> to show detailed help for a command.\n");
152 }
153
154 void display_command (const char *cmd)
155 {
156   if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
157     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.");
158   else
159   if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
160     pod2text ("kill-subprocess - kill the qemu subprocess", " kill-subprocess\n\nThis kills the qemu subprocess.  You should never need to call this.");
161   else
162   if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
163     pod2text ("add-drive - add an image to examine or modify", " add-drive <filename>\n\nThis function adds a virtual machine disk image C<filename> to the\nguest.  The first time you call this function, the disk appears as IDE\ndisk 0 (C</dev/sda>) in the guest, the second time as C</dev/sdb>, and\nso on.\n\nYou don't necessarily need to be root when using libguestfs.  However\nyou obviously do need sufficient permissions to access the filename\nfor whatever operations you want to perform (ie. read access if you\njust want to read the image or write access if you want to modify the\nimage).\n\nThis is equivalent to the qemu parameter C<-drive file=filename>.\n\nYou can use 'add' as an alias for this command.");
164   else
165   if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
166     pod2text ("add-cdrom - add a CD-ROM disk image to examine", " add-cdrom <filename>\n\nThis function adds a virtual CD-ROM disk image to the guest.\n\nThis is equivalent to the qemu parameter C<-cdrom filename>.\n\nYou can use 'cdrom' as an alias for this command.");
167   else
168   if (strcasecmp (cmd, "config") == 0)
169     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.");
170   else
171   if (strcasecmp (cmd, "set_qemu") == 0 || strcasecmp (cmd, "set-qemu") == 0 || strcasecmp (cmd, "qemu") == 0)
172     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.");
173   else
174   if (strcasecmp (cmd, "get_qemu") == 0 || strcasecmp (cmd, "get-qemu") == 0)
175     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.");
176   else
177   if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
178     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.");
179   else
180   if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
181     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.");
182   else
183   if (strcasecmp (cmd, "set_append") == 0 || strcasecmp (cmd, "set-append") == 0 || strcasecmp (cmd, "append") == 0)
184     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.");
185   else
186   if (strcasecmp (cmd, "get_append") == 0 || strcasecmp (cmd, "get-append") == 0)
187     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.");
188   else
189   if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
190     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.");
191   else
192   if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
193     pod2text ("get-autosync - get autosync mode", " get-autosync\n\nGet the autosync flag.");
194   else
195   if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
196     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.");
197   else
198   if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
199     pod2text ("get-verbose - get verbose mode", " get-verbose\n\nThis returns the verbose messages flag.");
200   else
201   if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
202     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)>.");
203   else
204   if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
205     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)>.");
206   else
207   if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
208     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)>.");
209   else
210   if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
211     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)>.");
212   else
213   if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
214     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)>.");
215   else
216   if (strcasecmp (cmd, "mount") == 0)
217     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.");
218   else
219   if (strcasecmp (cmd, "sync") == 0)
220     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.");
221   else
222   if (strcasecmp (cmd, "touch") == 0)
223     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.");
224   else
225   if (strcasecmp (cmd, "cat") == 0)
226     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.");
227   else
228   if (strcasecmp (cmd, "ll") == 0)
229     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.");
230   else
231   if (strcasecmp (cmd, "ls") == 0)
232     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.");
233   else
234   if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
235     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>");
236   else
237   if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
238     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>.");
239   else
240   if (strcasecmp (cmd, "pvs") == 0)
241     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>.");
242   else
243   if (strcasecmp (cmd, "vgs") == 0)
244     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>.");
245   else
246   if (strcasecmp (cmd, "lvs") == 0)
247     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>.");
248   else
249   if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
250     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.");
251   else
252   if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
253     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.");
254   else
255   if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
256     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.");
257   else
258   if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
259     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.");
260   else
261   if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
262     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/>.");
263   else
264   if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
265     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.");
266   else
267   if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
268     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.");
269   else
270   if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
271     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.");
272   else
273   if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
274     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.");
275   else
276   if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
277     pod2text ("aug-set - set Augeas path to value", " aug-set <path> <val>\n\nSet the value associated with C<path> to C<value>.");
278   else
279   if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
280     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]>.");
281   else
282   if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
283     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.");
284   else
285   if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
286     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.");
287   else
288   if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
289     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.");
290   else
291   if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
292     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.");
293   else
294   if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
295     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.");
296   else
297   if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
298     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.");
299   else
300   if (strcasecmp (cmd, "rm") == 0)
301     pod2text ("rm - remove a file", " rm <path>\n\nRemove the single file C<path>.");
302   else
303   if (strcasecmp (cmd, "rmdir") == 0)
304     pod2text ("rmdir - remove a directory", " rmdir <path>\n\nRemove the single directory C<path>.");
305   else
306   if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
307     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.");
308   else
309   if (strcasecmp (cmd, "mkdir") == 0)
310     pod2text ("mkdir - create a directory", " mkdir <path>\n\nCreate a directory named C<path>.");
311   else
312   if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
313     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.");
314   else
315   if (strcasecmp (cmd, "chmod") == 0)
316     pod2text ("chmod - change file mode", " chmod <mode> <path>\n\nChange the mode (permissions) of C<path> to C<mode>.  Only\nnumeric modes are supported.");
317   else
318   if (strcasecmp (cmd, "chown") == 0)
319     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).");
320   else
321   if (strcasecmp (cmd, "exists") == 0)
322     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>.");
323   else
324   if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
325     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>.");
326   else
327   if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
328     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>.");
329   else
330   if (strcasecmp (cmd, "pvcreate") == 0)
331     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>.");
332   else
333   if (strcasecmp (cmd, "vgcreate") == 0)
334     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>.");
335   else
336   if (strcasecmp (cmd, "lvcreate") == 0)
337     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.");
338   else
339   if (strcasecmp (cmd, "mkfs") == 0)
340     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>.");
341   else
342   if (strcasecmp (cmd, "sfdisk") == 0)
343     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\nB<This command is dangerous.  Without careful use you\ncan easily destroy all your data>.");
344   else
345   if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
346     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.");
347   else
348   if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
349     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.");
350   else
351   if (strcasecmp (cmd, "mounts") == 0)
352     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.");
353   else
354   if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
355     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.");
356   else
357   if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
358     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>.");
359   else
360   if (strcasecmp (cmd, "file") == 0)
361     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).");
362   else
363   if (strcasecmp (cmd, "command") == 0)
364     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.");
365   else
366   if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
367     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.");
368   else
369   if (strcasecmp (cmd, "stat") == 0)
370     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.");
371   else
372   if (strcasecmp (cmd, "lstat") == 0)
373     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.");
374   else
375   if (strcasecmp (cmd, "statvfs") == 0)
376     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.");
377   else
378   if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
379     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.");
380   else
381   if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
382     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.");
383   else
384   if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
385     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.");
386   else
387   if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
388     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.");
389   else
390   if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
391     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.");
392   else
393   if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
394     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.");
395   else
396   if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
397     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.");
398   else
399   if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
400     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.");
401   else
402   if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
403     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.");
404   else
405   if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
406     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.");
407   else
408   if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
409     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.");
410   else
411   if (strcasecmp (cmd, "upload") == 0)
412     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>.");
413   else
414   if (strcasecmp (cmd, "download") == 0)
415     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>.");
416   else
417   if (strcasecmp (cmd, "checksum") == 0)
418     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.");
419   else
420   if (strcasecmp (cmd, "tar_in") == 0 || strcasecmp (cmd, "tar-in") == 0)
421     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>.");
422   else
423   if (strcasecmp (cmd, "tar_out") == 0 || strcasecmp (cmd, "tar-out") == 0)
424     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>.");
425   else
426   if (strcasecmp (cmd, "tgz_in") == 0 || strcasecmp (cmd, "tgz-in") == 0)
427     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>.");
428   else
429   if (strcasecmp (cmd, "tgz_out") == 0 || strcasecmp (cmd, "tgz-out") == 0)
430     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>.");
431   else
432   if (strcasecmp (cmd, "mount_ro") == 0 || strcasecmp (cmd, "mount-ro") == 0)
433     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.");
434   else
435   if (strcasecmp (cmd, "mount_options") == 0 || strcasecmp (cmd, "mount-options") == 0)
436     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.");
437   else
438   if (strcasecmp (cmd, "mount_vfs") == 0 || strcasecmp (cmd, "mount-vfs") == 0)
439     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.");
440   else
441   if (strcasecmp (cmd, "debug") == 0)
442     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.");
443   else
444   if (strcasecmp (cmd, "lvremove") == 0)
445     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>.");
446   else
447   if (strcasecmp (cmd, "vgremove") == 0)
448     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).");
449   else
450   if (strcasecmp (cmd, "pvremove") == 0)
451     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.");
452   else
453   if (strcasecmp (cmd, "set_e2label") == 0 || strcasecmp (cmd, "set-e2label") == 0)
454     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.");
455   else
456   if (strcasecmp (cmd, "get_e2label") == 0 || strcasecmp (cmd, "get-e2label") == 0)
457     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>.");
458   else
459   if (strcasecmp (cmd, "set_e2uuid") == 0 || strcasecmp (cmd, "set-e2uuid") == 0)
460     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.");
461   else
462   if (strcasecmp (cmd, "get_e2uuid") == 0 || strcasecmp (cmd, "get-e2uuid") == 0)
463     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>.");
464   else
465   if (strcasecmp (cmd, "fsck") == 0)
466     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>.");
467   else
468   if (strcasecmp (cmd, "zero") == 0)
469     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.");
470   else
471   if (strcasecmp (cmd, "grub_install") == 0 || strcasecmp (cmd, "grub-install") == 0)
472     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>.");
473   else
474   if (strcasecmp (cmd, "cp") == 0)
475     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.");
476   else
477   if (strcasecmp (cmd, "cp_a") == 0 || strcasecmp (cmd, "cp-a") == 0)
478     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.");
479   else
480   if (strcasecmp (cmd, "mv") == 0)
481     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.");
482   else
483   if (strcasecmp (cmd, "drop_caches") == 0 || strcasecmp (cmd, "drop-caches") == 0)
484     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.");
485   else
486   if (strcasecmp (cmd, "dmesg") == 0)
487     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.");
488   else
489   if (strcasecmp (cmd, "ping_daemon") == 0 || strcasecmp (cmd, "ping-daemon") == 0)
490     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.");
491   else
492   if (strcasecmp (cmd, "equal") == 0)
493     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.");
494   else
495   if (strcasecmp (cmd, "strings") == 0)
496     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.");
497   else
498   if (strcasecmp (cmd, "strings_e") == 0 || strcasecmp (cmd, "strings-e") == 0)
499     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.");
500   else
501   if (strcasecmp (cmd, "hexdump") == 0)
502     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.");
503   else
504   if (strcasecmp (cmd, "zerofree") == 0)
505     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.");
506   else
507     display_builtin_command (cmd);
508 }
509
510 static void print_pv (struct guestfs_lvm_pv *pv)
511 {
512   int i;
513
514   printf ("pv_name: %s\n", pv->pv_name);
515   printf ("pv_uuid: ");
516   for (i = 0; i < 32; ++i)
517     printf ("%c", pv->pv_uuid[i]);
518   printf ("\n");
519   printf ("pv_fmt: %s\n", pv->pv_fmt);
520   printf ("pv_size: %" PRIu64 "\n", pv->pv_size);
521   printf ("dev_size: %" PRIu64 "\n", pv->dev_size);
522   printf ("pv_free: %" PRIu64 "\n", pv->pv_free);
523   printf ("pv_used: %" PRIu64 "\n", pv->pv_used);
524   printf ("pv_attr: %s\n", pv->pv_attr);
525   printf ("pv_pe_count: %" PRIi64 "\n", pv->pv_pe_count);
526   printf ("pv_pe_alloc_count: %" PRIi64 "\n", pv->pv_pe_alloc_count);
527   printf ("pv_tags: %s\n", pv->pv_tags);
528   printf ("pe_start: %" PRIu64 "\n", pv->pe_start);
529   printf ("pv_mda_count: %" PRIi64 "\n", pv->pv_mda_count);
530   printf ("pv_mda_free: %" PRIu64 "\n", pv->pv_mda_free);
531 }
532
533 static void print_pv_list (struct guestfs_lvm_pv_list *pvs)
534 {
535   int i;
536
537   for (i = 0; i < pvs->len; ++i)
538     print_pv (&pvs->val[i]);
539 }
540
541 static void print_vg (struct guestfs_lvm_vg *vg)
542 {
543   int i;
544
545   printf ("vg_name: %s\n", vg->vg_name);
546   printf ("vg_uuid: ");
547   for (i = 0; i < 32; ++i)
548     printf ("%c", vg->vg_uuid[i]);
549   printf ("\n");
550   printf ("vg_fmt: %s\n", vg->vg_fmt);
551   printf ("vg_attr: %s\n", vg->vg_attr);
552   printf ("vg_size: %" PRIu64 "\n", vg->vg_size);
553   printf ("vg_free: %" PRIu64 "\n", vg->vg_free);
554   printf ("vg_sysid: %s\n", vg->vg_sysid);
555   printf ("vg_extent_size: %" PRIu64 "\n", vg->vg_extent_size);
556   printf ("vg_extent_count: %" PRIi64 "\n", vg->vg_extent_count);
557   printf ("vg_free_count: %" PRIi64 "\n", vg->vg_free_count);
558   printf ("max_lv: %" PRIi64 "\n", vg->max_lv);
559   printf ("max_pv: %" PRIi64 "\n", vg->max_pv);
560   printf ("pv_count: %" PRIi64 "\n", vg->pv_count);
561   printf ("lv_count: %" PRIi64 "\n", vg->lv_count);
562   printf ("snap_count: %" PRIi64 "\n", vg->snap_count);
563   printf ("vg_seqno: %" PRIi64 "\n", vg->vg_seqno);
564   printf ("vg_tags: %s\n", vg->vg_tags);
565   printf ("vg_mda_count: %" PRIi64 "\n", vg->vg_mda_count);
566   printf ("vg_mda_free: %" PRIu64 "\n", vg->vg_mda_free);
567 }
568
569 static void print_vg_list (struct guestfs_lvm_vg_list *vgs)
570 {
571   int i;
572
573   for (i = 0; i < vgs->len; ++i)
574     print_vg (&vgs->val[i]);
575 }
576
577 static void print_lv (struct guestfs_lvm_lv *lv)
578 {
579   int i;
580
581   printf ("lv_name: %s\n", lv->lv_name);
582   printf ("lv_uuid: ");
583   for (i = 0; i < 32; ++i)
584     printf ("%c", lv->lv_uuid[i]);
585   printf ("\n");
586   printf ("lv_attr: %s\n", lv->lv_attr);
587   printf ("lv_major: %" PRIi64 "\n", lv->lv_major);
588   printf ("lv_minor: %" PRIi64 "\n", lv->lv_minor);
589   printf ("lv_kernel_major: %" PRIi64 "\n", lv->lv_kernel_major);
590   printf ("lv_kernel_minor: %" PRIi64 "\n", lv->lv_kernel_minor);
591   printf ("lv_size: %" PRIu64 "\n", lv->lv_size);
592   printf ("seg_count: %" PRIi64 "\n", lv->seg_count);
593   printf ("origin: %s\n", lv->origin);
594   if (lv->snap_percent >= 0) printf ("snap_percent: %g %%\n", lv->snap_percent);
595   else printf ("snap_percent: \n");
596   if (lv->copy_percent >= 0) printf ("copy_percent: %g %%\n", lv->copy_percent);
597   else printf ("copy_percent: \n");
598   printf ("move_pv: %s\n", lv->move_pv);
599   printf ("lv_tags: %s\n", lv->lv_tags);
600   printf ("mirror_log: %s\n", lv->mirror_log);
601   printf ("modules: %s\n", lv->modules);
602 }
603
604 static void print_lv_list (struct guestfs_lvm_lv_list *lvs)
605 {
606   int i;
607
608   for (i = 0; i < lvs->len; ++i)
609     print_lv (&lvs->val[i]);
610 }
611
612 static void print_stat (struct guestfs_stat *stat)
613 {
614   printf ("dev: %" PRIi64 "\n", stat->dev);
615   printf ("ino: %" PRIi64 "\n", stat->ino);
616   printf ("mode: %" PRIi64 "\n", stat->mode);
617   printf ("nlink: %" PRIi64 "\n", stat->nlink);
618   printf ("uid: %" PRIi64 "\n", stat->uid);
619   printf ("gid: %" PRIi64 "\n", stat->gid);
620   printf ("rdev: %" PRIi64 "\n", stat->rdev);
621   printf ("size: %" PRIi64 "\n", stat->size);
622   printf ("blksize: %" PRIi64 "\n", stat->blksize);
623   printf ("blocks: %" PRIi64 "\n", stat->blocks);
624   printf ("atime: %" PRIi64 "\n", stat->atime);
625   printf ("mtime: %" PRIi64 "\n", stat->mtime);
626   printf ("ctime: %" PRIi64 "\n", stat->ctime);
627 }
628
629 static void print_statvfs (struct guestfs_statvfs *statvfs)
630 {
631   printf ("bsize: %" PRIi64 "\n", statvfs->bsize);
632   printf ("frsize: %" PRIi64 "\n", statvfs->frsize);
633   printf ("blocks: %" PRIi64 "\n", statvfs->blocks);
634   printf ("bfree: %" PRIi64 "\n", statvfs->bfree);
635   printf ("bavail: %" PRIi64 "\n", statvfs->bavail);
636   printf ("files: %" PRIi64 "\n", statvfs->files);
637   printf ("ffree: %" PRIi64 "\n", statvfs->ffree);
638   printf ("favail: %" PRIi64 "\n", statvfs->favail);
639   printf ("fsid: %" PRIi64 "\n", statvfs->fsid);
640   printf ("flag: %" PRIi64 "\n", statvfs->flag);
641   printf ("namemax: %" PRIi64 "\n", statvfs->namemax);
642 }
643
644 static int run_launch (const char *cmd, int argc, char *argv[])
645 {
646   int r;
647   if (argc != 0) {
648     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
649     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
650     return -1;
651   }
652   r = launch (g);
653   return r;
654 }
655
656 static int run_kill_subprocess (const char *cmd, int argc, char *argv[])
657 {
658   int r;
659   if (argc != 0) {
660     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
661     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
662     return -1;
663   }
664   r = guestfs_kill_subprocess (g);
665   return r;
666 }
667
668 static int run_add_drive (const char *cmd, int argc, char *argv[])
669 {
670   int r;
671   const char *filename;
672   if (argc != 1) {
673     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
674     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
675     return -1;
676   }
677   filename = argv[0];
678   r = guestfs_add_drive (g, filename);
679   return r;
680 }
681
682 static int run_add_cdrom (const char *cmd, int argc, char *argv[])
683 {
684   int r;
685   const char *filename;
686   if (argc != 1) {
687     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
688     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
689     return -1;
690   }
691   filename = argv[0];
692   r = guestfs_add_cdrom (g, filename);
693   return r;
694 }
695
696 static int run_config (const char *cmd, int argc, char *argv[])
697 {
698   int r;
699   const char *qemuparam;
700   const char *qemuvalue;
701   if (argc != 2) {
702     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
703     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
704     return -1;
705   }
706   qemuparam = argv[0];
707   qemuvalue = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
708   r = guestfs_config (g, qemuparam, qemuvalue);
709   return r;
710 }
711
712 static int run_set_qemu (const char *cmd, int argc, char *argv[])
713 {
714   int r;
715   const char *qemu;
716   if (argc != 1) {
717     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
718     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
719     return -1;
720   }
721   qemu = argv[0];
722   r = guestfs_set_qemu (g, qemu);
723   return r;
724 }
725
726 static int run_get_qemu (const char *cmd, int argc, char *argv[])
727 {
728   const char *r;
729   if (argc != 0) {
730     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
731     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
732     return -1;
733   }
734   r = guestfs_get_qemu (g);
735   if (r == NULL) return -1;
736   printf ("%s\n", r);
737   return 0;
738 }
739
740 static int run_set_path (const char *cmd, int argc, char *argv[])
741 {
742   int r;
743   const char *path;
744   if (argc != 1) {
745     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
746     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
747     return -1;
748   }
749   path = argv[0];
750   r = guestfs_set_path (g, path);
751   return r;
752 }
753
754 static int run_get_path (const char *cmd, int argc, char *argv[])
755 {
756   const char *r;
757   if (argc != 0) {
758     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
759     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
760     return -1;
761   }
762   r = guestfs_get_path (g);
763   if (r == NULL) return -1;
764   printf ("%s\n", r);
765   return 0;
766 }
767
768 static int run_set_append (const char *cmd, int argc, char *argv[])
769 {
770   int r;
771   const char *append;
772   if (argc != 1) {
773     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
774     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
775     return -1;
776   }
777   append = argv[0];
778   r = guestfs_set_append (g, append);
779   return r;
780 }
781
782 static int run_get_append (const char *cmd, int argc, char *argv[])
783 {
784   const char *r;
785   if (argc != 0) {
786     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
787     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
788     return -1;
789   }
790   r = guestfs_get_append (g);
791   if (r == NULL) return -1;
792   printf ("%s\n", r);
793   return 0;
794 }
795
796 static int run_set_autosync (const char *cmd, int argc, char *argv[])
797 {
798   int r;
799   int autosync;
800   if (argc != 1) {
801     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
802     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
803     return -1;
804   }
805   autosync = is_true (argv[0]) ? 1 : 0;
806   r = guestfs_set_autosync (g, autosync);
807   return r;
808 }
809
810 static int run_get_autosync (const char *cmd, int argc, char *argv[])
811 {
812   int r;
813   if (argc != 0) {
814     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
815     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
816     return -1;
817   }
818   r = guestfs_get_autosync (g);
819   if (r == -1) return -1;
820   if (r) printf ("true\n"); else printf ("false\n");
821   return 0;
822 }
823
824 static int run_set_verbose (const char *cmd, int argc, char *argv[])
825 {
826   int r;
827   int verbose;
828   if (argc != 1) {
829     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
830     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
831     return -1;
832   }
833   verbose = is_true (argv[0]) ? 1 : 0;
834   r = guestfs_set_verbose (g, verbose);
835   return r;
836 }
837
838 static int run_get_verbose (const char *cmd, int argc, char *argv[])
839 {
840   int r;
841   if (argc != 0) {
842     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
843     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
844     return -1;
845   }
846   r = guestfs_get_verbose (g);
847   if (r == -1) return -1;
848   if (r) printf ("true\n"); else printf ("false\n");
849   return 0;
850 }
851
852 static int run_is_ready (const char *cmd, int argc, char *argv[])
853 {
854   int r;
855   if (argc != 0) {
856     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
857     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
858     return -1;
859   }
860   r = guestfs_is_ready (g);
861   if (r == -1) return -1;
862   if (r) printf ("true\n"); else printf ("false\n");
863   return 0;
864 }
865
866 static int run_is_config (const char *cmd, int argc, char *argv[])
867 {
868   int r;
869   if (argc != 0) {
870     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
871     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
872     return -1;
873   }
874   r = guestfs_is_config (g);
875   if (r == -1) return -1;
876   if (r) printf ("true\n"); else printf ("false\n");
877   return 0;
878 }
879
880 static int run_is_launching (const char *cmd, int argc, char *argv[])
881 {
882   int r;
883   if (argc != 0) {
884     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
885     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
886     return -1;
887   }
888   r = guestfs_is_launching (g);
889   if (r == -1) return -1;
890   if (r) printf ("true\n"); else printf ("false\n");
891   return 0;
892 }
893
894 static int run_is_busy (const char *cmd, int argc, char *argv[])
895 {
896   int r;
897   if (argc != 0) {
898     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
899     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
900     return -1;
901   }
902   r = guestfs_is_busy (g);
903   if (r == -1) return -1;
904   if (r) printf ("true\n"); else printf ("false\n");
905   return 0;
906 }
907
908 static int run_get_state (const char *cmd, int argc, char *argv[])
909 {
910   int r;
911   if (argc != 0) {
912     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
913     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
914     return -1;
915   }
916   r = guestfs_get_state (g);
917   if (r == -1) return -1;
918   printf ("%d\n", r);
919   return 0;
920 }
921
922 static int run_mount (const char *cmd, int argc, char *argv[])
923 {
924   int r;
925   const char *device;
926   const char *mountpoint;
927   if (argc != 2) {
928     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
929     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
930     return -1;
931   }
932   device = argv[0];
933   mountpoint = argv[1];
934   r = guestfs_mount (g, device, mountpoint);
935   return r;
936 }
937
938 static int run_sync (const char *cmd, int argc, char *argv[])
939 {
940   int r;
941   if (argc != 0) {
942     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
943     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
944     return -1;
945   }
946   r = guestfs_sync (g);
947   return r;
948 }
949
950 static int run_touch (const char *cmd, int argc, char *argv[])
951 {
952   int r;
953   const char *path;
954   if (argc != 1) {
955     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
956     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
957     return -1;
958   }
959   path = argv[0];
960   r = guestfs_touch (g, path);
961   return r;
962 }
963
964 static int run_cat (const char *cmd, int argc, char *argv[])
965 {
966   char *r;
967   const char *path;
968   if (argc != 1) {
969     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
970     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
971     return -1;
972   }
973   path = argv[0];
974   r = guestfs_cat (g, path);
975   if (r == NULL) return -1;
976   printf ("%s\n", r);
977   free (r);
978   return 0;
979 }
980
981 static int run_ll (const char *cmd, int argc, char *argv[])
982 {
983   char *r;
984   const char *directory;
985   if (argc != 1) {
986     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
987     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
988     return -1;
989   }
990   directory = argv[0];
991   r = guestfs_ll (g, directory);
992   if (r == NULL) return -1;
993   printf ("%s\n", r);
994   free (r);
995   return 0;
996 }
997
998 static int run_ls (const char *cmd, int argc, char *argv[])
999 {
1000   char **r;
1001   const char *directory;
1002   if (argc != 1) {
1003     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1004     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1005     return -1;
1006   }
1007   directory = argv[0];
1008   r = guestfs_ls (g, directory);
1009   if (r == NULL) return -1;
1010   print_strings (r);
1011   free_strings (r);
1012   return 0;
1013 }
1014
1015 static int run_list_devices (const char *cmd, int argc, char *argv[])
1016 {
1017   char **r;
1018   if (argc != 0) {
1019     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1020     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1021     return -1;
1022   }
1023   r = guestfs_list_devices (g);
1024   if (r == NULL) return -1;
1025   print_strings (r);
1026   free_strings (r);
1027   return 0;
1028 }
1029
1030 static int run_list_partitions (const char *cmd, int argc, char *argv[])
1031 {
1032   char **r;
1033   if (argc != 0) {
1034     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1035     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1036     return -1;
1037   }
1038   r = guestfs_list_partitions (g);
1039   if (r == NULL) return -1;
1040   print_strings (r);
1041   free_strings (r);
1042   return 0;
1043 }
1044
1045 static int run_pvs (const char *cmd, int argc, char *argv[])
1046 {
1047   char **r;
1048   if (argc != 0) {
1049     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1050     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1051     return -1;
1052   }
1053   r = guestfs_pvs (g);
1054   if (r == NULL) return -1;
1055   print_strings (r);
1056   free_strings (r);
1057   return 0;
1058 }
1059
1060 static int run_vgs (const char *cmd, int argc, char *argv[])
1061 {
1062   char **r;
1063   if (argc != 0) {
1064     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1065     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1066     return -1;
1067   }
1068   r = guestfs_vgs (g);
1069   if (r == NULL) return -1;
1070   print_strings (r);
1071   free_strings (r);
1072   return 0;
1073 }
1074
1075 static int run_lvs (const char *cmd, int argc, char *argv[])
1076 {
1077   char **r;
1078   if (argc != 0) {
1079     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1080     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1081     return -1;
1082   }
1083   r = guestfs_lvs (g);
1084   if (r == NULL) return -1;
1085   print_strings (r);
1086   free_strings (r);
1087   return 0;
1088 }
1089
1090 static int run_pvs_full (const char *cmd, int argc, char *argv[])
1091 {
1092   struct guestfs_lvm_pv_list *r;
1093   if (argc != 0) {
1094     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1095     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1096     return -1;
1097   }
1098   r = guestfs_pvs_full (g);
1099   if (r == NULL) return -1;
1100   print_pv_list (r);
1101   guestfs_free_lvm_pv_list (r);
1102   return 0;
1103 }
1104
1105 static int run_vgs_full (const char *cmd, int argc, char *argv[])
1106 {
1107   struct guestfs_lvm_vg_list *r;
1108   if (argc != 0) {
1109     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1110     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1111     return -1;
1112   }
1113   r = guestfs_vgs_full (g);
1114   if (r == NULL) return -1;
1115   print_vg_list (r);
1116   guestfs_free_lvm_vg_list (r);
1117   return 0;
1118 }
1119
1120 static int run_lvs_full (const char *cmd, int argc, char *argv[])
1121 {
1122   struct guestfs_lvm_lv_list *r;
1123   if (argc != 0) {
1124     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1125     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1126     return -1;
1127   }
1128   r = guestfs_lvs_full (g);
1129   if (r == NULL) return -1;
1130   print_lv_list (r);
1131   guestfs_free_lvm_lv_list (r);
1132   return 0;
1133 }
1134
1135 static int run_read_lines (const char *cmd, int argc, char *argv[])
1136 {
1137   char **r;
1138   const char *path;
1139   if (argc != 1) {
1140     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1141     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1142     return -1;
1143   }
1144   path = argv[0];
1145   r = guestfs_read_lines (g, path);
1146   if (r == NULL) return -1;
1147   print_strings (r);
1148   free_strings (r);
1149   return 0;
1150 }
1151
1152 static int run_aug_init (const char *cmd, int argc, char *argv[])
1153 {
1154   int r;
1155   const char *root;
1156   int flags;
1157   if (argc != 2) {
1158     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1159     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1160     return -1;
1161   }
1162   root = argv[0];
1163   flags = atoi (argv[1]);
1164   r = guestfs_aug_init (g, root, flags);
1165   return r;
1166 }
1167
1168 static int run_aug_close (const char *cmd, int argc, char *argv[])
1169 {
1170   int r;
1171   if (argc != 0) {
1172     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1173     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1174     return -1;
1175   }
1176   r = guestfs_aug_close (g);
1177   return r;
1178 }
1179
1180 static int run_aug_defvar (const char *cmd, int argc, char *argv[])
1181 {
1182   int r;
1183   const char *name;
1184   const char *expr;
1185   if (argc != 2) {
1186     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1187     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1188     return -1;
1189   }
1190   name = argv[0];
1191   expr = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
1192   r = guestfs_aug_defvar (g, name, expr);
1193   if (r == -1) return -1;
1194   printf ("%d\n", r);
1195   return 0;
1196 }
1197
1198 static int run_aug_defnode (const char *cmd, int argc, char *argv[])
1199 {
1200   struct guestfs_int_bool *r;
1201   const char *name;
1202   const char *expr;
1203   const char *val;
1204   if (argc != 3) {
1205     fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1206     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1207     return -1;
1208   }
1209   name = argv[0];
1210   expr = argv[1];
1211   val = argv[2];
1212   r = guestfs_aug_defnode (g, name, expr, val);
1213   if (r == NULL) return -1;
1214   printf ("%d, %s\n", r->i,
1215     r->b ? "true" : "false");
1216   guestfs_free_int_bool (r);
1217   return 0;
1218 }
1219
1220 static int run_aug_get (const char *cmd, int argc, char *argv[])
1221 {
1222   char *r;
1223   const char *path;
1224   if (argc != 1) {
1225     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1226     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1227     return -1;
1228   }
1229   path = argv[0];
1230   r = guestfs_aug_get (g, path);
1231   if (r == NULL) return -1;
1232   printf ("%s\n", r);
1233   free (r);
1234   return 0;
1235 }
1236
1237 static int run_aug_set (const char *cmd, int argc, char *argv[])
1238 {
1239   int r;
1240   const char *path;
1241   const char *val;
1242   if (argc != 2) {
1243     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1244     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1245     return -1;
1246   }
1247   path = argv[0];
1248   val = argv[1];
1249   r = guestfs_aug_set (g, path, val);
1250   return r;
1251 }
1252
1253 static int run_aug_insert (const char *cmd, int argc, char *argv[])
1254 {
1255   int r;
1256   const char *path;
1257   const char *label;
1258   int before;
1259   if (argc != 3) {
1260     fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1261     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1262     return -1;
1263   }
1264   path = argv[0];
1265   label = argv[1];
1266   before = is_true (argv[2]) ? 1 : 0;
1267   r = guestfs_aug_insert (g, path, label, before);
1268   return r;
1269 }
1270
1271 static int run_aug_rm (const char *cmd, int argc, char *argv[])
1272 {
1273   int r;
1274   const char *path;
1275   if (argc != 1) {
1276     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1277     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1278     return -1;
1279   }
1280   path = argv[0];
1281   r = guestfs_aug_rm (g, path);
1282   if (r == -1) return -1;
1283   printf ("%d\n", r);
1284   return 0;
1285 }
1286
1287 static int run_aug_mv (const char *cmd, int argc, char *argv[])
1288 {
1289   int r;
1290   const char *src;
1291   const char *dest;
1292   if (argc != 2) {
1293     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1294     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1295     return -1;
1296   }
1297   src = argv[0];
1298   dest = argv[1];
1299   r = guestfs_aug_mv (g, src, dest);
1300   return r;
1301 }
1302
1303 static int run_aug_match (const char *cmd, int argc, char *argv[])
1304 {
1305   char **r;
1306   const char *path;
1307   if (argc != 1) {
1308     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1309     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1310     return -1;
1311   }
1312   path = argv[0];
1313   r = guestfs_aug_match (g, path);
1314   if (r == NULL) return -1;
1315   print_strings (r);
1316   free_strings (r);
1317   return 0;
1318 }
1319
1320 static int run_aug_save (const char *cmd, int argc, char *argv[])
1321 {
1322   int r;
1323   if (argc != 0) {
1324     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1325     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1326     return -1;
1327   }
1328   r = guestfs_aug_save (g);
1329   return r;
1330 }
1331
1332 static int run_aug_load (const char *cmd, int argc, char *argv[])
1333 {
1334   int r;
1335   if (argc != 0) {
1336     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1337     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1338     return -1;
1339   }
1340   r = guestfs_aug_load (g);
1341   return r;
1342 }
1343
1344 static int run_aug_ls (const char *cmd, int argc, char *argv[])
1345 {
1346   char **r;
1347   const char *path;
1348   if (argc != 1) {
1349     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1350     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1351     return -1;
1352   }
1353   path = argv[0];
1354   r = guestfs_aug_ls (g, path);
1355   if (r == NULL) return -1;
1356   print_strings (r);
1357   free_strings (r);
1358   return 0;
1359 }
1360
1361 static int run_rm (const char *cmd, int argc, char *argv[])
1362 {
1363   int r;
1364   const char *path;
1365   if (argc != 1) {
1366     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1367     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1368     return -1;
1369   }
1370   path = argv[0];
1371   r = guestfs_rm (g, path);
1372   return r;
1373 }
1374
1375 static int run_rmdir (const char *cmd, int argc, char *argv[])
1376 {
1377   int r;
1378   const char *path;
1379   if (argc != 1) {
1380     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1381     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1382     return -1;
1383   }
1384   path = argv[0];
1385   r = guestfs_rmdir (g, path);
1386   return r;
1387 }
1388
1389 static int run_rm_rf (const char *cmd, int argc, char *argv[])
1390 {
1391   int r;
1392   const char *path;
1393   if (argc != 1) {
1394     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1395     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1396     return -1;
1397   }
1398   path = argv[0];
1399   r = guestfs_rm_rf (g, path);
1400   return r;
1401 }
1402
1403 static int run_mkdir (const char *cmd, int argc, char *argv[])
1404 {
1405   int r;
1406   const char *path;
1407   if (argc != 1) {
1408     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1409     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1410     return -1;
1411   }
1412   path = argv[0];
1413   r = guestfs_mkdir (g, path);
1414   return r;
1415 }
1416
1417 static int run_mkdir_p (const char *cmd, int argc, char *argv[])
1418 {
1419   int r;
1420   const char *path;
1421   if (argc != 1) {
1422     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1423     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1424     return -1;
1425   }
1426   path = argv[0];
1427   r = guestfs_mkdir_p (g, path);
1428   return r;
1429 }
1430
1431 static int run_chmod (const char *cmd, int argc, char *argv[])
1432 {
1433   int r;
1434   int mode;
1435   const char *path;
1436   if (argc != 2) {
1437     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1438     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1439     return -1;
1440   }
1441   mode = atoi (argv[0]);
1442   path = argv[1];
1443   r = guestfs_chmod (g, mode, path);
1444   return r;
1445 }
1446
1447 static int run_chown (const char *cmd, int argc, char *argv[])
1448 {
1449   int r;
1450   int owner;
1451   int group;
1452   const char *path;
1453   if (argc != 3) {
1454     fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1455     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1456     return -1;
1457   }
1458   owner = atoi (argv[0]);
1459   group = atoi (argv[1]);
1460   path = argv[2];
1461   r = guestfs_chown (g, owner, group, path);
1462   return r;
1463 }
1464
1465 static int run_exists (const char *cmd, int argc, char *argv[])
1466 {
1467   int r;
1468   const char *path;
1469   if (argc != 1) {
1470     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1471     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1472     return -1;
1473   }
1474   path = argv[0];
1475   r = guestfs_exists (g, path);
1476   if (r == -1) return -1;
1477   if (r) printf ("true\n"); else printf ("false\n");
1478   return 0;
1479 }
1480
1481 static int run_is_file (const char *cmd, int argc, char *argv[])
1482 {
1483   int r;
1484   const char *path;
1485   if (argc != 1) {
1486     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1487     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1488     return -1;
1489   }
1490   path = argv[0];
1491   r = guestfs_is_file (g, path);
1492   if (r == -1) return -1;
1493   if (r) printf ("true\n"); else printf ("false\n");
1494   return 0;
1495 }
1496
1497 static int run_is_dir (const char *cmd, int argc, char *argv[])
1498 {
1499   int r;
1500   const char *path;
1501   if (argc != 1) {
1502     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1503     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1504     return -1;
1505   }
1506   path = argv[0];
1507   r = guestfs_is_dir (g, path);
1508   if (r == -1) return -1;
1509   if (r) printf ("true\n"); else printf ("false\n");
1510   return 0;
1511 }
1512
1513 static int run_pvcreate (const char *cmd, int argc, char *argv[])
1514 {
1515   int r;
1516   const char *device;
1517   if (argc != 1) {
1518     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1519     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1520     return -1;
1521   }
1522   device = argv[0];
1523   r = guestfs_pvcreate (g, device);
1524   return r;
1525 }
1526
1527 static int run_vgcreate (const char *cmd, int argc, char *argv[])
1528 {
1529   int r;
1530   const char *volgroup;
1531   char **physvols;
1532   if (argc != 2) {
1533     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1534     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1535     return -1;
1536   }
1537   volgroup = argv[0];
1538   physvols = parse_string_list (argv[1]);
1539   r = guestfs_vgcreate (g, volgroup, physvols);
1540   return r;
1541 }
1542
1543 static int run_lvcreate (const char *cmd, int argc, char *argv[])
1544 {
1545   int r;
1546   const char *logvol;
1547   const char *volgroup;
1548   int mbytes;
1549   if (argc != 3) {
1550     fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1551     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1552     return -1;
1553   }
1554   logvol = argv[0];
1555   volgroup = argv[1];
1556   mbytes = atoi (argv[2]);
1557   r = guestfs_lvcreate (g, logvol, volgroup, mbytes);
1558   return r;
1559 }
1560
1561 static int run_mkfs (const char *cmd, int argc, char *argv[])
1562 {
1563   int r;
1564   const char *fstype;
1565   const char *device;
1566   if (argc != 2) {
1567     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1568     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1569     return -1;
1570   }
1571   fstype = argv[0];
1572   device = argv[1];
1573   r = guestfs_mkfs (g, fstype, device);
1574   return r;
1575 }
1576
1577 static int run_sfdisk (const char *cmd, int argc, char *argv[])
1578 {
1579   int r;
1580   const char *device;
1581   int cyls;
1582   int heads;
1583   int sectors;
1584   char **lines;
1585   if (argc != 5) {
1586     fprintf (stderr, "%s should have 5 parameter(s)\n", cmd);
1587     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1588     return -1;
1589   }
1590   device = argv[0];
1591   cyls = atoi (argv[1]);
1592   heads = atoi (argv[2]);
1593   sectors = atoi (argv[3]);
1594   lines = parse_string_list (argv[4]);
1595   r = guestfs_sfdisk (g, device, cyls, heads, sectors, lines);
1596   return r;
1597 }
1598
1599 static int run_write_file (const char *cmd, int argc, char *argv[])
1600 {
1601   int r;
1602   const char *path;
1603   const char *content;
1604   int size;
1605   if (argc != 3) {
1606     fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1607     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1608     return -1;
1609   }
1610   path = argv[0];
1611   content = argv[1];
1612   size = atoi (argv[2]);
1613   r = guestfs_write_file (g, path, content, size);
1614   return r;
1615 }
1616
1617 static int run_umount (const char *cmd, int argc, char *argv[])
1618 {
1619   int r;
1620   const char *pathordevice;
1621   if (argc != 1) {
1622     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1623     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1624     return -1;
1625   }
1626   pathordevice = argv[0];
1627   r = guestfs_umount (g, pathordevice);
1628   return r;
1629 }
1630
1631 static int run_mounts (const char *cmd, int argc, char *argv[])
1632 {
1633   char **r;
1634   if (argc != 0) {
1635     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1636     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1637     return -1;
1638   }
1639   r = guestfs_mounts (g);
1640   if (r == NULL) return -1;
1641   print_strings (r);
1642   free_strings (r);
1643   return 0;
1644 }
1645
1646 static int run_umount_all (const char *cmd, int argc, char *argv[])
1647 {
1648   int r;
1649   if (argc != 0) {
1650     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1651     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1652     return -1;
1653   }
1654   r = guestfs_umount_all (g);
1655   return r;
1656 }
1657
1658 static int run_lvm_remove_all (const char *cmd, int argc, char *argv[])
1659 {
1660   int r;
1661   if (argc != 0) {
1662     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1663     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1664     return -1;
1665   }
1666   r = guestfs_lvm_remove_all (g);
1667   return r;
1668 }
1669
1670 static int run_file (const char *cmd, int argc, char *argv[])
1671 {
1672   char *r;
1673   const char *path;
1674   if (argc != 1) {
1675     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1676     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1677     return -1;
1678   }
1679   path = argv[0];
1680   r = guestfs_file (g, path);
1681   if (r == NULL) return -1;
1682   printf ("%s\n", r);
1683   free (r);
1684   return 0;
1685 }
1686
1687 static int run_command (const char *cmd, int argc, char *argv[])
1688 {
1689   char *r;
1690   char **arguments;
1691   if (argc != 1) {
1692     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1693     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1694     return -1;
1695   }
1696   arguments = parse_string_list (argv[0]);
1697   r = guestfs_command (g, arguments);
1698   if (r == NULL) return -1;
1699   printf ("%s\n", r);
1700   free (r);
1701   return 0;
1702 }
1703
1704 static int run_command_lines (const char *cmd, int argc, char *argv[])
1705 {
1706   char **r;
1707   char **arguments;
1708   if (argc != 1) {
1709     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1710     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1711     return -1;
1712   }
1713   arguments = parse_string_list (argv[0]);
1714   r = guestfs_command_lines (g, arguments);
1715   if (r == NULL) return -1;
1716   print_strings (r);
1717   free_strings (r);
1718   return 0;
1719 }
1720
1721 static int run_stat (const char *cmd, int argc, char *argv[])
1722 {
1723   struct guestfs_stat *r;
1724   const char *path;
1725   if (argc != 1) {
1726     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1727     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1728     return -1;
1729   }
1730   path = argv[0];
1731   r = guestfs_stat (g, path);
1732   if (r == NULL) return -1;
1733   print_stat (r);
1734   free (r);
1735   return 0;
1736 }
1737
1738 static int run_lstat (const char *cmd, int argc, char *argv[])
1739 {
1740   struct guestfs_stat *r;
1741   const char *path;
1742   if (argc != 1) {
1743     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1744     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1745     return -1;
1746   }
1747   path = argv[0];
1748   r = guestfs_lstat (g, path);
1749   if (r == NULL) return -1;
1750   print_stat (r);
1751   free (r);
1752   return 0;
1753 }
1754
1755 static int run_statvfs (const char *cmd, int argc, char *argv[])
1756 {
1757   struct guestfs_statvfs *r;
1758   const char *path;
1759   if (argc != 1) {
1760     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1761     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1762     return -1;
1763   }
1764   path = argv[0];
1765   r = guestfs_statvfs (g, path);
1766   if (r == NULL) return -1;
1767   print_statvfs (r);
1768   free (r);
1769   return 0;
1770 }
1771
1772 static int run_tune2fs_l (const char *cmd, int argc, char *argv[])
1773 {
1774   char **r;
1775   const char *device;
1776   if (argc != 1) {
1777     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1778     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1779     return -1;
1780   }
1781   device = argv[0];
1782   r = guestfs_tune2fs_l (g, device);
1783   if (r == NULL) return -1;
1784   print_table (r);
1785   free_strings (r);
1786   return 0;
1787 }
1788
1789 static int run_blockdev_setro (const char *cmd, int argc, char *argv[])
1790 {
1791   int r;
1792   const char *device;
1793   if (argc != 1) {
1794     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1795     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1796     return -1;
1797   }
1798   device = argv[0];
1799   r = guestfs_blockdev_setro (g, device);
1800   return r;
1801 }
1802
1803 static int run_blockdev_setrw (const char *cmd, int argc, char *argv[])
1804 {
1805   int r;
1806   const char *device;
1807   if (argc != 1) {
1808     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1809     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1810     return -1;
1811   }
1812   device = argv[0];
1813   r = guestfs_blockdev_setrw (g, device);
1814   return r;
1815 }
1816
1817 static int run_blockdev_getro (const char *cmd, int argc, char *argv[])
1818 {
1819   int r;
1820   const char *device;
1821   if (argc != 1) {
1822     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1823     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1824     return -1;
1825   }
1826   device = argv[0];
1827   r = guestfs_blockdev_getro (g, device);
1828   if (r == -1) return -1;
1829   if (r) printf ("true\n"); else printf ("false\n");
1830   return 0;
1831 }
1832
1833 static int run_blockdev_getss (const char *cmd, int argc, char *argv[])
1834 {
1835   int r;
1836   const char *device;
1837   if (argc != 1) {
1838     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1839     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1840     return -1;
1841   }
1842   device = argv[0];
1843   r = guestfs_blockdev_getss (g, device);
1844   if (r == -1) return -1;
1845   printf ("%d\n", r);
1846   return 0;
1847 }
1848
1849 static int run_blockdev_getbsz (const char *cmd, int argc, char *argv[])
1850 {
1851   int r;
1852   const char *device;
1853   if (argc != 1) {
1854     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1855     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1856     return -1;
1857   }
1858   device = argv[0];
1859   r = guestfs_blockdev_getbsz (g, device);
1860   if (r == -1) return -1;
1861   printf ("%d\n", r);
1862   return 0;
1863 }
1864
1865 static int run_blockdev_setbsz (const char *cmd, int argc, char *argv[])
1866 {
1867   int r;
1868   const char *device;
1869   int blocksize;
1870   if (argc != 2) {
1871     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1872     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1873     return -1;
1874   }
1875   device = argv[0];
1876   blocksize = atoi (argv[1]);
1877   r = guestfs_blockdev_setbsz (g, device, blocksize);
1878   return r;
1879 }
1880
1881 static int run_blockdev_getsz (const char *cmd, int argc, char *argv[])
1882 {
1883   int64_t r;
1884   const char *device;
1885   if (argc != 1) {
1886     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1887     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1888     return -1;
1889   }
1890   device = argv[0];
1891   r = guestfs_blockdev_getsz (g, device);
1892   if (r == -1) return -1;
1893   printf ("%" PRIi64 "\n", r);
1894   return 0;
1895 }
1896
1897 static int run_blockdev_getsize64 (const char *cmd, int argc, char *argv[])
1898 {
1899   int64_t r;
1900   const char *device;
1901   if (argc != 1) {
1902     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1903     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1904     return -1;
1905   }
1906   device = argv[0];
1907   r = guestfs_blockdev_getsize64 (g, device);
1908   if (r == -1) return -1;
1909   printf ("%" PRIi64 "\n", r);
1910   return 0;
1911 }
1912
1913 static int run_blockdev_flushbufs (const char *cmd, int argc, char *argv[])
1914 {
1915   int r;
1916   const char *device;
1917   if (argc != 1) {
1918     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1919     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1920     return -1;
1921   }
1922   device = argv[0];
1923   r = guestfs_blockdev_flushbufs (g, device);
1924   return r;
1925 }
1926
1927 static int run_blockdev_rereadpt (const char *cmd, int argc, char *argv[])
1928 {
1929   int r;
1930   const char *device;
1931   if (argc != 1) {
1932     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1933     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1934     return -1;
1935   }
1936   device = argv[0];
1937   r = guestfs_blockdev_rereadpt (g, device);
1938   return r;
1939 }
1940
1941 static int run_upload (const char *cmd, int argc, char *argv[])
1942 {
1943   int r;
1944   const char *filename;
1945   const char *remotefilename;
1946   if (argc != 2) {
1947     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1948     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1949     return -1;
1950   }
1951   filename = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
1952   remotefilename = argv[1];
1953   r = guestfs_upload (g, filename, remotefilename);
1954   return r;
1955 }
1956
1957 static int run_download (const char *cmd, int argc, char *argv[])
1958 {
1959   int r;
1960   const char *remotefilename;
1961   const char *filename;
1962   if (argc != 2) {
1963     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1964     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1965     return -1;
1966   }
1967   remotefilename = argv[0];
1968   filename = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
1969   r = guestfs_download (g, remotefilename, filename);
1970   return r;
1971 }
1972
1973 static int run_checksum (const char *cmd, int argc, char *argv[])
1974 {
1975   char *r;
1976   const char *csumtype;
1977   const char *path;
1978   if (argc != 2) {
1979     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1980     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1981     return -1;
1982   }
1983   csumtype = argv[0];
1984   path = argv[1];
1985   r = guestfs_checksum (g, csumtype, path);
1986   if (r == NULL) return -1;
1987   printf ("%s\n", r);
1988   free (r);
1989   return 0;
1990 }
1991
1992 static int run_tar_in (const char *cmd, int argc, char *argv[])
1993 {
1994   int r;
1995   const char *tarfile;
1996   const char *directory;
1997   if (argc != 2) {
1998     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1999     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2000     return -1;
2001   }
2002   tarfile = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
2003   directory = argv[1];
2004   r = guestfs_tar_in (g, tarfile, directory);
2005   return r;
2006 }
2007
2008 static int run_tar_out (const char *cmd, int argc, char *argv[])
2009 {
2010   int r;
2011   const char *directory;
2012   const char *tarfile;
2013   if (argc != 2) {
2014     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2015     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2016     return -1;
2017   }
2018   directory = argv[0];
2019   tarfile = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
2020   r = guestfs_tar_out (g, directory, tarfile);
2021   return r;
2022 }
2023
2024 static int run_tgz_in (const char *cmd, int argc, char *argv[])
2025 {
2026   int r;
2027   const char *tarball;
2028   const char *directory;
2029   if (argc != 2) {
2030     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2031     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2032     return -1;
2033   }
2034   tarball = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
2035   directory = argv[1];
2036   r = guestfs_tgz_in (g, tarball, directory);
2037   return r;
2038 }
2039
2040 static int run_tgz_out (const char *cmd, int argc, char *argv[])
2041 {
2042   int r;
2043   const char *directory;
2044   const char *tarball;
2045   if (argc != 2) {
2046     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2047     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2048     return -1;
2049   }
2050   directory = argv[0];
2051   tarball = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
2052   r = guestfs_tgz_out (g, directory, tarball);
2053   return r;
2054 }
2055
2056 static int run_mount_ro (const char *cmd, int argc, char *argv[])
2057 {
2058   int r;
2059   const char *device;
2060   const char *mountpoint;
2061   if (argc != 2) {
2062     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2063     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2064     return -1;
2065   }
2066   device = argv[0];
2067   mountpoint = argv[1];
2068   r = guestfs_mount_ro (g, device, mountpoint);
2069   return r;
2070 }
2071
2072 static int run_mount_options (const char *cmd, int argc, char *argv[])
2073 {
2074   int r;
2075   const char *options;
2076   const char *device;
2077   const char *mountpoint;
2078   if (argc != 3) {
2079     fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
2080     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2081     return -1;
2082   }
2083   options = argv[0];
2084   device = argv[1];
2085   mountpoint = argv[2];
2086   r = guestfs_mount_options (g, options, device, mountpoint);
2087   return r;
2088 }
2089
2090 static int run_mount_vfs (const char *cmd, int argc, char *argv[])
2091 {
2092   int r;
2093   const char *options;
2094   const char *vfstype;
2095   const char *device;
2096   const char *mountpoint;
2097   if (argc != 4) {
2098     fprintf (stderr, "%s should have 4 parameter(s)\n", cmd);
2099     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2100     return -1;
2101   }
2102   options = argv[0];
2103   vfstype = argv[1];
2104   device = argv[2];
2105   mountpoint = argv[3];
2106   r = guestfs_mount_vfs (g, options, vfstype, device, mountpoint);
2107   return r;
2108 }
2109
2110 static int run_debug (const char *cmd, int argc, char *argv[])
2111 {
2112   char *r;
2113   const char *subcmd;
2114   char **extraargs;
2115   if (argc != 2) {
2116     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2117     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2118     return -1;
2119   }
2120   subcmd = argv[0];
2121   extraargs = parse_string_list (argv[1]);
2122   r = guestfs_debug (g, subcmd, extraargs);
2123   if (r == NULL) return -1;
2124   printf ("%s\n", r);
2125   free (r);
2126   return 0;
2127 }
2128
2129 static int run_lvremove (const char *cmd, int argc, char *argv[])
2130 {
2131   int r;
2132   const char *device;
2133   if (argc != 1) {
2134     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2135     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2136     return -1;
2137   }
2138   device = argv[0];
2139   r = guestfs_lvremove (g, device);
2140   return r;
2141 }
2142
2143 static int run_vgremove (const char *cmd, int argc, char *argv[])
2144 {
2145   int r;
2146   const char *vgname;
2147   if (argc != 1) {
2148     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2149     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2150     return -1;
2151   }
2152   vgname = argv[0];
2153   r = guestfs_vgremove (g, vgname);
2154   return r;
2155 }
2156
2157 static int run_pvremove (const char *cmd, int argc, char *argv[])
2158 {
2159   int r;
2160   const char *device;
2161   if (argc != 1) {
2162     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2163     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2164     return -1;
2165   }
2166   device = argv[0];
2167   r = guestfs_pvremove (g, device);
2168   return r;
2169 }
2170
2171 static int run_set_e2label (const char *cmd, int argc, char *argv[])
2172 {
2173   int r;
2174   const char *device;
2175   const char *label;
2176   if (argc != 2) {
2177     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2178     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2179     return -1;
2180   }
2181   device = argv[0];
2182   label = argv[1];
2183   r = guestfs_set_e2label (g, device, label);
2184   return r;
2185 }
2186
2187 static int run_get_e2label (const char *cmd, int argc, char *argv[])
2188 {
2189   char *r;
2190   const char *device;
2191   if (argc != 1) {
2192     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2193     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2194     return -1;
2195   }
2196   device = argv[0];
2197   r = guestfs_get_e2label (g, device);
2198   if (r == NULL) return -1;
2199   printf ("%s\n", r);
2200   free (r);
2201   return 0;
2202 }
2203
2204 static int run_set_e2uuid (const char *cmd, int argc, char *argv[])
2205 {
2206   int r;
2207   const char *device;
2208   const char *uuid;
2209   if (argc != 2) {
2210     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2211     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2212     return -1;
2213   }
2214   device = argv[0];
2215   uuid = argv[1];
2216   r = guestfs_set_e2uuid (g, device, uuid);
2217   return r;
2218 }
2219
2220 static int run_get_e2uuid (const char *cmd, int argc, char *argv[])
2221 {
2222   char *r;
2223   const char *device;
2224   if (argc != 1) {
2225     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2226     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2227     return -1;
2228   }
2229   device = argv[0];
2230   r = guestfs_get_e2uuid (g, device);
2231   if (r == NULL) return -1;
2232   printf ("%s\n", r);
2233   free (r);
2234   return 0;
2235 }
2236
2237 static int run_fsck (const char *cmd, int argc, char *argv[])
2238 {
2239   int r;
2240   const char *fstype;
2241   const char *device;
2242   if (argc != 2) {
2243     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2244     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2245     return -1;
2246   }
2247   fstype = argv[0];
2248   device = argv[1];
2249   r = guestfs_fsck (g, fstype, device);
2250   if (r == -1) return -1;
2251   printf ("%d\n", r);
2252   return 0;
2253 }
2254
2255 static int run_zero (const char *cmd, int argc, char *argv[])
2256 {
2257   int r;
2258   const char *device;
2259   if (argc != 1) {
2260     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2261     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2262     return -1;
2263   }
2264   device = argv[0];
2265   r = guestfs_zero (g, device);
2266   return r;
2267 }
2268
2269 static int run_grub_install (const char *cmd, int argc, char *argv[])
2270 {
2271   int r;
2272   const char *root;
2273   const char *device;
2274   if (argc != 2) {
2275     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2276     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2277     return -1;
2278   }
2279   root = argv[0];
2280   device = argv[1];
2281   r = guestfs_grub_install (g, root, device);
2282   return r;
2283 }
2284
2285 static int run_cp (const char *cmd, int argc, char *argv[])
2286 {
2287   int r;
2288   const char *src;
2289   const char *dest;
2290   if (argc != 2) {
2291     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2292     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2293     return -1;
2294   }
2295   src = argv[0];
2296   dest = argv[1];
2297   r = guestfs_cp (g, src, dest);
2298   return r;
2299 }
2300
2301 static int run_cp_a (const char *cmd, int argc, char *argv[])
2302 {
2303   int r;
2304   const char *src;
2305   const char *dest;
2306   if (argc != 2) {
2307     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2308     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2309     return -1;
2310   }
2311   src = argv[0];
2312   dest = argv[1];
2313   r = guestfs_cp_a (g, src, dest);
2314   return r;
2315 }
2316
2317 static int run_mv (const char *cmd, int argc, char *argv[])
2318 {
2319   int r;
2320   const char *src;
2321   const char *dest;
2322   if (argc != 2) {
2323     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2324     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2325     return -1;
2326   }
2327   src = argv[0];
2328   dest = argv[1];
2329   r = guestfs_mv (g, src, dest);
2330   return r;
2331 }
2332
2333 static int run_drop_caches (const char *cmd, int argc, char *argv[])
2334 {
2335   int r;
2336   int whattodrop;
2337   if (argc != 1) {
2338     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2339     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2340     return -1;
2341   }
2342   whattodrop = atoi (argv[0]);
2343   r = guestfs_drop_caches (g, whattodrop);
2344   return r;
2345 }
2346
2347 static int run_dmesg (const char *cmd, int argc, char *argv[])
2348 {
2349   char *r;
2350   if (argc != 0) {
2351     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
2352     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2353     return -1;
2354   }
2355   r = guestfs_dmesg (g);
2356   if (r == NULL) return -1;
2357   printf ("%s\n", r);
2358   free (r);
2359   return 0;
2360 }
2361
2362 static int run_ping_daemon (const char *cmd, int argc, char *argv[])
2363 {
2364   int r;
2365   if (argc != 0) {
2366     fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
2367     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2368     return -1;
2369   }
2370   r = guestfs_ping_daemon (g);
2371   return r;
2372 }
2373
2374 static int run_equal (const char *cmd, int argc, char *argv[])
2375 {
2376   int r;
2377   const char *file1;
2378   const char *file2;
2379   if (argc != 2) {
2380     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2381     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2382     return -1;
2383   }
2384   file1 = argv[0];
2385   file2 = argv[1];
2386   r = guestfs_equal (g, file1, file2);
2387   if (r == -1) return -1;
2388   if (r) printf ("true\n"); else printf ("false\n");
2389   return 0;
2390 }
2391
2392 static int run_strings (const char *cmd, int argc, char *argv[])
2393 {
2394   char **r;
2395   const char *path;
2396   if (argc != 1) {
2397     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2398     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2399     return -1;
2400   }
2401   path = argv[0];
2402   r = guestfs_strings (g, path);
2403   if (r == NULL) return -1;
2404   print_strings (r);
2405   free_strings (r);
2406   return 0;
2407 }
2408
2409 static int run_strings_e (const char *cmd, int argc, char *argv[])
2410 {
2411   char **r;
2412   const char *encoding;
2413   const char *path;
2414   if (argc != 2) {
2415     fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2416     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2417     return -1;
2418   }
2419   encoding = argv[0];
2420   path = argv[1];
2421   r = guestfs_strings_e (g, encoding, path);
2422   if (r == NULL) return -1;
2423   print_strings (r);
2424   free_strings (r);
2425   return 0;
2426 }
2427
2428 static int run_hexdump (const char *cmd, int argc, char *argv[])
2429 {
2430   char *r;
2431   const char *path;
2432   if (argc != 1) {
2433     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2434     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2435     return -1;
2436   }
2437   path = argv[0];
2438   r = guestfs_hexdump (g, path);
2439   if (r == NULL) return -1;
2440   printf ("%s\n", r);
2441   free (r);
2442   return 0;
2443 }
2444
2445 static int run_zerofree (const char *cmd, int argc, char *argv[])
2446 {
2447   int r;
2448   const char *device;
2449   if (argc != 1) {
2450     fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2451     fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2452     return -1;
2453   }
2454   device = argv[0];
2455   r = guestfs_zerofree (g, device);
2456   return r;
2457 }
2458
2459 int run_action (const char *cmd, int argc, char *argv[])
2460 {
2461   if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
2462     return run_launch (cmd, argc, argv);
2463   else
2464   if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
2465     return run_kill_subprocess (cmd, argc, argv);
2466   else
2467   if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
2468     return run_add_drive (cmd, argc, argv);
2469   else
2470   if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
2471     return run_add_cdrom (cmd, argc, argv);
2472   else
2473   if (strcasecmp (cmd, "config") == 0)
2474     return run_config (cmd, argc, argv);
2475   else
2476   if (strcasecmp (cmd, "set_qemu") == 0 || strcasecmp (cmd, "set-qemu") == 0 || strcasecmp (cmd, "qemu") == 0)
2477     return run_set_qemu (cmd, argc, argv);
2478   else
2479   if (strcasecmp (cmd, "get_qemu") == 0 || strcasecmp (cmd, "get-qemu") == 0)
2480     return run_get_qemu (cmd, argc, argv);
2481   else
2482   if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
2483     return run_set_path (cmd, argc, argv);
2484   else
2485   if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
2486     return run_get_path (cmd, argc, argv);
2487   else
2488   if (strcasecmp (cmd, "set_append") == 0 || strcasecmp (cmd, "set-append") == 0 || strcasecmp (cmd, "append") == 0)
2489     return run_set_append (cmd, argc, argv);
2490   else
2491   if (strcasecmp (cmd, "get_append") == 0 || strcasecmp (cmd, "get-append") == 0)
2492     return run_get_append (cmd, argc, argv);
2493   else
2494   if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
2495     return run_set_autosync (cmd, argc, argv);
2496   else
2497   if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
2498     return run_get_autosync (cmd, argc, argv);
2499   else
2500   if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
2501     return run_set_verbose (cmd, argc, argv);
2502   else
2503   if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
2504     return run_get_verbose (cmd, argc, argv);
2505   else
2506   if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
2507     return run_is_ready (cmd, argc, argv);
2508   else
2509   if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
2510     return run_is_config (cmd, argc, argv);
2511   else
2512   if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
2513     return run_is_launching (cmd, argc, argv);
2514   else
2515   if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
2516     return run_is_busy (cmd, argc, argv);
2517   else
2518   if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
2519     return run_get_state (cmd, argc, argv);
2520   else
2521   if (strcasecmp (cmd, "mount") == 0)
2522     return run_mount (cmd, argc, argv);
2523   else
2524   if (strcasecmp (cmd, "sync") == 0)
2525     return run_sync (cmd, argc, argv);
2526   else
2527   if (strcasecmp (cmd, "touch") == 0)
2528     return run_touch (cmd, argc, argv);
2529   else
2530   if (strcasecmp (cmd, "cat") == 0)
2531     return run_cat (cmd, argc, argv);
2532   else
2533   if (strcasecmp (cmd, "ll") == 0)
2534     return run_ll (cmd, argc, argv);
2535   else
2536   if (strcasecmp (cmd, "ls") == 0)
2537     return run_ls (cmd, argc, argv);
2538   else
2539   if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
2540     return run_list_devices (cmd, argc, argv);
2541   else
2542   if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
2543     return run_list_partitions (cmd, argc, argv);
2544   else
2545   if (strcasecmp (cmd, "pvs") == 0)
2546     return run_pvs (cmd, argc, argv);
2547   else
2548   if (strcasecmp (cmd, "vgs") == 0)
2549     return run_vgs (cmd, argc, argv);
2550   else
2551   if (strcasecmp (cmd, "lvs") == 0)
2552     return run_lvs (cmd, argc, argv);
2553   else
2554   if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
2555     return run_pvs_full (cmd, argc, argv);
2556   else
2557   if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
2558     return run_vgs_full (cmd, argc, argv);
2559   else
2560   if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
2561     return run_lvs_full (cmd, argc, argv);
2562   else
2563   if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
2564     return run_read_lines (cmd, argc, argv);
2565   else
2566   if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
2567     return run_aug_init (cmd, argc, argv);
2568   else
2569   if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
2570     return run_aug_close (cmd, argc, argv);
2571   else
2572   if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
2573     return run_aug_defvar (cmd, argc, argv);
2574   else
2575   if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
2576     return run_aug_defnode (cmd, argc, argv);
2577   else
2578   if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
2579     return run_aug_get (cmd, argc, argv);
2580   else
2581   if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
2582     return run_aug_set (cmd, argc, argv);
2583   else
2584   if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
2585     return run_aug_insert (cmd, argc, argv);
2586   else
2587   if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
2588     return run_aug_rm (cmd, argc, argv);
2589   else
2590   if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
2591     return run_aug_mv (cmd, argc, argv);
2592   else
2593   if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
2594     return run_aug_match (cmd, argc, argv);
2595   else
2596   if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
2597     return run_aug_save (cmd, argc, argv);
2598   else
2599   if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
2600     return run_aug_load (cmd, argc, argv);
2601   else
2602   if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
2603     return run_aug_ls (cmd, argc, argv);
2604   else
2605   if (strcasecmp (cmd, "rm") == 0)
2606     return run_rm (cmd, argc, argv);
2607   else
2608   if (strcasecmp (cmd, "rmdir") == 0)
2609     return run_rmdir (cmd, argc, argv);
2610   else
2611   if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
2612     return run_rm_rf (cmd, argc, argv);
2613   else
2614   if (strcasecmp (cmd, "mkdir") == 0)
2615     return run_mkdir (cmd, argc, argv);
2616   else
2617   if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
2618     return run_mkdir_p (cmd, argc, argv);
2619   else
2620   if (strcasecmp (cmd, "chmod") == 0)
2621     return run_chmod (cmd, argc, argv);
2622   else
2623   if (strcasecmp (cmd, "chown") == 0)
2624     return run_chown (cmd, argc, argv);
2625   else
2626   if (strcasecmp (cmd, "exists") == 0)
2627     return run_exists (cmd, argc, argv);
2628   else
2629   if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
2630     return run_is_file (cmd, argc, argv);
2631   else
2632   if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
2633     return run_is_dir (cmd, argc, argv);
2634   else
2635   if (strcasecmp (cmd, "pvcreate") == 0)
2636     return run_pvcreate (cmd, argc, argv);
2637   else
2638   if (strcasecmp (cmd, "vgcreate") == 0)
2639     return run_vgcreate (cmd, argc, argv);
2640   else
2641   if (strcasecmp (cmd, "lvcreate") == 0)
2642     return run_lvcreate (cmd, argc, argv);
2643   else
2644   if (strcasecmp (cmd, "mkfs") == 0)
2645     return run_mkfs (cmd, argc, argv);
2646   else
2647   if (strcasecmp (cmd, "sfdisk") == 0)
2648     return run_sfdisk (cmd, argc, argv);
2649   else
2650   if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
2651     return run_write_file (cmd, argc, argv);
2652   else
2653   if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
2654     return run_umount (cmd, argc, argv);
2655   else
2656   if (strcasecmp (cmd, "mounts") == 0)
2657     return run_mounts (cmd, argc, argv);
2658   else
2659   if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
2660     return run_umount_all (cmd, argc, argv);
2661   else
2662   if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
2663     return run_lvm_remove_all (cmd, argc, argv);
2664   else
2665   if (strcasecmp (cmd, "file") == 0)
2666     return run_file (cmd, argc, argv);
2667   else
2668   if (strcasecmp (cmd, "command") == 0)
2669     return run_command (cmd, argc, argv);
2670   else
2671   if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
2672     return run_command_lines (cmd, argc, argv);
2673   else
2674   if (strcasecmp (cmd, "stat") == 0)
2675     return run_stat (cmd, argc, argv);
2676   else
2677   if (strcasecmp (cmd, "lstat") == 0)
2678     return run_lstat (cmd, argc, argv);
2679   else
2680   if (strcasecmp (cmd, "statvfs") == 0)
2681     return run_statvfs (cmd, argc, argv);
2682   else
2683   if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
2684     return run_tune2fs_l (cmd, argc, argv);
2685   else
2686   if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
2687     return run_blockdev_setro (cmd, argc, argv);
2688   else
2689   if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
2690     return run_blockdev_setrw (cmd, argc, argv);
2691   else
2692   if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
2693     return run_blockdev_getro (cmd, argc, argv);
2694   else
2695   if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
2696     return run_blockdev_getss (cmd, argc, argv);
2697   else
2698   if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
2699     return run_blockdev_getbsz (cmd, argc, argv);
2700   else
2701   if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
2702     return run_blockdev_setbsz (cmd, argc, argv);
2703   else
2704   if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
2705     return run_blockdev_getsz (cmd, argc, argv);
2706   else
2707   if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
2708     return run_blockdev_getsize64 (cmd, argc, argv);
2709   else
2710   if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
2711     return run_blockdev_flushbufs (cmd, argc, argv);
2712   else
2713   if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
2714     return run_blockdev_rereadpt (cmd, argc, argv);
2715   else
2716   if (strcasecmp (cmd, "upload") == 0)
2717     return run_upload (cmd, argc, argv);
2718   else
2719   if (strcasecmp (cmd, "download") == 0)
2720     return run_download (cmd, argc, argv);
2721   else
2722   if (strcasecmp (cmd, "checksum") == 0)
2723     return run_checksum (cmd, argc, argv);
2724   else
2725   if (strcasecmp (cmd, "tar_in") == 0 || strcasecmp (cmd, "tar-in") == 0)
2726     return run_tar_in (cmd, argc, argv);
2727   else
2728   if (strcasecmp (cmd, "tar_out") == 0 || strcasecmp (cmd, "tar-out") == 0)
2729     return run_tar_out (cmd, argc, argv);
2730   else
2731   if (strcasecmp (cmd, "tgz_in") == 0 || strcasecmp (cmd, "tgz-in") == 0)
2732     return run_tgz_in (cmd, argc, argv);
2733   else
2734   if (strcasecmp (cmd, "tgz_out") == 0 || strcasecmp (cmd, "tgz-out") == 0)
2735     return run_tgz_out (cmd, argc, argv);
2736   else
2737   if (strcasecmp (cmd, "mount_ro") == 0 || strcasecmp (cmd, "mount-ro") == 0)
2738     return run_mount_ro (cmd, argc, argv);
2739   else
2740   if (strcasecmp (cmd, "mount_options") == 0 || strcasecmp (cmd, "mount-options") == 0)
2741     return run_mount_options (cmd, argc, argv);
2742   else
2743   if (strcasecmp (cmd, "mount_vfs") == 0 || strcasecmp (cmd, "mount-vfs") == 0)
2744     return run_mount_vfs (cmd, argc, argv);
2745   else
2746   if (strcasecmp (cmd, "debug") == 0)
2747     return run_debug (cmd, argc, argv);
2748   else
2749   if (strcasecmp (cmd, "lvremove") == 0)
2750     return run_lvremove (cmd, argc, argv);
2751   else
2752   if (strcasecmp (cmd, "vgremove") == 0)
2753     return run_vgremove (cmd, argc, argv);
2754   else
2755   if (strcasecmp (cmd, "pvremove") == 0)
2756     return run_pvremove (cmd, argc, argv);
2757   else
2758   if (strcasecmp (cmd, "set_e2label") == 0 || strcasecmp (cmd, "set-e2label") == 0)
2759     return run_set_e2label (cmd, argc, argv);
2760   else
2761   if (strcasecmp (cmd, "get_e2label") == 0 || strcasecmp (cmd, "get-e2label") == 0)
2762     return run_get_e2label (cmd, argc, argv);
2763   else
2764   if (strcasecmp (cmd, "set_e2uuid") == 0 || strcasecmp (cmd, "set-e2uuid") == 0)
2765     return run_set_e2uuid (cmd, argc, argv);
2766   else
2767   if (strcasecmp (cmd, "get_e2uuid") == 0 || strcasecmp (cmd, "get-e2uuid") == 0)
2768     return run_get_e2uuid (cmd, argc, argv);
2769   else
2770   if (strcasecmp (cmd, "fsck") == 0)
2771     return run_fsck (cmd, argc, argv);
2772   else
2773   if (strcasecmp (cmd, "zero") == 0)
2774     return run_zero (cmd, argc, argv);
2775   else
2776   if (strcasecmp (cmd, "grub_install") == 0 || strcasecmp (cmd, "grub-install") == 0)
2777     return run_grub_install (cmd, argc, argv);
2778   else
2779   if (strcasecmp (cmd, "cp") == 0)
2780     return run_cp (cmd, argc, argv);
2781   else
2782   if (strcasecmp (cmd, "cp_a") == 0 || strcasecmp (cmd, "cp-a") == 0)
2783     return run_cp_a (cmd, argc, argv);
2784   else
2785   if (strcasecmp (cmd, "mv") == 0)
2786     return run_mv (cmd, argc, argv);
2787   else
2788   if (strcasecmp (cmd, "drop_caches") == 0 || strcasecmp (cmd, "drop-caches") == 0)
2789     return run_drop_caches (cmd, argc, argv);
2790   else
2791   if (strcasecmp (cmd, "dmesg") == 0)
2792     return run_dmesg (cmd, argc, argv);
2793   else
2794   if (strcasecmp (cmd, "ping_daemon") == 0 || strcasecmp (cmd, "ping-daemon") == 0)
2795     return run_ping_daemon (cmd, argc, argv);
2796   else
2797   if (strcasecmp (cmd, "equal") == 0)
2798     return run_equal (cmd, argc, argv);
2799   else
2800   if (strcasecmp (cmd, "strings") == 0)
2801     return run_strings (cmd, argc, argv);
2802   else
2803   if (strcasecmp (cmd, "strings_e") == 0 || strcasecmp (cmd, "strings-e") == 0)
2804     return run_strings_e (cmd, argc, argv);
2805   else
2806   if (strcasecmp (cmd, "hexdump") == 0)
2807     return run_hexdump (cmd, argc, argv);
2808   else
2809   if (strcasecmp (cmd, "zerofree") == 0)
2810     return run_zerofree (cmd, argc, argv);
2811   else
2812     {
2813       fprintf (stderr, "%s: unknown command\n", cmd);
2814       return -1;
2815     }
2816   return 0;
2817 }
2818