1 /* libguestfs generated file
2 * WARNING: THIS FILE IS GENERATED BY 'src/generator.ml'.
3 * ANY CHANGES YOU MAKE TO THIS FILE WILL BE LOST.
5 * Copyright (C) 2009 Red Hat Inc.
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License along
18 * with this program; if not, write to the Free Software Foundation, Inc.,
19 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
30 void list_commands (void)
32 printf (" %-16s %s\n", "Command", "Description");
33 list_builtin_commands ();
34 printf ("%-20s %s\n", "add-cdrom", "add a CD-ROM disk image to examine");
35 printf ("%-20s %s\n", "add-drive", "add an image to examine or modify");
36 printf ("%-20s %s\n", "add-drive-ro", "add a drive in snapshot mode (read-only)");
37 printf ("%-20s %s\n", "aug-close", "close the current Augeas handle");
38 printf ("%-20s %s\n", "aug-defnode", "define an Augeas node");
39 printf ("%-20s %s\n", "aug-defvar", "define an Augeas variable");
40 printf ("%-20s %s\n", "aug-get", "look up the value of an Augeas path");
41 printf ("%-20s %s\n", "aug-init", "create a new Augeas handle");
42 printf ("%-20s %s\n", "aug-insert", "insert a sibling Augeas node");
43 printf ("%-20s %s\n", "aug-load", "load files into the tree");
44 printf ("%-20s %s\n", "aug-ls", "list Augeas nodes under a path");
45 printf ("%-20s %s\n", "aug-match", "return Augeas nodes which match path");
46 printf ("%-20s %s\n", "aug-mv", "move Augeas node");
47 printf ("%-20s %s\n", "aug-rm", "remove an Augeas path");
48 printf ("%-20s %s\n", "aug-save", "write all pending Augeas changes to disk");
49 printf ("%-20s %s\n", "aug-set", "set Augeas path to value");
50 printf ("%-20s %s\n", "blockdev-flushbufs", "flush device buffers");
51 printf ("%-20s %s\n", "blockdev-getbsz", "get blocksize of block device");
52 printf ("%-20s %s\n", "blockdev-getro", "is block device set to read-only");
53 printf ("%-20s %s\n", "blockdev-getsize64", "get total size of device in bytes");
54 printf ("%-20s %s\n", "blockdev-getss", "get sectorsize of block device");
55 printf ("%-20s %s\n", "blockdev-getsz", "get total size of device in 512-byte sectors");
56 printf ("%-20s %s\n", "blockdev-rereadpt", "reread partition table");
57 printf ("%-20s %s\n", "blockdev-setbsz", "set blocksize of block device");
58 printf ("%-20s %s\n", "blockdev-setro", "set block device to read-only");
59 printf ("%-20s %s\n", "blockdev-setrw", "set block device to read-write");
60 printf ("%-20s %s\n", "cat", "list the contents of a file");
61 printf ("%-20s %s\n", "checksum", "compute MD5, SHAx or CRC checksum of file");
62 printf ("%-20s %s\n", "chmod", "change file mode");
63 printf ("%-20s %s\n", "chown", "change file owner and group");
64 printf ("%-20s %s\n", "command", "run a command from the guest filesystem");
65 printf ("%-20s %s\n", "command-lines", "run a command, returning lines");
66 printf ("%-20s %s\n", "config", "add qemu parameters");
67 printf ("%-20s %s\n", "cp", "copy a file");
68 printf ("%-20s %s\n", "cp-a", "copy a file or directory recursively");
69 printf ("%-20s %s\n", "debug", "debugging and internals");
70 printf ("%-20s %s\n", "df", "report file system disk space usage");
71 printf ("%-20s %s\n", "df-h", "report file system disk space usage (human readable)");
72 printf ("%-20s %s\n", "dmesg", "return kernel messages");
73 printf ("%-20s %s\n", "download", "download a file to the local machine");
74 printf ("%-20s %s\n", "drop-caches", "drop kernel page cache, dentries and inodes");
75 printf ("%-20s %s\n", "e2fsck-f", "check an ext2/ext3 filesystem");
76 printf ("%-20s %s\n", "equal", "test if two files have equal contents");
77 printf ("%-20s %s\n", "exists", "test if file or directory exists");
78 printf ("%-20s %s\n", "file", "determine file type");
79 printf ("%-20s %s\n", "find", "find all files and directories");
80 printf ("%-20s %s\n", "fsck", "run the filesystem checker");
81 printf ("%-20s %s\n", "get-append", "get the additional kernel options");
82 printf ("%-20s %s\n", "get-autosync", "get autosync mode");
83 printf ("%-20s %s\n", "get-e2label", "get the ext2/3/4 filesystem label");
84 printf ("%-20s %s\n", "get-e2uuid", "get the ext2/3/4 filesystem UUID");
85 printf ("%-20s %s\n", "get-path", "get the search path");
86 printf ("%-20s %s\n", "get-qemu", "get the qemu binary");
87 printf ("%-20s %s\n", "get-state", "get the current state");
88 printf ("%-20s %s\n", "get-verbose", "get verbose mode");
89 printf ("%-20s %s\n", "glob-expand", "expand a wildcard path");
90 printf ("%-20s %s\n", "grub-install", "install GRUB");
91 printf ("%-20s %s\n", "head", "return first 10 lines of a file");
92 printf ("%-20s %s\n", "head-n", "return first N lines of a file");
93 printf ("%-20s %s\n", "hexdump", "dump a file in hexadecimal");
94 printf ("%-20s %s\n", "is-busy", "is busy processing a command");
95 printf ("%-20s %s\n", "is-config", "is in configuration state");
96 printf ("%-20s %s\n", "is-dir", "test if file exists");
97 printf ("%-20s %s\n", "is-file", "test if file exists");
98 printf ("%-20s %s\n", "is-launching", "is launching subprocess");
99 printf ("%-20s %s\n", "is-ready", "is ready to accept commands");
100 printf ("%-20s %s\n", "kill-subprocess", "kill the qemu subprocess");
101 printf ("%-20s %s\n", "launch", "launch the qemu subprocess");
102 printf ("%-20s %s\n", "list-devices", "list the block devices");
103 printf ("%-20s %s\n", "list-partitions", "list the partitions");
104 printf ("%-20s %s\n", "ll", "list the files in a directory (long format)");
105 printf ("%-20s %s\n", "ls", "list the files in a directory");
106 printf ("%-20s %s\n", "lstat", "get file information for a symbolic link");
107 printf ("%-20s %s\n", "lvcreate", "create an LVM volume group");
108 printf ("%-20s %s\n", "lvm-remove-all", "remove all LVM LVs, VGs and PVs");
109 printf ("%-20s %s\n", "lvremove", "remove an LVM logical volume");
110 printf ("%-20s %s\n", "lvresize", "resize an LVM logical volume");
111 printf ("%-20s %s\n", "lvs", "list the LVM logical volumes (LVs)");
112 printf ("%-20s %s\n", "lvs-full", "list the LVM logical volumes (LVs)");
113 printf ("%-20s %s\n", "mkdir", "create a directory");
114 printf ("%-20s %s\n", "mkdir-p", "create a directory and parents");
115 printf ("%-20s %s\n", "mkdtemp", "create a temporary directory");
116 printf ("%-20s %s\n", "mkfs", "make a filesystem");
117 printf ("%-20s %s\n", "mount", "mount a guest disk at a position in the filesystem");
118 printf ("%-20s %s\n", "mount-options", "mount a guest disk with mount options");
119 printf ("%-20s %s\n", "mount-ro", "mount a guest disk, read-only");
120 printf ("%-20s %s\n", "mount-vfs", "mount a guest disk with mount options and vfstype");
121 printf ("%-20s %s\n", "mounts", "show mounted filesystems");
122 printf ("%-20s %s\n", "mv", "move a file");
123 printf ("%-20s %s\n", "ntfs-3g-probe", "probe NTFS volume");
124 printf ("%-20s %s\n", "ping-daemon", "ping the guest daemon");
125 printf ("%-20s %s\n", "pvcreate", "create an LVM physical volume");
126 printf ("%-20s %s\n", "pvremove", "remove an LVM physical volume");
127 printf ("%-20s %s\n", "pvresize", "resize an LVM physical volume");
128 printf ("%-20s %s\n", "pvs", "list the LVM physical volumes (PVs)");
129 printf ("%-20s %s\n", "pvs-full", "list the LVM physical volumes (PVs)");
130 printf ("%-20s %s\n", "read-lines", "read file as lines");
131 printf ("%-20s %s\n", "resize2fs", "resize an ext2/ext3 filesystem");
132 printf ("%-20s %s\n", "rm", "remove a file");
133 printf ("%-20s %s\n", "rm-rf", "remove a file or directory recursively");
134 printf ("%-20s %s\n", "rmdir", "remove a directory");
135 printf ("%-20s %s\n", "scrub-device", "scrub (securely wipe) a device");
136 printf ("%-20s %s\n", "scrub-file", "scrub (securely wipe) a file");
137 printf ("%-20s %s\n", "scrub-freespace", "scrub (securely wipe) free space");
138 printf ("%-20s %s\n", "set-append", "add options to kernel command line");
139 printf ("%-20s %s\n", "set-autosync", "set autosync mode");
140 printf ("%-20s %s\n", "set-e2label", "set the ext2/3/4 filesystem label");
141 printf ("%-20s %s\n", "set-e2uuid", "set the ext2/3/4 filesystem UUID");
142 printf ("%-20s %s\n", "set-path", "set the search path");
143 printf ("%-20s %s\n", "set-qemu", "set the qemu binary");
144 printf ("%-20s %s\n", "set-verbose", "set verbose mode");
145 printf ("%-20s %s\n", "sfdisk", "create partitions on a block device");
146 printf ("%-20s %s\n", "sfdisk-N", "modify a single partition on a block device");
147 printf ("%-20s %s\n", "sfdisk-disk-geometry", "display the disk geometry from the partition table");
148 printf ("%-20s %s\n", "sfdisk-kernel-geometry", "display the kernel geometry");
149 printf ("%-20s %s\n", "sfdisk-l", "display the partition table");
150 printf ("%-20s %s\n", "sh", "run a command via the shell");
151 printf ("%-20s %s\n", "sh-lines", "run a command via the shell returning lines");
152 printf ("%-20s %s\n", "sleep", "sleep for some seconds");
153 printf ("%-20s %s\n", "stat", "get file information");
154 printf ("%-20s %s\n", "statvfs", "get file system statistics");
155 printf ("%-20s %s\n", "strings", "print the printable strings in a file");
156 printf ("%-20s %s\n", "strings-e", "print the printable strings in a file");
157 printf ("%-20s %s\n", "sync", "sync disks, writes are flushed through to the disk image");
158 printf ("%-20s %s\n", "tail", "return last 10 lines of a file");
159 printf ("%-20s %s\n", "tail-n", "return last N lines of a file");
160 printf ("%-20s %s\n", "tar-in", "unpack tarfile to directory");
161 printf ("%-20s %s\n", "tar-out", "pack directory into tarfile");
162 printf ("%-20s %s\n", "tgz-in", "unpack compressed tarball to directory");
163 printf ("%-20s %s\n", "tgz-out", "pack directory into compressed tarball");
164 printf ("%-20s %s\n", "touch", "update file timestamps or create a new file");
165 printf ("%-20s %s\n", "tune2fs-l", "get ext2/ext3/ext4 superblock details");
166 printf ("%-20s %s\n", "umount", "unmount a filesystem");
167 printf ("%-20s %s\n", "umount-all", "unmount all filesystems");
168 printf ("%-20s %s\n", "upload", "upload a file from the local machine");
169 printf ("%-20s %s\n", "vg-activate", "activate or deactivate some volume groups");
170 printf ("%-20s %s\n", "vg-activate-all", "activate or deactivate all volume groups");
171 printf ("%-20s %s\n", "vgcreate", "create an LVM volume group");
172 printf ("%-20s %s\n", "vgremove", "remove an LVM volume group");
173 printf ("%-20s %s\n", "vgs", "list the LVM volume groups (VGs)");
174 printf ("%-20s %s\n", "vgs-full", "list the LVM volume groups (VGs)");
175 printf ("%-20s %s\n", "wc-c", "count characters in a file");
176 printf ("%-20s %s\n", "wc-l", "count lines in a file");
177 printf ("%-20s %s\n", "wc-w", "count words in a file");
178 printf ("%-20s %s\n", "write-file", "create a file");
179 printf ("%-20s %s\n", "zero", "write zeroes to the device");
180 printf ("%-20s %s\n", "zerofree", "zero unused inodes and disk blocks on ext2/3 filesystem");
181 printf (" Use -h <cmd> / help <cmd> to show detailed help for a command.\n");
184 void display_command (const char *cmd)
186 if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
187 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.");
189 if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
190 pod2text ("kill-subprocess - kill the qemu subprocess", " kill-subprocess\n\nThis kills the qemu subprocess. You should never need to call this.");
192 if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
193 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,cache=off>.\n\nNote that this call checks for the existence of C<filename>. This\nstops you from specifying other types of drive which are supported\nby qemu such as C<nbd:> and C<http:> URLs. To specify those, use\nthe general C<config> call instead.\n\nYou can use 'add' as an alias for this command.");
195 if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
196 pod2text ("add-cdrom - add a CD-ROM disk image to examine", " add-cdrom <filename>\n\nThis function adds a virtual CD-ROM disk image to the guest.\n\nThis is equivalent to the qemu parameter C<-cdrom filename>.\n\nNote that this call checks for the existence of C<filename>. This\nstops you from specifying other types of drive which are supported\nby qemu such as C<nbd:> and C<http:> URLs. To specify those, use\nthe general C<config> call instead.\n\nYou can use 'cdrom' as an alias for this command.");
198 if (strcasecmp (cmd, "add_drive_ro") == 0 || strcasecmp (cmd, "add-drive-ro") == 0 || strcasecmp (cmd, "add-ro") == 0)
199 pod2text ("add-drive-ro - add a drive in snapshot mode (read-only)", " add-drive-ro <filename>\n\nThis adds a drive in snapshot mode, making it effectively\nread-only.\n\nNote that writes to the device are allowed, and will be seen for\nthe duration of the guestfs handle, but they are written\nto a temporary file which is discarded as soon as the guestfs\nhandle is closed. We don't currently have any method to enable\nchanges to be committed, although qemu can support this.\n\nThis is equivalent to the qemu parameter\nC<-drive file=filename,snapshot=on>.\n\nNote that this call checks for the existence of C<filename>. This\nstops you from specifying other types of drive which are supported\nby qemu such as C<nbd:> and C<http:> URLs. To specify those, use\nthe general C<config> call instead.\n\nYou can use 'add-ro' as an alias for this command.");
201 if (strcasecmp (cmd, "config") == 0)
202 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.");
204 if (strcasecmp (cmd, "set_qemu") == 0 || strcasecmp (cmd, "set-qemu") == 0 || strcasecmp (cmd, "qemu") == 0)
205 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.");
207 if (strcasecmp (cmd, "get_qemu") == 0 || strcasecmp (cmd, "get-qemu") == 0)
208 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.");
210 if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
211 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.");
213 if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
214 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.");
216 if (strcasecmp (cmd, "set_append") == 0 || strcasecmp (cmd, "set-append") == 0 || strcasecmp (cmd, "append") == 0)
217 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.");
219 if (strcasecmp (cmd, "get_append") == 0 || strcasecmp (cmd, "get-append") == 0)
220 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.");
222 if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
223 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.");
225 if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
226 pod2text ("get-autosync - get autosync mode", " get-autosync\n\nGet the autosync flag.");
228 if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
229 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.");
231 if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
232 pod2text ("get-verbose - get verbose mode", " get-verbose\n\nThis returns the verbose messages flag.");
234 if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
235 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)>.");
237 if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
238 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)>.");
240 if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
241 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)>.");
243 if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
244 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)>.");
246 if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
247 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)>.");
249 if (strcasecmp (cmd, "mount") == 0)
250 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.");
252 if (strcasecmp (cmd, "sync") == 0)
253 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.");
255 if (strcasecmp (cmd, "touch") == 0)
256 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.");
258 if (strcasecmp (cmd, "cat") == 0)
259 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.");
261 if (strcasecmp (cmd, "ll") == 0)
262 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.");
264 if (strcasecmp (cmd, "ls") == 0)
265 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.");
267 if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
268 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>");
270 if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
271 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>.");
273 if (strcasecmp (cmd, "pvs") == 0)
274 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>.");
276 if (strcasecmp (cmd, "vgs") == 0)
277 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>.");
279 if (strcasecmp (cmd, "lvs") == 0)
280 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>.");
282 if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
283 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.");
285 if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
286 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.");
288 if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
289 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.");
291 if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
292 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.");
294 if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
295 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/>.");
297 if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
298 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.");
300 if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
301 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.");
303 if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
304 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.");
306 if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
307 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.");
309 if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
310 pod2text ("aug-set - set Augeas path to value", " aug-set <path> <val>\n\nSet the value associated with C<path> to C<value>.");
312 if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
313 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]>.");
315 if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
316 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.");
318 if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
319 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.");
321 if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
322 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.");
324 if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
325 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.");
327 if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
328 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.");
330 if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
331 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.");
333 if (strcasecmp (cmd, "rm") == 0)
334 pod2text ("rm - remove a file", " rm <path>\n\nRemove the single file C<path>.");
336 if (strcasecmp (cmd, "rmdir") == 0)
337 pod2text ("rmdir - remove a directory", " rmdir <path>\n\nRemove the single directory C<path>.");
339 if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
340 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.");
342 if (strcasecmp (cmd, "mkdir") == 0)
343 pod2text ("mkdir - create a directory", " mkdir <path>\n\nCreate a directory named C<path>.");
345 if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
346 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.");
348 if (strcasecmp (cmd, "chmod") == 0)
349 pod2text ("chmod - change file mode", " chmod <mode> <path>\n\nChange the mode (permissions) of C<path> to C<mode>. Only\nnumeric modes are supported.");
351 if (strcasecmp (cmd, "chown") == 0)
352 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).");
354 if (strcasecmp (cmd, "exists") == 0)
355 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>.");
357 if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
358 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>.");
360 if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
361 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>.");
363 if (strcasecmp (cmd, "pvcreate") == 0)
364 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>.");
366 if (strcasecmp (cmd, "vgcreate") == 0)
367 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>.");
369 if (strcasecmp (cmd, "lvcreate") == 0)
370 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.");
372 if (strcasecmp (cmd, "mkfs") == 0)
373 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>.");
375 if (strcasecmp (cmd, "sfdisk") == 0)
376 pod2text ("sfdisk - create partitions on a block device", " sfdisk <device> <cyls> <heads> <sectors> <lines>\n\nThis is a direct interface to the L<sfdisk(8)> program for creating\npartitions on block devices.\n\nC<device> should be a block device, for example C</dev/sda>.\n\nC<cyls>, C<heads> and C<sectors> are the number of cylinders, heads\nand sectors on the device, which are passed directly to sfdisk as\nthe I<-C>, I<-H> and I<-S> parameters. If you pass C<0> for any\nof these, then the corresponding parameter is omitted. Usually for\n'large' disks, you can just pass C<0> for these, but for small\n(floppy-sized) disks, sfdisk (or rather, the kernel) cannot work\nout the right geometry and you will need to tell it.\n\nC<lines> is a list of lines that we feed to C<sfdisk>. For more\ninformation refer to the L<sfdisk(8)> manpage.\n\nTo create a single partition occupying the whole disk, you would\npass C<lines> as a single element list, when the single element being\nthe string C<,> (comma).\n\nSee also: C<sfdisk_l>, C<sfdisk_N>\n\nB<This command is dangerous. Without careful use you\ncan easily destroy all your data>.");
378 if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
379 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.");
381 if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
382 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.");
384 if (strcasecmp (cmd, "mounts") == 0)
385 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.");
387 if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
388 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.");
390 if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
391 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>.");
393 if (strcasecmp (cmd, "file") == 0)
394 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).");
396 if (strcasecmp (cmd, "command") == 0)
397 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). Note that\nthe command runs directly, and is I<not> invoked via\nthe shell (see C<sh>).\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.");
399 if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
400 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\nSee also: C<sh_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.");
402 if (strcasecmp (cmd, "stat") == 0)
403 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.");
405 if (strcasecmp (cmd, "lstat") == 0)
406 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.");
408 if (strcasecmp (cmd, "statvfs") == 0)
409 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.");
411 if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
412 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.");
414 if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
415 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.");
417 if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
418 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.");
420 if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
421 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.");
423 if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
424 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.");
426 if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
427 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.");
429 if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
430 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.");
432 if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
433 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.");
435 if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
436 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.");
438 if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
439 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.");
441 if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
442 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.");
444 if (strcasecmp (cmd, "upload") == 0)
445 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>.");
447 if (strcasecmp (cmd, "download") == 0)
448 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>.");
450 if (strcasecmp (cmd, "checksum") == 0)
451 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.");
453 if (strcasecmp (cmd, "tar_in") == 0 || strcasecmp (cmd, "tar-in") == 0)
454 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>.");
456 if (strcasecmp (cmd, "tar_out") == 0 || strcasecmp (cmd, "tar-out") == 0)
457 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>.");
459 if (strcasecmp (cmd, "tgz_in") == 0 || strcasecmp (cmd, "tgz-in") == 0)
460 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>.");
462 if (strcasecmp (cmd, "tgz_out") == 0 || strcasecmp (cmd, "tgz-out") == 0)
463 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>.");
465 if (strcasecmp (cmd, "mount_ro") == 0 || strcasecmp (cmd, "mount-ro") == 0)
466 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.");
468 if (strcasecmp (cmd, "mount_options") == 0 || strcasecmp (cmd, "mount-options") == 0)
469 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.");
471 if (strcasecmp (cmd, "mount_vfs") == 0 || strcasecmp (cmd, "mount-vfs") == 0)
472 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.");
474 if (strcasecmp (cmd, "debug") == 0)
475 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.");
477 if (strcasecmp (cmd, "lvremove") == 0)
478 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>.");
480 if (strcasecmp (cmd, "vgremove") == 0)
481 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).");
483 if (strcasecmp (cmd, "pvremove") == 0)
484 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.");
486 if (strcasecmp (cmd, "set_e2label") == 0 || strcasecmp (cmd, "set-e2label") == 0)
487 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.");
489 if (strcasecmp (cmd, "get_e2label") == 0 || strcasecmp (cmd, "get-e2label") == 0)
490 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>.");
492 if (strcasecmp (cmd, "set_e2uuid") == 0 || strcasecmp (cmd, "set-e2uuid") == 0)
493 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.");
495 if (strcasecmp (cmd, "get_e2uuid") == 0 || strcasecmp (cmd, "get-e2uuid") == 0)
496 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>.");
498 if (strcasecmp (cmd, "fsck") == 0)
499 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>.");
501 if (strcasecmp (cmd, "zero") == 0)
502 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.\n\nSee also: C<scrub_device>.");
504 if (strcasecmp (cmd, "grub_install") == 0 || strcasecmp (cmd, "grub-install") == 0)
505 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>.");
507 if (strcasecmp (cmd, "cp") == 0)
508 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.");
510 if (strcasecmp (cmd, "cp_a") == 0 || strcasecmp (cmd, "cp-a") == 0)
511 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.");
513 if (strcasecmp (cmd, "mv") == 0)
514 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.");
516 if (strcasecmp (cmd, "drop_caches") == 0 || strcasecmp (cmd, "drop-caches") == 0)
517 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.");
519 if (strcasecmp (cmd, "dmesg") == 0)
520 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.");
522 if (strcasecmp (cmd, "ping_daemon") == 0 || strcasecmp (cmd, "ping-daemon") == 0)
523 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.");
525 if (strcasecmp (cmd, "equal") == 0)
526 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.");
528 if (strcasecmp (cmd, "strings") == 0)
529 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.");
531 if (strcasecmp (cmd, "strings_e") == 0 || strcasecmp (cmd, "strings-e") == 0)
532 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.");
534 if (strcasecmp (cmd, "hexdump") == 0)
535 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.");
537 if (strcasecmp (cmd, "zerofree") == 0)
538 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.");
540 if (strcasecmp (cmd, "pvresize") == 0)
541 pod2text ("pvresize - resize an LVM physical volume", " pvresize <device>\n\nThis resizes (expands or shrinks) an existing LVM physical\nvolume to match the new size of the underlying device.");
543 if (strcasecmp (cmd, "sfdisk_N") == 0 || strcasecmp (cmd, "sfdisk-N") == 0)
544 pod2text ("sfdisk-N - modify a single partition on a block device", " sfdisk-N <device> <partnum> <cyls> <heads> <sectors> <line>\n\nThis runs L<sfdisk(8)> option to modify just the single\npartition C<n> (note: C<n> counts from 1).\n\nFor other parameters, see C<sfdisk>. You should usually\npass C<0> for the cyls/heads/sectors parameters.\n\nB<This command is dangerous. Without careful use you\ncan easily destroy all your data>.");
546 if (strcasecmp (cmd, "sfdisk_l") == 0 || strcasecmp (cmd, "sfdisk-l") == 0)
547 pod2text ("sfdisk-l - display the partition table", " sfdisk-l <device>\n\nThis displays the partition table on C<device>, in the\nhuman-readable output of the L<sfdisk(8)> command. It is\nnot intended to be parsed.");
549 if (strcasecmp (cmd, "sfdisk_kernel_geometry") == 0 || strcasecmp (cmd, "sfdisk-kernel-geometry") == 0)
550 pod2text ("sfdisk-kernel-geometry - display the kernel geometry", " sfdisk-kernel-geometry <device>\n\nThis displays the kernel's idea of the geometry of C<device>.\n\nThe result is in human-readable format, and not designed to\nbe parsed.");
552 if (strcasecmp (cmd, "sfdisk_disk_geometry") == 0 || strcasecmp (cmd, "sfdisk-disk-geometry") == 0)
553 pod2text ("sfdisk-disk-geometry - display the disk geometry from the partition table", " sfdisk-disk-geometry <device>\n\nThis displays the disk geometry of C<device> read from the\npartition table. Especially in the case where the underlying\nblock device has been resized, this can be different from the\nkernel's idea of the geometry (see C<sfdisk_kernel_geometry>).\n\nThe result is in human-readable format, and not designed to\nbe parsed.");
555 if (strcasecmp (cmd, "vg_activate_all") == 0 || strcasecmp (cmd, "vg-activate-all") == 0)
556 pod2text ("vg-activate-all - activate or deactivate all volume groups", " vg-activate-all <activate>\n\nThis command activates or (if C<activate> is false) deactivates\nall logical volumes in all volume groups.\nIf activated, then they are made known to the\nkernel, ie. they appear as C</dev/mapper> devices. If deactivated,\nthen those devices disappear.\n\nThis command is the same as running C<vgchange -a y|n>");
558 if (strcasecmp (cmd, "vg_activate") == 0 || strcasecmp (cmd, "vg-activate") == 0)
559 pod2text ("vg-activate - activate or deactivate some volume groups", " vg-activate <activate> <volgroups>\n\nThis command activates or (if C<activate> is false) deactivates\nall logical volumes in the listed volume groups C<volgroups>.\nIf activated, then they are made known to the\nkernel, ie. they appear as C</dev/mapper> devices. If deactivated,\nthen those devices disappear.\n\nThis command is the same as running C<vgchange -a y|n volgroups...>\n\nNote that if C<volgroups> is an empty list then B<all> volume groups\nare activated or deactivated.");
561 if (strcasecmp (cmd, "lvresize") == 0)
562 pod2text ("lvresize - resize an LVM logical volume", " lvresize <device> <mbytes>\n\nThis resizes (expands or shrinks) an existing LVM logical\nvolume to C<mbytes>. When reducing, data in the reduced part\nis lost.");
564 if (strcasecmp (cmd, "resize2fs") == 0)
565 pod2text ("resize2fs - resize an ext2/ext3 filesystem", " resize2fs <device>\n\nThis resizes an ext2 or ext3 filesystem to match the size of\nthe underlying device.\n\nI<Note:> It is sometimes required that you run C<e2fsck_f>\non the C<device> before calling this command. For unknown reasons\nC<resize2fs> sometimes gives an error about this and sometimes not.\nIn any case, it is always safe to call C<e2fsck_f> before\ncalling this function.");
567 if (strcasecmp (cmd, "find") == 0)
568 pod2text ("find - find all files and directories", " find <directory>\n\nThis command lists out all files and directories, recursively,\nstarting at C<directory>. It is essentially equivalent to\nrunning the shell command C<find directory -print> but some\npost-processing happens on the output, described below.\n\nThis returns a list of strings I<without any prefix>. Thus\nif the directory structure was:\n\n /tmp/a\n /tmp/b\n /tmp/c/d\n\nthen the returned list from C<find> C</tmp> would be\n4 elements:\n\n a\n b\n c\n c/d\n\nIf C<directory> is not a directory, then this command returns\nan error.\n\nThe returned list is sorted.");
570 if (strcasecmp (cmd, "e2fsck_f") == 0 || strcasecmp (cmd, "e2fsck-f") == 0)
571 pod2text ("e2fsck-f - check an ext2/ext3 filesystem", " e2fsck-f <device>\n\nThis runs C<e2fsck -p -f device>, ie. runs the ext2/ext3\nfilesystem checker on C<device>, noninteractively (C<-p>),\neven if the filesystem appears to be clean (C<-f>).\n\nThis command is only needed because of C<resize2fs>\n(q.v.). Normally you should use C<fsck>.");
573 if (strcasecmp (cmd, "sleep") == 0)
574 pod2text ("sleep - sleep for some seconds", " sleep <secs>\n\nSleep for C<secs> seconds.");
576 if (strcasecmp (cmd, "ntfs_3g_probe") == 0 || strcasecmp (cmd, "ntfs-3g-probe") == 0)
577 pod2text ("ntfs-3g-probe - probe NTFS volume", " ntfs-3g-probe <rw> <device>\n\nThis command runs the L<ntfs-3g.probe(8)> command which probes\nan NTFS C<device> for mountability. (Not all NTFS volumes can\nbe mounted read-write, and some cannot be mounted at all).\n\nC<rw> is a boolean flag. Set it to true if you want to test\nif the volume can be mounted read-write. Set it to false if\nyou want to test if the volume can be mounted read-only.\n\nThe return value is an integer which C<0> if the operation\nwould succeed, or some non-zero value documented in the\nL<ntfs-3g.probe(8)> manual page.");
579 if (strcasecmp (cmd, "sh") == 0)
580 pod2text ("sh - run a command via the shell", " sh <command>\n\nThis call runs a command from the guest filesystem via the\nguest's C</bin/sh>.\n\nThis is like C<command>, but passes the command to:\n\n /bin/sh -c \"command\"\n\nDepending on the guest's shell, this usually results in\nwildcards being expanded, shell expressions being interpolated\nand so on.\n\nAll the provisos about C<command> apply to this call.");
582 if (strcasecmp (cmd, "sh_lines") == 0 || strcasecmp (cmd, "sh-lines") == 0)
583 pod2text ("sh-lines - run a command via the shell returning lines", " sh-lines <command>\n\nThis is the same as C<sh>, but splits the result\ninto a list of lines.\n\nSee also: C<command_lines>");
585 if (strcasecmp (cmd, "glob_expand") == 0 || strcasecmp (cmd, "glob-expand") == 0)
586 pod2text ("glob-expand - expand a wildcard path", " glob-expand <pattern>\n\nThis command searches for all the pathnames matching\nC<pattern> according to the wildcard expansion rules\nused by the shell.\n\nIf no paths match, then this returns an empty list\n(note: not an error).\n\nIt is just a wrapper around the C L<glob(3)> function\nwith flags C<GLOB_MARK|GLOB_BRACE>.\nSee that manual page for more details.");
588 if (strcasecmp (cmd, "scrub_device") == 0 || strcasecmp (cmd, "scrub-device") == 0)
589 pod2text ("scrub-device - scrub (securely wipe) a device", " scrub-device <device>\n\nThis command writes patterns over C<device> to make data retrieval\nmore difficult.\n\nIt is an interface to the L<scrub(1)> program. See that\nmanual page for more details.\n\nB<This command is dangerous. Without careful use you\ncan easily destroy all your data>.");
591 if (strcasecmp (cmd, "scrub_file") == 0 || strcasecmp (cmd, "scrub-file") == 0)
592 pod2text ("scrub-file - scrub (securely wipe) a file", " scrub-file <file>\n\nThis command writes patterns over a file to make data retrieval\nmore difficult.\n\nThe file is I<removed> after scrubbing.\n\nIt is an interface to the L<scrub(1)> program. See that\nmanual page for more details.");
594 if (strcasecmp (cmd, "scrub_freespace") == 0 || strcasecmp (cmd, "scrub-freespace") == 0)
595 pod2text ("scrub-freespace - scrub (securely wipe) free space", " scrub-freespace <dir>\n\nThis command creates the directory C<dir> and then fills it\nwith files until the filesystem is full, and scrubs the files\nas for C<scrub_file>, and deletes them.\nThe intention is to scrub any free space on the partition\ncontaining C<dir>.\n\nIt is an interface to the L<scrub(1)> program. See that\nmanual page for more details.");
597 if (strcasecmp (cmd, "mkdtemp") == 0)
598 pod2text ("mkdtemp - create a temporary directory", " mkdtemp <template>\n\nThis command creates a temporary directory. The\nC<template> parameter should be a full pathname for the\ntemporary directory name with the final six characters being\n\"XXXXXX\".\n\nFor example: \"/tmp/myprogXXXXXX\" or \"/Temp/myprogXXXXXX\",\nthe second one being suitable for Windows filesystems.\n\nThe name of the temporary directory that was created\nis returned.\n\nThe temporary directory is created with mode 0700\nand is owned by root.\n\nThe caller is responsible for deleting the temporary\ndirectory and its contents after use.\n\nSee also: L<mkdtemp(3)>");
600 if (strcasecmp (cmd, "wc_l") == 0 || strcasecmp (cmd, "wc-l") == 0)
601 pod2text ("wc-l - count lines in a file", " wc-l <path>\n\nThis command counts the lines in a file, using the\nC<wc -l> external command.");
603 if (strcasecmp (cmd, "wc_w") == 0 || strcasecmp (cmd, "wc-w") == 0)
604 pod2text ("wc-w - count words in a file", " wc-w <path>\n\nThis command counts the words in a file, using the\nC<wc -w> external command.");
606 if (strcasecmp (cmd, "wc_c") == 0 || strcasecmp (cmd, "wc-c") == 0)
607 pod2text ("wc-c - count characters in a file", " wc-c <path>\n\nThis command counts the characters in a file, using the\nC<wc -c> external command.");
609 if (strcasecmp (cmd, "head") == 0)
610 pod2text ("head - return first 10 lines of a file", " head <path>\n\nThis command returns up to the first 10 lines of a file as\na list of strings.\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.");
612 if (strcasecmp (cmd, "head_n") == 0 || strcasecmp (cmd, "head-n") == 0)
613 pod2text ("head-n - return first N lines of a file", " head-n <nrlines> <path>\n\nIf the parameter C<nrlines> is a positive number, this returns the first\nC<nrlines> lines of the file C<path>.\n\nIf the parameter C<nrlines> is a negative number, this returns lines\nfrom the file C<path>, excluding the last C<nrlines> lines.\n\nIf the parameter C<nrlines> is zero, this returns an empty list.\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.");
615 if (strcasecmp (cmd, "tail") == 0)
616 pod2text ("tail - return last 10 lines of a file", " tail <path>\n\nThis command returns up to the last 10 lines of a file as\na list of strings.\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.");
618 if (strcasecmp (cmd, "tail_n") == 0 || strcasecmp (cmd, "tail-n") == 0)
619 pod2text ("tail-n - return last N lines of a file", " tail-n <nrlines> <path>\n\nIf the parameter C<nrlines> is a positive number, this returns the last\nC<nrlines> lines of the file C<path>.\n\nIf the parameter C<nrlines> is a negative number, this returns lines\nfrom the file C<path>, starting with the C<-nrlines>th line.\n\nIf the parameter C<nrlines> is zero, this returns an empty list.\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.");
621 if (strcasecmp (cmd, "df") == 0)
622 pod2text ("df - report file system disk space usage", " df\n\nThis command runs the C<df> command to report disk space used.\n\nThis command is mostly useful for interactive sessions. It\nis I<not> intended that you try to parse the output string.\nUse C<statvfs> from programs.");
624 if (strcasecmp (cmd, "df_h") == 0 || strcasecmp (cmd, "df-h") == 0)
625 pod2text ("df-h - report file system disk space usage (human readable)", " df-h\n\nThis command runs the C<df -h> command to report disk space used\nin human-readable format.\n\nThis command is mostly useful for interactive sessions. It\nis I<not> intended that you try to parse the output string.\nUse C<statvfs> from programs.");
627 display_builtin_command (cmd);
630 static void print_pv (struct guestfs_lvm_pv *pv)
634 printf ("pv_name: %s\n", pv->pv_name);
635 printf ("pv_uuid: ");
636 for (i = 0; i < 32; ++i)
637 printf ("%c", pv->pv_uuid[i]);
639 printf ("pv_fmt: %s\n", pv->pv_fmt);
640 printf ("pv_size: %" PRIu64 "\n", pv->pv_size);
641 printf ("dev_size: %" PRIu64 "\n", pv->dev_size);
642 printf ("pv_free: %" PRIu64 "\n", pv->pv_free);
643 printf ("pv_used: %" PRIu64 "\n", pv->pv_used);
644 printf ("pv_attr: %s\n", pv->pv_attr);
645 printf ("pv_pe_count: %" PRIi64 "\n", pv->pv_pe_count);
646 printf ("pv_pe_alloc_count: %" PRIi64 "\n", pv->pv_pe_alloc_count);
647 printf ("pv_tags: %s\n", pv->pv_tags);
648 printf ("pe_start: %" PRIu64 "\n", pv->pe_start);
649 printf ("pv_mda_count: %" PRIi64 "\n", pv->pv_mda_count);
650 printf ("pv_mda_free: %" PRIu64 "\n", pv->pv_mda_free);
653 static void print_pv_list (struct guestfs_lvm_pv_list *pvs)
657 for (i = 0; i < pvs->len; ++i)
658 print_pv (&pvs->val[i]);
661 static void print_vg (struct guestfs_lvm_vg *vg)
665 printf ("vg_name: %s\n", vg->vg_name);
666 printf ("vg_uuid: ");
667 for (i = 0; i < 32; ++i)
668 printf ("%c", vg->vg_uuid[i]);
670 printf ("vg_fmt: %s\n", vg->vg_fmt);
671 printf ("vg_attr: %s\n", vg->vg_attr);
672 printf ("vg_size: %" PRIu64 "\n", vg->vg_size);
673 printf ("vg_free: %" PRIu64 "\n", vg->vg_free);
674 printf ("vg_sysid: %s\n", vg->vg_sysid);
675 printf ("vg_extent_size: %" PRIu64 "\n", vg->vg_extent_size);
676 printf ("vg_extent_count: %" PRIi64 "\n", vg->vg_extent_count);
677 printf ("vg_free_count: %" PRIi64 "\n", vg->vg_free_count);
678 printf ("max_lv: %" PRIi64 "\n", vg->max_lv);
679 printf ("max_pv: %" PRIi64 "\n", vg->max_pv);
680 printf ("pv_count: %" PRIi64 "\n", vg->pv_count);
681 printf ("lv_count: %" PRIi64 "\n", vg->lv_count);
682 printf ("snap_count: %" PRIi64 "\n", vg->snap_count);
683 printf ("vg_seqno: %" PRIi64 "\n", vg->vg_seqno);
684 printf ("vg_tags: %s\n", vg->vg_tags);
685 printf ("vg_mda_count: %" PRIi64 "\n", vg->vg_mda_count);
686 printf ("vg_mda_free: %" PRIu64 "\n", vg->vg_mda_free);
689 static void print_vg_list (struct guestfs_lvm_vg_list *vgs)
693 for (i = 0; i < vgs->len; ++i)
694 print_vg (&vgs->val[i]);
697 static void print_lv (struct guestfs_lvm_lv *lv)
701 printf ("lv_name: %s\n", lv->lv_name);
702 printf ("lv_uuid: ");
703 for (i = 0; i < 32; ++i)
704 printf ("%c", lv->lv_uuid[i]);
706 printf ("lv_attr: %s\n", lv->lv_attr);
707 printf ("lv_major: %" PRIi64 "\n", lv->lv_major);
708 printf ("lv_minor: %" PRIi64 "\n", lv->lv_minor);
709 printf ("lv_kernel_major: %" PRIi64 "\n", lv->lv_kernel_major);
710 printf ("lv_kernel_minor: %" PRIi64 "\n", lv->lv_kernel_minor);
711 printf ("lv_size: %" PRIu64 "\n", lv->lv_size);
712 printf ("seg_count: %" PRIi64 "\n", lv->seg_count);
713 printf ("origin: %s\n", lv->origin);
714 if (lv->snap_percent >= 0) printf ("snap_percent: %g %%\n", lv->snap_percent);
715 else printf ("snap_percent: \n");
716 if (lv->copy_percent >= 0) printf ("copy_percent: %g %%\n", lv->copy_percent);
717 else printf ("copy_percent: \n");
718 printf ("move_pv: %s\n", lv->move_pv);
719 printf ("lv_tags: %s\n", lv->lv_tags);
720 printf ("mirror_log: %s\n", lv->mirror_log);
721 printf ("modules: %s\n", lv->modules);
724 static void print_lv_list (struct guestfs_lvm_lv_list *lvs)
728 for (i = 0; i < lvs->len; ++i)
729 print_lv (&lvs->val[i]);
732 static void print_stat (struct guestfs_stat *stat)
734 printf ("dev: %" PRIi64 "\n", stat->dev);
735 printf ("ino: %" PRIi64 "\n", stat->ino);
736 printf ("mode: %" PRIi64 "\n", stat->mode);
737 printf ("nlink: %" PRIi64 "\n", stat->nlink);
738 printf ("uid: %" PRIi64 "\n", stat->uid);
739 printf ("gid: %" PRIi64 "\n", stat->gid);
740 printf ("rdev: %" PRIi64 "\n", stat->rdev);
741 printf ("size: %" PRIi64 "\n", stat->size);
742 printf ("blksize: %" PRIi64 "\n", stat->blksize);
743 printf ("blocks: %" PRIi64 "\n", stat->blocks);
744 printf ("atime: %" PRIi64 "\n", stat->atime);
745 printf ("mtime: %" PRIi64 "\n", stat->mtime);
746 printf ("ctime: %" PRIi64 "\n", stat->ctime);
749 static void print_statvfs (struct guestfs_statvfs *statvfs)
751 printf ("bsize: %" PRIi64 "\n", statvfs->bsize);
752 printf ("frsize: %" PRIi64 "\n", statvfs->frsize);
753 printf ("blocks: %" PRIi64 "\n", statvfs->blocks);
754 printf ("bfree: %" PRIi64 "\n", statvfs->bfree);
755 printf ("bavail: %" PRIi64 "\n", statvfs->bavail);
756 printf ("files: %" PRIi64 "\n", statvfs->files);
757 printf ("ffree: %" PRIi64 "\n", statvfs->ffree);
758 printf ("favail: %" PRIi64 "\n", statvfs->favail);
759 printf ("fsid: %" PRIi64 "\n", statvfs->fsid);
760 printf ("flag: %" PRIi64 "\n", statvfs->flag);
761 printf ("namemax: %" PRIi64 "\n", statvfs->namemax);
764 static int run_launch (const char *cmd, int argc, char *argv[])
768 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
769 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
776 static int run_kill_subprocess (const char *cmd, int argc, char *argv[])
780 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
781 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
784 r = guestfs_kill_subprocess (g);
788 static int run_add_drive (const char *cmd, int argc, char *argv[])
791 const char *filename;
793 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
794 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
798 r = guestfs_add_drive (g, filename);
802 static int run_add_cdrom (const char *cmd, int argc, char *argv[])
805 const char *filename;
807 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
808 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
812 r = guestfs_add_cdrom (g, filename);
816 static int run_add_drive_ro (const char *cmd, int argc, char *argv[])
819 const char *filename;
821 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
822 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
826 r = guestfs_add_drive_ro (g, filename);
830 static int run_config (const char *cmd, int argc, char *argv[])
833 const char *qemuparam;
834 const char *qemuvalue;
836 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
837 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
841 qemuvalue = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
842 r = guestfs_config (g, qemuparam, qemuvalue);
846 static int run_set_qemu (const char *cmd, int argc, char *argv[])
851 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
852 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
856 r = guestfs_set_qemu (g, qemu);
860 static int run_get_qemu (const char *cmd, int argc, char *argv[])
864 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
865 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
868 r = guestfs_get_qemu (g);
869 if (r == NULL) return -1;
874 static int run_set_path (const char *cmd, int argc, char *argv[])
879 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
880 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
884 r = guestfs_set_path (g, path);
888 static int run_get_path (const char *cmd, int argc, char *argv[])
892 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
893 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
896 r = guestfs_get_path (g);
897 if (r == NULL) return -1;
902 static int run_set_append (const char *cmd, int argc, char *argv[])
907 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
908 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
912 r = guestfs_set_append (g, append);
916 static int run_get_append (const char *cmd, int argc, char *argv[])
920 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
921 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
924 r = guestfs_get_append (g);
925 if (r == NULL) return -1;
930 static int run_set_autosync (const char *cmd, int argc, char *argv[])
935 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
936 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
939 autosync = is_true (argv[0]) ? 1 : 0;
940 r = guestfs_set_autosync (g, autosync);
944 static int run_get_autosync (const char *cmd, int argc, char *argv[])
948 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
949 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
952 r = guestfs_get_autosync (g);
953 if (r == -1) return -1;
954 if (r) printf ("true\n"); else printf ("false\n");
958 static int run_set_verbose (const char *cmd, int argc, char *argv[])
963 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
964 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
967 verbose = is_true (argv[0]) ? 1 : 0;
968 r = guestfs_set_verbose (g, verbose);
972 static int run_get_verbose (const char *cmd, int argc, char *argv[])
976 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
977 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
980 r = guestfs_get_verbose (g);
981 if (r == -1) return -1;
982 if (r) printf ("true\n"); else printf ("false\n");
986 static int run_is_ready (const char *cmd, int argc, char *argv[])
990 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
991 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
994 r = guestfs_is_ready (g);
995 if (r == -1) return -1;
996 if (r) printf ("true\n"); else printf ("false\n");
1000 static int run_is_config (const char *cmd, int argc, char *argv[])
1004 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1005 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1008 r = guestfs_is_config (g);
1009 if (r == -1) return -1;
1010 if (r) printf ("true\n"); else printf ("false\n");
1014 static int run_is_launching (const char *cmd, int argc, char *argv[])
1018 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1019 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1022 r = guestfs_is_launching (g);
1023 if (r == -1) return -1;
1024 if (r) printf ("true\n"); else printf ("false\n");
1028 static int run_is_busy (const char *cmd, int argc, char *argv[])
1032 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1033 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1036 r = guestfs_is_busy (g);
1037 if (r == -1) return -1;
1038 if (r) printf ("true\n"); else printf ("false\n");
1042 static int run_get_state (const char *cmd, int argc, char *argv[])
1046 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1047 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1050 r = guestfs_get_state (g);
1051 if (r == -1) return -1;
1056 static int run_mount (const char *cmd, int argc, char *argv[])
1060 const char *mountpoint;
1062 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1063 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1067 mountpoint = argv[1];
1068 r = guestfs_mount (g, device, mountpoint);
1072 static int run_sync (const char *cmd, int argc, char *argv[])
1076 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1077 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1080 r = guestfs_sync (g);
1084 static int run_touch (const char *cmd, int argc, char *argv[])
1089 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1090 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1094 r = guestfs_touch (g, path);
1098 static int run_cat (const char *cmd, int argc, char *argv[])
1103 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1104 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1108 r = guestfs_cat (g, path);
1109 if (r == NULL) return -1;
1115 static int run_ll (const char *cmd, int argc, char *argv[])
1118 const char *directory;
1120 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1121 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1124 directory = argv[0];
1125 r = guestfs_ll (g, directory);
1126 if (r == NULL) return -1;
1132 static int run_ls (const char *cmd, int argc, char *argv[])
1135 const char *directory;
1137 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1138 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1141 directory = argv[0];
1142 r = guestfs_ls (g, directory);
1143 if (r == NULL) return -1;
1149 static int run_list_devices (const char *cmd, int argc, char *argv[])
1153 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1154 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1157 r = guestfs_list_devices (g);
1158 if (r == NULL) return -1;
1164 static int run_list_partitions (const char *cmd, int argc, char *argv[])
1168 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1169 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1172 r = guestfs_list_partitions (g);
1173 if (r == NULL) return -1;
1179 static int run_pvs (const char *cmd, int argc, char *argv[])
1183 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1184 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1187 r = guestfs_pvs (g);
1188 if (r == NULL) return -1;
1194 static int run_vgs (const char *cmd, int argc, char *argv[])
1198 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1199 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1202 r = guestfs_vgs (g);
1203 if (r == NULL) return -1;
1209 static int run_lvs (const char *cmd, int argc, char *argv[])
1213 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1214 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1217 r = guestfs_lvs (g);
1218 if (r == NULL) return -1;
1224 static int run_pvs_full (const char *cmd, int argc, char *argv[])
1226 struct guestfs_lvm_pv_list *r;
1228 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1229 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1232 r = guestfs_pvs_full (g);
1233 if (r == NULL) return -1;
1235 guestfs_free_lvm_pv_list (r);
1239 static int run_vgs_full (const char *cmd, int argc, char *argv[])
1241 struct guestfs_lvm_vg_list *r;
1243 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1244 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1247 r = guestfs_vgs_full (g);
1248 if (r == NULL) return -1;
1250 guestfs_free_lvm_vg_list (r);
1254 static int run_lvs_full (const char *cmd, int argc, char *argv[])
1256 struct guestfs_lvm_lv_list *r;
1258 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1259 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1262 r = guestfs_lvs_full (g);
1263 if (r == NULL) return -1;
1265 guestfs_free_lvm_lv_list (r);
1269 static int run_read_lines (const char *cmd, int argc, char *argv[])
1274 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1275 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1279 r = guestfs_read_lines (g, path);
1280 if (r == NULL) return -1;
1286 static int run_aug_init (const char *cmd, int argc, char *argv[])
1292 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1293 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1297 flags = atoi (argv[1]);
1298 r = guestfs_aug_init (g, root, flags);
1302 static int run_aug_close (const char *cmd, int argc, char *argv[])
1306 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1307 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1310 r = guestfs_aug_close (g);
1314 static int run_aug_defvar (const char *cmd, int argc, char *argv[])
1320 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1321 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1325 expr = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
1326 r = guestfs_aug_defvar (g, name, expr);
1327 if (r == -1) return -1;
1332 static int run_aug_defnode (const char *cmd, int argc, char *argv[])
1334 struct guestfs_int_bool *r;
1339 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1340 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1346 r = guestfs_aug_defnode (g, name, expr, val);
1347 if (r == NULL) return -1;
1348 printf ("%d, %s\n", r->i,
1349 r->b ? "true" : "false");
1350 guestfs_free_int_bool (r);
1354 static int run_aug_get (const char *cmd, int argc, char *argv[])
1359 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1360 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1364 r = guestfs_aug_get (g, path);
1365 if (r == NULL) return -1;
1371 static int run_aug_set (const char *cmd, int argc, char *argv[])
1377 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1378 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1383 r = guestfs_aug_set (g, path, val);
1387 static int run_aug_insert (const char *cmd, int argc, char *argv[])
1394 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1395 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1400 before = is_true (argv[2]) ? 1 : 0;
1401 r = guestfs_aug_insert (g, path, label, before);
1405 static int run_aug_rm (const char *cmd, int argc, char *argv[])
1410 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1411 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1415 r = guestfs_aug_rm (g, path);
1416 if (r == -1) return -1;
1421 static int run_aug_mv (const char *cmd, int argc, char *argv[])
1427 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1428 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1433 r = guestfs_aug_mv (g, src, dest);
1437 static int run_aug_match (const char *cmd, int argc, char *argv[])
1442 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1443 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1447 r = guestfs_aug_match (g, path);
1448 if (r == NULL) return -1;
1454 static int run_aug_save (const char *cmd, int argc, char *argv[])
1458 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1459 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1462 r = guestfs_aug_save (g);
1466 static int run_aug_load (const char *cmd, int argc, char *argv[])
1470 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1471 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1474 r = guestfs_aug_load (g);
1478 static int run_aug_ls (const char *cmd, int argc, char *argv[])
1483 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1484 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1488 r = guestfs_aug_ls (g, path);
1489 if (r == NULL) return -1;
1495 static int run_rm (const char *cmd, int argc, char *argv[])
1500 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1501 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1505 r = guestfs_rm (g, path);
1509 static int run_rmdir (const char *cmd, int argc, char *argv[])
1514 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1515 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1519 r = guestfs_rmdir (g, path);
1523 static int run_rm_rf (const char *cmd, int argc, char *argv[])
1528 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1529 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1533 r = guestfs_rm_rf (g, path);
1537 static int run_mkdir (const char *cmd, int argc, char *argv[])
1542 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1543 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1547 r = guestfs_mkdir (g, path);
1551 static int run_mkdir_p (const char *cmd, int argc, char *argv[])
1556 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1557 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1561 r = guestfs_mkdir_p (g, path);
1565 static int run_chmod (const char *cmd, int argc, char *argv[])
1571 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1572 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1575 mode = atoi (argv[0]);
1577 r = guestfs_chmod (g, mode, path);
1581 static int run_chown (const char *cmd, int argc, char *argv[])
1588 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1589 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1592 owner = atoi (argv[0]);
1593 group = atoi (argv[1]);
1595 r = guestfs_chown (g, owner, group, path);
1599 static int run_exists (const char *cmd, int argc, char *argv[])
1604 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1605 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1609 r = guestfs_exists (g, path);
1610 if (r == -1) return -1;
1611 if (r) printf ("true\n"); else printf ("false\n");
1615 static int run_is_file (const char *cmd, int argc, char *argv[])
1620 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1621 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1625 r = guestfs_is_file (g, path);
1626 if (r == -1) return -1;
1627 if (r) printf ("true\n"); else printf ("false\n");
1631 static int run_is_dir (const char *cmd, int argc, char *argv[])
1636 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1637 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1641 r = guestfs_is_dir (g, path);
1642 if (r == -1) return -1;
1643 if (r) printf ("true\n"); else printf ("false\n");
1647 static int run_pvcreate (const char *cmd, int argc, char *argv[])
1652 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1653 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1657 r = guestfs_pvcreate (g, device);
1661 static int run_vgcreate (const char *cmd, int argc, char *argv[])
1664 const char *volgroup;
1667 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1668 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1672 physvols = parse_string_list (argv[1]);
1673 r = guestfs_vgcreate (g, volgroup, physvols);
1677 static int run_lvcreate (const char *cmd, int argc, char *argv[])
1681 const char *volgroup;
1684 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1685 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1690 mbytes = atoi (argv[2]);
1691 r = guestfs_lvcreate (g, logvol, volgroup, mbytes);
1695 static int run_mkfs (const char *cmd, int argc, char *argv[])
1701 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1702 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1707 r = guestfs_mkfs (g, fstype, device);
1711 static int run_sfdisk (const char *cmd, int argc, char *argv[])
1720 fprintf (stderr, "%s should have 5 parameter(s)\n", cmd);
1721 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1725 cyls = atoi (argv[1]);
1726 heads = atoi (argv[2]);
1727 sectors = atoi (argv[3]);
1728 lines = parse_string_list (argv[4]);
1729 r = guestfs_sfdisk (g, device, cyls, heads, sectors, lines);
1733 static int run_write_file (const char *cmd, int argc, char *argv[])
1737 const char *content;
1740 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1741 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1746 size = atoi (argv[2]);
1747 r = guestfs_write_file (g, path, content, size);
1751 static int run_umount (const char *cmd, int argc, char *argv[])
1754 const char *pathordevice;
1756 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1757 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1760 pathordevice = argv[0];
1761 r = guestfs_umount (g, pathordevice);
1765 static int run_mounts (const char *cmd, int argc, char *argv[])
1769 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1770 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1773 r = guestfs_mounts (g);
1774 if (r == NULL) return -1;
1780 static int run_umount_all (const char *cmd, int argc, char *argv[])
1784 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1785 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1788 r = guestfs_umount_all (g);
1792 static int run_lvm_remove_all (const char *cmd, int argc, char *argv[])
1796 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1797 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1800 r = guestfs_lvm_remove_all (g);
1804 static int run_file (const char *cmd, int argc, char *argv[])
1809 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1810 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1814 r = guestfs_file (g, path);
1815 if (r == NULL) return -1;
1821 static int run_command (const char *cmd, int argc, char *argv[])
1826 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1827 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1830 arguments = parse_string_list (argv[0]);
1831 r = guestfs_command (g, arguments);
1832 if (r == NULL) return -1;
1838 static int run_command_lines (const char *cmd, int argc, char *argv[])
1843 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1844 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1847 arguments = parse_string_list (argv[0]);
1848 r = guestfs_command_lines (g, arguments);
1849 if (r == NULL) return -1;
1855 static int run_stat (const char *cmd, int argc, char *argv[])
1857 struct guestfs_stat *r;
1860 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1861 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1865 r = guestfs_stat (g, path);
1866 if (r == NULL) return -1;
1872 static int run_lstat (const char *cmd, int argc, char *argv[])
1874 struct guestfs_stat *r;
1877 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1878 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1882 r = guestfs_lstat (g, path);
1883 if (r == NULL) return -1;
1889 static int run_statvfs (const char *cmd, int argc, char *argv[])
1891 struct guestfs_statvfs *r;
1894 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1895 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1899 r = guestfs_statvfs (g, path);
1900 if (r == NULL) return -1;
1906 static int run_tune2fs_l (const char *cmd, int argc, char *argv[])
1911 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1912 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1916 r = guestfs_tune2fs_l (g, device);
1917 if (r == NULL) return -1;
1923 static int run_blockdev_setro (const char *cmd, int argc, char *argv[])
1928 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1929 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1933 r = guestfs_blockdev_setro (g, device);
1937 static int run_blockdev_setrw (const char *cmd, int argc, char *argv[])
1942 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1943 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1947 r = guestfs_blockdev_setrw (g, device);
1951 static int run_blockdev_getro (const char *cmd, int argc, char *argv[])
1956 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1957 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1961 r = guestfs_blockdev_getro (g, device);
1962 if (r == -1) return -1;
1963 if (r) printf ("true\n"); else printf ("false\n");
1967 static int run_blockdev_getss (const char *cmd, int argc, char *argv[])
1972 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1973 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1977 r = guestfs_blockdev_getss (g, device);
1978 if (r == -1) return -1;
1983 static int run_blockdev_getbsz (const char *cmd, int argc, char *argv[])
1988 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1989 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1993 r = guestfs_blockdev_getbsz (g, device);
1994 if (r == -1) return -1;
1999 static int run_blockdev_setbsz (const char *cmd, int argc, char *argv[])
2005 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2006 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2010 blocksize = atoi (argv[1]);
2011 r = guestfs_blockdev_setbsz (g, device, blocksize);
2015 static int run_blockdev_getsz (const char *cmd, int argc, char *argv[])
2020 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2021 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2025 r = guestfs_blockdev_getsz (g, device);
2026 if (r == -1) return -1;
2027 printf ("%" PRIi64 "\n", r);
2031 static int run_blockdev_getsize64 (const char *cmd, int argc, char *argv[])
2036 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2037 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2041 r = guestfs_blockdev_getsize64 (g, device);
2042 if (r == -1) return -1;
2043 printf ("%" PRIi64 "\n", r);
2047 static int run_blockdev_flushbufs (const char *cmd, int argc, char *argv[])
2052 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2053 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2057 r = guestfs_blockdev_flushbufs (g, device);
2061 static int run_blockdev_rereadpt (const char *cmd, int argc, char *argv[])
2066 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2067 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2071 r = guestfs_blockdev_rereadpt (g, device);
2075 static int run_upload (const char *cmd, int argc, char *argv[])
2078 const char *filename;
2079 const char *remotefilename;
2081 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2082 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2085 filename = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
2086 remotefilename = argv[1];
2087 r = guestfs_upload (g, filename, remotefilename);
2091 static int run_download (const char *cmd, int argc, char *argv[])
2094 const char *remotefilename;
2095 const char *filename;
2097 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2098 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2101 remotefilename = argv[0];
2102 filename = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
2103 r = guestfs_download (g, remotefilename, filename);
2107 static int run_checksum (const char *cmd, int argc, char *argv[])
2110 const char *csumtype;
2113 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2114 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2119 r = guestfs_checksum (g, csumtype, path);
2120 if (r == NULL) return -1;
2126 static int run_tar_in (const char *cmd, int argc, char *argv[])
2129 const char *tarfile;
2130 const char *directory;
2132 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2133 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2136 tarfile = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
2137 directory = argv[1];
2138 r = guestfs_tar_in (g, tarfile, directory);
2142 static int run_tar_out (const char *cmd, int argc, char *argv[])
2145 const char *directory;
2146 const char *tarfile;
2148 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2149 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2152 directory = argv[0];
2153 tarfile = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
2154 r = guestfs_tar_out (g, directory, tarfile);
2158 static int run_tgz_in (const char *cmd, int argc, char *argv[])
2161 const char *tarball;
2162 const char *directory;
2164 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2165 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2168 tarball = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
2169 directory = argv[1];
2170 r = guestfs_tgz_in (g, tarball, directory);
2174 static int run_tgz_out (const char *cmd, int argc, char *argv[])
2177 const char *directory;
2178 const char *tarball;
2180 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2181 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2184 directory = argv[0];
2185 tarball = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
2186 r = guestfs_tgz_out (g, directory, tarball);
2190 static int run_mount_ro (const char *cmd, int argc, char *argv[])
2194 const char *mountpoint;
2196 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2197 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2201 mountpoint = argv[1];
2202 r = guestfs_mount_ro (g, device, mountpoint);
2206 static int run_mount_options (const char *cmd, int argc, char *argv[])
2209 const char *options;
2211 const char *mountpoint;
2213 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
2214 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2219 mountpoint = argv[2];
2220 r = guestfs_mount_options (g, options, device, mountpoint);
2224 static int run_mount_vfs (const char *cmd, int argc, char *argv[])
2227 const char *options;
2228 const char *vfstype;
2230 const char *mountpoint;
2232 fprintf (stderr, "%s should have 4 parameter(s)\n", cmd);
2233 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2239 mountpoint = argv[3];
2240 r = guestfs_mount_vfs (g, options, vfstype, device, mountpoint);
2244 static int run_debug (const char *cmd, int argc, char *argv[])
2250 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2251 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2255 extraargs = parse_string_list (argv[1]);
2256 r = guestfs_debug (g, subcmd, extraargs);
2257 if (r == NULL) return -1;
2263 static int run_lvremove (const char *cmd, int argc, char *argv[])
2268 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2269 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2273 r = guestfs_lvremove (g, device);
2277 static int run_vgremove (const char *cmd, int argc, char *argv[])
2282 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2283 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2287 r = guestfs_vgremove (g, vgname);
2291 static int run_pvremove (const char *cmd, int argc, char *argv[])
2296 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2297 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2301 r = guestfs_pvremove (g, device);
2305 static int run_set_e2label (const char *cmd, int argc, char *argv[])
2311 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2312 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2317 r = guestfs_set_e2label (g, device, label);
2321 static int run_get_e2label (const char *cmd, int argc, char *argv[])
2326 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2327 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2331 r = guestfs_get_e2label (g, device);
2332 if (r == NULL) return -1;
2338 static int run_set_e2uuid (const char *cmd, int argc, char *argv[])
2344 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2345 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2350 r = guestfs_set_e2uuid (g, device, uuid);
2354 static int run_get_e2uuid (const char *cmd, int argc, char *argv[])
2359 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2360 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2364 r = guestfs_get_e2uuid (g, device);
2365 if (r == NULL) return -1;
2371 static int run_fsck (const char *cmd, int argc, char *argv[])
2377 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2378 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2383 r = guestfs_fsck (g, fstype, device);
2384 if (r == -1) return -1;
2389 static int run_zero (const char *cmd, int argc, char *argv[])
2394 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2395 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2399 r = guestfs_zero (g, device);
2403 static int run_grub_install (const char *cmd, int argc, char *argv[])
2409 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2410 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2415 r = guestfs_grub_install (g, root, device);
2419 static int run_cp (const char *cmd, int argc, char *argv[])
2425 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2426 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2431 r = guestfs_cp (g, src, dest);
2435 static int run_cp_a (const char *cmd, int argc, char *argv[])
2441 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2442 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2447 r = guestfs_cp_a (g, src, dest);
2451 static int run_mv (const char *cmd, int argc, char *argv[])
2457 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2458 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2463 r = guestfs_mv (g, src, dest);
2467 static int run_drop_caches (const char *cmd, int argc, char *argv[])
2472 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2473 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2476 whattodrop = atoi (argv[0]);
2477 r = guestfs_drop_caches (g, whattodrop);
2481 static int run_dmesg (const char *cmd, int argc, char *argv[])
2485 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
2486 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2489 r = guestfs_dmesg (g);
2490 if (r == NULL) return -1;
2496 static int run_ping_daemon (const char *cmd, int argc, char *argv[])
2500 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
2501 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2504 r = guestfs_ping_daemon (g);
2508 static int run_equal (const char *cmd, int argc, char *argv[])
2514 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2515 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2520 r = guestfs_equal (g, file1, file2);
2521 if (r == -1) return -1;
2522 if (r) printf ("true\n"); else printf ("false\n");
2526 static int run_strings (const char *cmd, int argc, char *argv[])
2531 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2532 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2536 r = guestfs_strings (g, path);
2537 if (r == NULL) return -1;
2543 static int run_strings_e (const char *cmd, int argc, char *argv[])
2546 const char *encoding;
2549 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2550 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2555 r = guestfs_strings_e (g, encoding, path);
2556 if (r == NULL) return -1;
2562 static int run_hexdump (const char *cmd, int argc, char *argv[])
2567 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2568 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2572 r = guestfs_hexdump (g, path);
2573 if (r == NULL) return -1;
2579 static int run_zerofree (const char *cmd, int argc, char *argv[])
2584 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2585 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2589 r = guestfs_zerofree (g, device);
2593 static int run_pvresize (const char *cmd, int argc, char *argv[])
2598 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2599 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2603 r = guestfs_pvresize (g, device);
2607 static int run_sfdisk_N (const char *cmd, int argc, char *argv[])
2617 fprintf (stderr, "%s should have 6 parameter(s)\n", cmd);
2618 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2622 partnum = atoi (argv[1]);
2623 cyls = atoi (argv[2]);
2624 heads = atoi (argv[3]);
2625 sectors = atoi (argv[4]);
2627 r = guestfs_sfdisk_N (g, device, partnum, cyls, heads, sectors, line);
2631 static int run_sfdisk_l (const char *cmd, int argc, char *argv[])
2636 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2637 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2641 r = guestfs_sfdisk_l (g, device);
2642 if (r == NULL) return -1;
2648 static int run_sfdisk_kernel_geometry (const char *cmd, int argc, char *argv[])
2653 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2654 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2658 r = guestfs_sfdisk_kernel_geometry (g, device);
2659 if (r == NULL) return -1;
2665 static int run_sfdisk_disk_geometry (const char *cmd, int argc, char *argv[])
2670 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2671 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2675 r = guestfs_sfdisk_disk_geometry (g, device);
2676 if (r == NULL) return -1;
2682 static int run_vg_activate_all (const char *cmd, int argc, char *argv[])
2687 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2688 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2691 activate = is_true (argv[0]) ? 1 : 0;
2692 r = guestfs_vg_activate_all (g, activate);
2696 static int run_vg_activate (const char *cmd, int argc, char *argv[])
2702 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2703 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2706 activate = is_true (argv[0]) ? 1 : 0;
2707 volgroups = parse_string_list (argv[1]);
2708 r = guestfs_vg_activate (g, activate, volgroups);
2712 static int run_lvresize (const char *cmd, int argc, char *argv[])
2718 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2719 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2723 mbytes = atoi (argv[1]);
2724 r = guestfs_lvresize (g, device, mbytes);
2728 static int run_resize2fs (const char *cmd, int argc, char *argv[])
2733 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2734 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2738 r = guestfs_resize2fs (g, device);
2742 static int run_find (const char *cmd, int argc, char *argv[])
2745 const char *directory;
2747 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2748 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2751 directory = argv[0];
2752 r = guestfs_find (g, directory);
2753 if (r == NULL) return -1;
2759 static int run_e2fsck_f (const char *cmd, int argc, char *argv[])
2764 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2765 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2769 r = guestfs_e2fsck_f (g, device);
2773 static int run_sleep (const char *cmd, int argc, char *argv[])
2778 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2779 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2782 secs = atoi (argv[0]);
2783 r = guestfs_sleep (g, secs);
2787 static int run_ntfs_3g_probe (const char *cmd, int argc, char *argv[])
2793 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2794 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2797 rw = is_true (argv[0]) ? 1 : 0;
2799 r = guestfs_ntfs_3g_probe (g, rw, device);
2800 if (r == -1) return -1;
2805 static int run_sh (const char *cmd, int argc, char *argv[])
2808 const char *command;
2810 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2811 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2815 r = guestfs_sh (g, command);
2816 if (r == NULL) return -1;
2822 static int run_sh_lines (const char *cmd, int argc, char *argv[])
2825 const char *command;
2827 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2828 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2832 r = guestfs_sh_lines (g, command);
2833 if (r == NULL) return -1;
2839 static int run_glob_expand (const char *cmd, int argc, char *argv[])
2842 const char *pattern;
2844 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2845 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2849 r = guestfs_glob_expand (g, pattern);
2850 if (r == NULL) return -1;
2856 static int run_scrub_device (const char *cmd, int argc, char *argv[])
2861 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2862 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2866 r = guestfs_scrub_device (g, device);
2870 static int run_scrub_file (const char *cmd, int argc, char *argv[])
2875 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2876 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2880 r = guestfs_scrub_file (g, file);
2884 static int run_scrub_freespace (const char *cmd, int argc, char *argv[])
2889 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2890 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2894 r = guestfs_scrub_freespace (g, dir);
2898 static int run_mkdtemp (const char *cmd, int argc, char *argv[])
2901 const char *template;
2903 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2904 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2908 r = guestfs_mkdtemp (g, template);
2909 if (r == NULL) return -1;
2915 static int run_wc_l (const char *cmd, int argc, char *argv[])
2920 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2921 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2925 r = guestfs_wc_l (g, path);
2926 if (r == -1) return -1;
2931 static int run_wc_w (const char *cmd, int argc, char *argv[])
2936 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2937 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2941 r = guestfs_wc_w (g, path);
2942 if (r == -1) return -1;
2947 static int run_wc_c (const char *cmd, int argc, char *argv[])
2952 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2953 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2957 r = guestfs_wc_c (g, path);
2958 if (r == -1) return -1;
2963 static int run_head (const char *cmd, int argc, char *argv[])
2968 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2969 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2973 r = guestfs_head (g, path);
2974 if (r == NULL) return -1;
2980 static int run_head_n (const char *cmd, int argc, char *argv[])
2986 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2987 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2990 nrlines = atoi (argv[0]);
2992 r = guestfs_head_n (g, nrlines, path);
2993 if (r == NULL) return -1;
2999 static int run_tail (const char *cmd, int argc, char *argv[])
3004 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
3005 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
3009 r = guestfs_tail (g, path);
3010 if (r == NULL) return -1;
3016 static int run_tail_n (const char *cmd, int argc, char *argv[])
3022 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
3023 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
3026 nrlines = atoi (argv[0]);
3028 r = guestfs_tail_n (g, nrlines, path);
3029 if (r == NULL) return -1;
3035 static int run_df (const char *cmd, int argc, char *argv[])
3039 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
3040 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
3044 if (r == NULL) return -1;
3050 static int run_df_h (const char *cmd, int argc, char *argv[])
3054 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
3055 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
3058 r = guestfs_df_h (g);
3059 if (r == NULL) return -1;
3065 int run_action (const char *cmd, int argc, char *argv[])
3067 if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
3068 return run_launch (cmd, argc, argv);
3070 if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
3071 return run_kill_subprocess (cmd, argc, argv);
3073 if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
3074 return run_add_drive (cmd, argc, argv);
3076 if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
3077 return run_add_cdrom (cmd, argc, argv);
3079 if (strcasecmp (cmd, "add_drive_ro") == 0 || strcasecmp (cmd, "add-drive-ro") == 0 || strcasecmp (cmd, "add-ro") == 0)
3080 return run_add_drive_ro (cmd, argc, argv);
3082 if (strcasecmp (cmd, "config") == 0)
3083 return run_config (cmd, argc, argv);
3085 if (strcasecmp (cmd, "set_qemu") == 0 || strcasecmp (cmd, "set-qemu") == 0 || strcasecmp (cmd, "qemu") == 0)
3086 return run_set_qemu (cmd, argc, argv);
3088 if (strcasecmp (cmd, "get_qemu") == 0 || strcasecmp (cmd, "get-qemu") == 0)
3089 return run_get_qemu (cmd, argc, argv);
3091 if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
3092 return run_set_path (cmd, argc, argv);
3094 if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
3095 return run_get_path (cmd, argc, argv);
3097 if (strcasecmp (cmd, "set_append") == 0 || strcasecmp (cmd, "set-append") == 0 || strcasecmp (cmd, "append") == 0)
3098 return run_set_append (cmd, argc, argv);
3100 if (strcasecmp (cmd, "get_append") == 0 || strcasecmp (cmd, "get-append") == 0)
3101 return run_get_append (cmd, argc, argv);
3103 if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
3104 return run_set_autosync (cmd, argc, argv);
3106 if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
3107 return run_get_autosync (cmd, argc, argv);
3109 if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
3110 return run_set_verbose (cmd, argc, argv);
3112 if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
3113 return run_get_verbose (cmd, argc, argv);
3115 if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
3116 return run_is_ready (cmd, argc, argv);
3118 if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
3119 return run_is_config (cmd, argc, argv);
3121 if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
3122 return run_is_launching (cmd, argc, argv);
3124 if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
3125 return run_is_busy (cmd, argc, argv);
3127 if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
3128 return run_get_state (cmd, argc, argv);
3130 if (strcasecmp (cmd, "mount") == 0)
3131 return run_mount (cmd, argc, argv);
3133 if (strcasecmp (cmd, "sync") == 0)
3134 return run_sync (cmd, argc, argv);
3136 if (strcasecmp (cmd, "touch") == 0)
3137 return run_touch (cmd, argc, argv);
3139 if (strcasecmp (cmd, "cat") == 0)
3140 return run_cat (cmd, argc, argv);
3142 if (strcasecmp (cmd, "ll") == 0)
3143 return run_ll (cmd, argc, argv);
3145 if (strcasecmp (cmd, "ls") == 0)
3146 return run_ls (cmd, argc, argv);
3148 if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
3149 return run_list_devices (cmd, argc, argv);
3151 if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
3152 return run_list_partitions (cmd, argc, argv);
3154 if (strcasecmp (cmd, "pvs") == 0)
3155 return run_pvs (cmd, argc, argv);
3157 if (strcasecmp (cmd, "vgs") == 0)
3158 return run_vgs (cmd, argc, argv);
3160 if (strcasecmp (cmd, "lvs") == 0)
3161 return run_lvs (cmd, argc, argv);
3163 if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
3164 return run_pvs_full (cmd, argc, argv);
3166 if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
3167 return run_vgs_full (cmd, argc, argv);
3169 if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
3170 return run_lvs_full (cmd, argc, argv);
3172 if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
3173 return run_read_lines (cmd, argc, argv);
3175 if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
3176 return run_aug_init (cmd, argc, argv);
3178 if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
3179 return run_aug_close (cmd, argc, argv);
3181 if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
3182 return run_aug_defvar (cmd, argc, argv);
3184 if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
3185 return run_aug_defnode (cmd, argc, argv);
3187 if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
3188 return run_aug_get (cmd, argc, argv);
3190 if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
3191 return run_aug_set (cmd, argc, argv);
3193 if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
3194 return run_aug_insert (cmd, argc, argv);
3196 if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
3197 return run_aug_rm (cmd, argc, argv);
3199 if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
3200 return run_aug_mv (cmd, argc, argv);
3202 if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
3203 return run_aug_match (cmd, argc, argv);
3205 if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
3206 return run_aug_save (cmd, argc, argv);
3208 if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
3209 return run_aug_load (cmd, argc, argv);
3211 if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
3212 return run_aug_ls (cmd, argc, argv);
3214 if (strcasecmp (cmd, "rm") == 0)
3215 return run_rm (cmd, argc, argv);
3217 if (strcasecmp (cmd, "rmdir") == 0)
3218 return run_rmdir (cmd, argc, argv);
3220 if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
3221 return run_rm_rf (cmd, argc, argv);
3223 if (strcasecmp (cmd, "mkdir") == 0)
3224 return run_mkdir (cmd, argc, argv);
3226 if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
3227 return run_mkdir_p (cmd, argc, argv);
3229 if (strcasecmp (cmd, "chmod") == 0)
3230 return run_chmod (cmd, argc, argv);
3232 if (strcasecmp (cmd, "chown") == 0)
3233 return run_chown (cmd, argc, argv);
3235 if (strcasecmp (cmd, "exists") == 0)
3236 return run_exists (cmd, argc, argv);
3238 if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
3239 return run_is_file (cmd, argc, argv);
3241 if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
3242 return run_is_dir (cmd, argc, argv);
3244 if (strcasecmp (cmd, "pvcreate") == 0)
3245 return run_pvcreate (cmd, argc, argv);
3247 if (strcasecmp (cmd, "vgcreate") == 0)
3248 return run_vgcreate (cmd, argc, argv);
3250 if (strcasecmp (cmd, "lvcreate") == 0)
3251 return run_lvcreate (cmd, argc, argv);
3253 if (strcasecmp (cmd, "mkfs") == 0)
3254 return run_mkfs (cmd, argc, argv);
3256 if (strcasecmp (cmd, "sfdisk") == 0)
3257 return run_sfdisk (cmd, argc, argv);
3259 if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
3260 return run_write_file (cmd, argc, argv);
3262 if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
3263 return run_umount (cmd, argc, argv);
3265 if (strcasecmp (cmd, "mounts") == 0)
3266 return run_mounts (cmd, argc, argv);
3268 if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
3269 return run_umount_all (cmd, argc, argv);
3271 if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
3272 return run_lvm_remove_all (cmd, argc, argv);
3274 if (strcasecmp (cmd, "file") == 0)
3275 return run_file (cmd, argc, argv);
3277 if (strcasecmp (cmd, "command") == 0)
3278 return run_command (cmd, argc, argv);
3280 if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
3281 return run_command_lines (cmd, argc, argv);
3283 if (strcasecmp (cmd, "stat") == 0)
3284 return run_stat (cmd, argc, argv);
3286 if (strcasecmp (cmd, "lstat") == 0)
3287 return run_lstat (cmd, argc, argv);
3289 if (strcasecmp (cmd, "statvfs") == 0)
3290 return run_statvfs (cmd, argc, argv);
3292 if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
3293 return run_tune2fs_l (cmd, argc, argv);
3295 if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
3296 return run_blockdev_setro (cmd, argc, argv);
3298 if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
3299 return run_blockdev_setrw (cmd, argc, argv);
3301 if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
3302 return run_blockdev_getro (cmd, argc, argv);
3304 if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
3305 return run_blockdev_getss (cmd, argc, argv);
3307 if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
3308 return run_blockdev_getbsz (cmd, argc, argv);
3310 if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
3311 return run_blockdev_setbsz (cmd, argc, argv);
3313 if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
3314 return run_blockdev_getsz (cmd, argc, argv);
3316 if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
3317 return run_blockdev_getsize64 (cmd, argc, argv);
3319 if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
3320 return run_blockdev_flushbufs (cmd, argc, argv);
3322 if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
3323 return run_blockdev_rereadpt (cmd, argc, argv);
3325 if (strcasecmp (cmd, "upload") == 0)
3326 return run_upload (cmd, argc, argv);
3328 if (strcasecmp (cmd, "download") == 0)
3329 return run_download (cmd, argc, argv);
3331 if (strcasecmp (cmd, "checksum") == 0)
3332 return run_checksum (cmd, argc, argv);
3334 if (strcasecmp (cmd, "tar_in") == 0 || strcasecmp (cmd, "tar-in") == 0)
3335 return run_tar_in (cmd, argc, argv);
3337 if (strcasecmp (cmd, "tar_out") == 0 || strcasecmp (cmd, "tar-out") == 0)
3338 return run_tar_out (cmd, argc, argv);
3340 if (strcasecmp (cmd, "tgz_in") == 0 || strcasecmp (cmd, "tgz-in") == 0)
3341 return run_tgz_in (cmd, argc, argv);
3343 if (strcasecmp (cmd, "tgz_out") == 0 || strcasecmp (cmd, "tgz-out") == 0)
3344 return run_tgz_out (cmd, argc, argv);
3346 if (strcasecmp (cmd, "mount_ro") == 0 || strcasecmp (cmd, "mount-ro") == 0)
3347 return run_mount_ro (cmd, argc, argv);
3349 if (strcasecmp (cmd, "mount_options") == 0 || strcasecmp (cmd, "mount-options") == 0)
3350 return run_mount_options (cmd, argc, argv);
3352 if (strcasecmp (cmd, "mount_vfs") == 0 || strcasecmp (cmd, "mount-vfs") == 0)
3353 return run_mount_vfs (cmd, argc, argv);
3355 if (strcasecmp (cmd, "debug") == 0)
3356 return run_debug (cmd, argc, argv);
3358 if (strcasecmp (cmd, "lvremove") == 0)
3359 return run_lvremove (cmd, argc, argv);
3361 if (strcasecmp (cmd, "vgremove") == 0)
3362 return run_vgremove (cmd, argc, argv);
3364 if (strcasecmp (cmd, "pvremove") == 0)
3365 return run_pvremove (cmd, argc, argv);
3367 if (strcasecmp (cmd, "set_e2label") == 0 || strcasecmp (cmd, "set-e2label") == 0)
3368 return run_set_e2label (cmd, argc, argv);
3370 if (strcasecmp (cmd, "get_e2label") == 0 || strcasecmp (cmd, "get-e2label") == 0)
3371 return run_get_e2label (cmd, argc, argv);
3373 if (strcasecmp (cmd, "set_e2uuid") == 0 || strcasecmp (cmd, "set-e2uuid") == 0)
3374 return run_set_e2uuid (cmd, argc, argv);
3376 if (strcasecmp (cmd, "get_e2uuid") == 0 || strcasecmp (cmd, "get-e2uuid") == 0)
3377 return run_get_e2uuid (cmd, argc, argv);
3379 if (strcasecmp (cmd, "fsck") == 0)
3380 return run_fsck (cmd, argc, argv);
3382 if (strcasecmp (cmd, "zero") == 0)
3383 return run_zero (cmd, argc, argv);
3385 if (strcasecmp (cmd, "grub_install") == 0 || strcasecmp (cmd, "grub-install") == 0)
3386 return run_grub_install (cmd, argc, argv);
3388 if (strcasecmp (cmd, "cp") == 0)
3389 return run_cp (cmd, argc, argv);
3391 if (strcasecmp (cmd, "cp_a") == 0 || strcasecmp (cmd, "cp-a") == 0)
3392 return run_cp_a (cmd, argc, argv);
3394 if (strcasecmp (cmd, "mv") == 0)
3395 return run_mv (cmd, argc, argv);
3397 if (strcasecmp (cmd, "drop_caches") == 0 || strcasecmp (cmd, "drop-caches") == 0)
3398 return run_drop_caches (cmd, argc, argv);
3400 if (strcasecmp (cmd, "dmesg") == 0)
3401 return run_dmesg (cmd, argc, argv);
3403 if (strcasecmp (cmd, "ping_daemon") == 0 || strcasecmp (cmd, "ping-daemon") == 0)
3404 return run_ping_daemon (cmd, argc, argv);
3406 if (strcasecmp (cmd, "equal") == 0)
3407 return run_equal (cmd, argc, argv);
3409 if (strcasecmp (cmd, "strings") == 0)
3410 return run_strings (cmd, argc, argv);
3412 if (strcasecmp (cmd, "strings_e") == 0 || strcasecmp (cmd, "strings-e") == 0)
3413 return run_strings_e (cmd, argc, argv);
3415 if (strcasecmp (cmd, "hexdump") == 0)
3416 return run_hexdump (cmd, argc, argv);
3418 if (strcasecmp (cmd, "zerofree") == 0)
3419 return run_zerofree (cmd, argc, argv);
3421 if (strcasecmp (cmd, "pvresize") == 0)
3422 return run_pvresize (cmd, argc, argv);
3424 if (strcasecmp (cmd, "sfdisk_N") == 0 || strcasecmp (cmd, "sfdisk-N") == 0)
3425 return run_sfdisk_N (cmd, argc, argv);
3427 if (strcasecmp (cmd, "sfdisk_l") == 0 || strcasecmp (cmd, "sfdisk-l") == 0)
3428 return run_sfdisk_l (cmd, argc, argv);
3430 if (strcasecmp (cmd, "sfdisk_kernel_geometry") == 0 || strcasecmp (cmd, "sfdisk-kernel-geometry") == 0)
3431 return run_sfdisk_kernel_geometry (cmd, argc, argv);
3433 if (strcasecmp (cmd, "sfdisk_disk_geometry") == 0 || strcasecmp (cmd, "sfdisk-disk-geometry") == 0)
3434 return run_sfdisk_disk_geometry (cmd, argc, argv);
3436 if (strcasecmp (cmd, "vg_activate_all") == 0 || strcasecmp (cmd, "vg-activate-all") == 0)
3437 return run_vg_activate_all (cmd, argc, argv);
3439 if (strcasecmp (cmd, "vg_activate") == 0 || strcasecmp (cmd, "vg-activate") == 0)
3440 return run_vg_activate (cmd, argc, argv);
3442 if (strcasecmp (cmd, "lvresize") == 0)
3443 return run_lvresize (cmd, argc, argv);
3445 if (strcasecmp (cmd, "resize2fs") == 0)
3446 return run_resize2fs (cmd, argc, argv);
3448 if (strcasecmp (cmd, "find") == 0)
3449 return run_find (cmd, argc, argv);
3451 if (strcasecmp (cmd, "e2fsck_f") == 0 || strcasecmp (cmd, "e2fsck-f") == 0)
3452 return run_e2fsck_f (cmd, argc, argv);
3454 if (strcasecmp (cmd, "sleep") == 0)
3455 return run_sleep (cmd, argc, argv);
3457 if (strcasecmp (cmd, "ntfs_3g_probe") == 0 || strcasecmp (cmd, "ntfs-3g-probe") == 0)
3458 return run_ntfs_3g_probe (cmd, argc, argv);
3460 if (strcasecmp (cmd, "sh") == 0)
3461 return run_sh (cmd, argc, argv);
3463 if (strcasecmp (cmd, "sh_lines") == 0 || strcasecmp (cmd, "sh-lines") == 0)
3464 return run_sh_lines (cmd, argc, argv);
3466 if (strcasecmp (cmd, "glob_expand") == 0 || strcasecmp (cmd, "glob-expand") == 0)
3467 return run_glob_expand (cmd, argc, argv);
3469 if (strcasecmp (cmd, "scrub_device") == 0 || strcasecmp (cmd, "scrub-device") == 0)
3470 return run_scrub_device (cmd, argc, argv);
3472 if (strcasecmp (cmd, "scrub_file") == 0 || strcasecmp (cmd, "scrub-file") == 0)
3473 return run_scrub_file (cmd, argc, argv);
3475 if (strcasecmp (cmd, "scrub_freespace") == 0 || strcasecmp (cmd, "scrub-freespace") == 0)
3476 return run_scrub_freespace (cmd, argc, argv);
3478 if (strcasecmp (cmd, "mkdtemp") == 0)
3479 return run_mkdtemp (cmd, argc, argv);
3481 if (strcasecmp (cmd, "wc_l") == 0 || strcasecmp (cmd, "wc-l") == 0)
3482 return run_wc_l (cmd, argc, argv);
3484 if (strcasecmp (cmd, "wc_w") == 0 || strcasecmp (cmd, "wc-w") == 0)
3485 return run_wc_w (cmd, argc, argv);
3487 if (strcasecmp (cmd, "wc_c") == 0 || strcasecmp (cmd, "wc-c") == 0)
3488 return run_wc_c (cmd, argc, argv);
3490 if (strcasecmp (cmd, "head") == 0)
3491 return run_head (cmd, argc, argv);
3493 if (strcasecmp (cmd, "head_n") == 0 || strcasecmp (cmd, "head-n") == 0)
3494 return run_head_n (cmd, argc, argv);
3496 if (strcasecmp (cmd, "tail") == 0)
3497 return run_tail (cmd, argc, argv);
3499 if (strcasecmp (cmd, "tail_n") == 0 || strcasecmp (cmd, "tail-n") == 0)
3500 return run_tail_n (cmd, argc, argv);
3502 if (strcasecmp (cmd, "df") == 0)
3503 return run_df (cmd, argc, argv);
3505 if (strcasecmp (cmd, "df_h") == 0 || strcasecmp (cmd, "df-h") == 0)
3506 return run_df_h (cmd, argc, argv);
3509 fprintf (stderr, "%s: unknown command\n", cmd);