1 /* libguestfs generated file
2 * WARNING: THIS FILE IS GENERATED BY 'src/generator.ml'.
3 * ANY CHANGES YOU MAKE TO THIS FILE WILL BE LOST.
5 * Copyright (C) 2009 Red Hat Inc.
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License along
18 * with this program; if not, write to the Free Software Foundation, Inc.,
19 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
30 void list_commands (void)
32 printf (" %-16s %s\n", "Command", "Description");
33 list_builtin_commands ();
34 printf ("%-20s %s\n", "add-cdrom", "add a CD-ROM disk image to examine");
35 printf ("%-20s %s\n", "add-drive", "add an image to examine or modify");
36 printf ("%-20s %s\n", "aug-close", "close the current Augeas handle");
37 printf ("%-20s %s\n", "aug-defnode", "define an Augeas node");
38 printf ("%-20s %s\n", "aug-defvar", "define an Augeas variable");
39 printf ("%-20s %s\n", "aug-get", "look up the value of an Augeas path");
40 printf ("%-20s %s\n", "aug-init", "create a new Augeas handle");
41 printf ("%-20s %s\n", "aug-insert", "insert a sibling Augeas node");
42 printf ("%-20s %s\n", "aug-load", "load files into the tree");
43 printf ("%-20s %s\n", "aug-ls", "list Augeas nodes under a path");
44 printf ("%-20s %s\n", "aug-match", "return Augeas nodes which match path");
45 printf ("%-20s %s\n", "aug-mv", "move Augeas node");
46 printf ("%-20s %s\n", "aug-rm", "remove an Augeas path");
47 printf ("%-20s %s\n", "aug-save", "write all pending Augeas changes to disk");
48 printf ("%-20s %s\n", "aug-set", "set Augeas path to value");
49 printf ("%-20s %s\n", "blockdev-flushbufs", "flush device buffers");
50 printf ("%-20s %s\n", "blockdev-getbsz", "get blocksize of block device");
51 printf ("%-20s %s\n", "blockdev-getro", "is block device set to read-only");
52 printf ("%-20s %s\n", "blockdev-getsize64", "get total size of device in bytes");
53 printf ("%-20s %s\n", "blockdev-getss", "get sectorsize of block device");
54 printf ("%-20s %s\n", "blockdev-getsz", "get total size of device in 512-byte sectors");
55 printf ("%-20s %s\n", "blockdev-rereadpt", "reread partition table");
56 printf ("%-20s %s\n", "blockdev-setbsz", "set blocksize of block device");
57 printf ("%-20s %s\n", "blockdev-setro", "set block device to read-only");
58 printf ("%-20s %s\n", "blockdev-setrw", "set block device to read-write");
59 printf ("%-20s %s\n", "cat", "list the contents of a file");
60 printf ("%-20s %s\n", "checksum", "compute MD5, SHAx or CRC checksum of file");
61 printf ("%-20s %s\n", "chmod", "change file mode");
62 printf ("%-20s %s\n", "chown", "change file owner and group");
63 printf ("%-20s %s\n", "command", "run a command from the guest filesystem");
64 printf ("%-20s %s\n", "command-lines", "run a command, returning lines");
65 printf ("%-20s %s\n", "config", "add qemu parameters");
66 printf ("%-20s %s\n", "cp", "copy a file");
67 printf ("%-20s %s\n", "cp-a", "copy a file or directory recursively");
68 printf ("%-20s %s\n", "debug", "debugging and internals");
69 printf ("%-20s %s\n", "dmesg", "return kernel messages");
70 printf ("%-20s %s\n", "download", "download a file to the local machine");
71 printf ("%-20s %s\n", "drop-caches", "drop kernel page cache, dentries and inodes");
72 printf ("%-20s %s\n", "equal", "test if two files have equal contents");
73 printf ("%-20s %s\n", "exists", "test if file or directory exists");
74 printf ("%-20s %s\n", "file", "determine file type");
75 printf ("%-20s %s\n", "fsck", "run the filesystem checker");
76 printf ("%-20s %s\n", "get-append", "get the additional kernel options");
77 printf ("%-20s %s\n", "get-autosync", "get autosync mode");
78 printf ("%-20s %s\n", "get-e2label", "get the ext2/3/4 filesystem label");
79 printf ("%-20s %s\n", "get-e2uuid", "get the ext2/3/4 filesystem UUID");
80 printf ("%-20s %s\n", "get-path", "get the search path");
81 printf ("%-20s %s\n", "get-qemu", "get the qemu binary");
82 printf ("%-20s %s\n", "get-state", "get the current state");
83 printf ("%-20s %s\n", "get-verbose", "get verbose mode");
84 printf ("%-20s %s\n", "grub-install", "install GRUB");
85 printf ("%-20s %s\n", "hexdump", "dump a file in hexadecimal");
86 printf ("%-20s %s\n", "is-busy", "is busy processing a command");
87 printf ("%-20s %s\n", "is-config", "is in configuration state");
88 printf ("%-20s %s\n", "is-dir", "test if file exists");
89 printf ("%-20s %s\n", "is-file", "test if file exists");
90 printf ("%-20s %s\n", "is-launching", "is launching subprocess");
91 printf ("%-20s %s\n", "is-ready", "is ready to accept commands");
92 printf ("%-20s %s\n", "kill-subprocess", "kill the qemu subprocess");
93 printf ("%-20s %s\n", "launch", "launch the qemu subprocess");
94 printf ("%-20s %s\n", "list-devices", "list the block devices");
95 printf ("%-20s %s\n", "list-partitions", "list the partitions");
96 printf ("%-20s %s\n", "ll", "list the files in a directory (long format)");
97 printf ("%-20s %s\n", "ls", "list the files in a directory");
98 printf ("%-20s %s\n", "lstat", "get file information for a symbolic link");
99 printf ("%-20s %s\n", "lvcreate", "create an LVM volume group");
100 printf ("%-20s %s\n", "lvm-remove-all", "remove all LVM LVs, VGs and PVs");
101 printf ("%-20s %s\n", "lvremove", "remove an LVM logical volume");
102 printf ("%-20s %s\n", "lvs", "list the LVM logical volumes (LVs)");
103 printf ("%-20s %s\n", "lvs-full", "list the LVM logical volumes (LVs)");
104 printf ("%-20s %s\n", "mkdir", "create a directory");
105 printf ("%-20s %s\n", "mkdir-p", "create a directory and parents");
106 printf ("%-20s %s\n", "mkfs", "make a filesystem");
107 printf ("%-20s %s\n", "mount", "mount a guest disk at a position in the filesystem");
108 printf ("%-20s %s\n", "mount-options", "mount a guest disk with mount options");
109 printf ("%-20s %s\n", "mount-ro", "mount a guest disk, read-only");
110 printf ("%-20s %s\n", "mount-vfs", "mount a guest disk with mount options and vfstype");
111 printf ("%-20s %s\n", "mounts", "show mounted filesystems");
112 printf ("%-20s %s\n", "mv", "move a file");
113 printf ("%-20s %s\n", "ping-daemon", "ping the guest daemon");
114 printf ("%-20s %s\n", "pvcreate", "create an LVM physical volume");
115 printf ("%-20s %s\n", "pvremove", "remove an LVM physical volume");
116 printf ("%-20s %s\n", "pvresize", "resize an LVM physical volume");
117 printf ("%-20s %s\n", "pvs", "list the LVM physical volumes (PVs)");
118 printf ("%-20s %s\n", "pvs-full", "list the LVM physical volumes (PVs)");
119 printf ("%-20s %s\n", "read-lines", "read file as lines");
120 printf ("%-20s %s\n", "rm", "remove a file");
121 printf ("%-20s %s\n", "rm-rf", "remove a file or directory recursively");
122 printf ("%-20s %s\n", "rmdir", "remove a directory");
123 printf ("%-20s %s\n", "set-append", "add options to kernel command line");
124 printf ("%-20s %s\n", "set-autosync", "set autosync mode");
125 printf ("%-20s %s\n", "set-e2label", "set the ext2/3/4 filesystem label");
126 printf ("%-20s %s\n", "set-e2uuid", "set the ext2/3/4 filesystem UUID");
127 printf ("%-20s %s\n", "set-path", "set the search path");
128 printf ("%-20s %s\n", "set-qemu", "set the qemu binary");
129 printf ("%-20s %s\n", "set-verbose", "set verbose mode");
130 printf ("%-20s %s\n", "sfdisk", "create partitions on a block device");
131 printf ("%-20s %s\n", "sfdisk-N", "modify a single partition on a block device");
132 printf ("%-20s %s\n", "sfdisk-disk-geometry", "display the disk geometry from the partition table");
133 printf ("%-20s %s\n", "sfdisk-kernel-geometry", "display the kernel geometry");
134 printf ("%-20s %s\n", "sfdisk-l", "display the partition table");
135 printf ("%-20s %s\n", "stat", "get file information");
136 printf ("%-20s %s\n", "statvfs", "get file system statistics");
137 printf ("%-20s %s\n", "strings", "print the printable strings in a file");
138 printf ("%-20s %s\n", "strings-e", "print the printable strings in a file");
139 printf ("%-20s %s\n", "sync", "sync disks, writes are flushed through to the disk image");
140 printf ("%-20s %s\n", "tar-in", "unpack tarfile to directory");
141 printf ("%-20s %s\n", "tar-out", "pack directory into tarfile");
142 printf ("%-20s %s\n", "tgz-in", "unpack compressed tarball to directory");
143 printf ("%-20s %s\n", "tgz-out", "pack directory into compressed tarball");
144 printf ("%-20s %s\n", "touch", "update file timestamps or create a new file");
145 printf ("%-20s %s\n", "tune2fs-l", "get ext2/ext3/ext4 superblock details");
146 printf ("%-20s %s\n", "umount", "unmount a filesystem");
147 printf ("%-20s %s\n", "umount-all", "unmount all filesystems");
148 printf ("%-20s %s\n", "upload", "upload a file from the local machine");
149 printf ("%-20s %s\n", "vg-activate", "activate or deactivate some volume groups");
150 printf ("%-20s %s\n", "vg-activate-all", "activate or deactivate all volume groups");
151 printf ("%-20s %s\n", "vgcreate", "create an LVM volume group");
152 printf ("%-20s %s\n", "vgremove", "remove an LVM volume group");
153 printf ("%-20s %s\n", "vgs", "list the LVM volume groups (VGs)");
154 printf ("%-20s %s\n", "vgs-full", "list the LVM volume groups (VGs)");
155 printf ("%-20s %s\n", "write-file", "create a file");
156 printf ("%-20s %s\n", "zero", "write zeroes to the device");
157 printf ("%-20s %s\n", "zerofree", "zero unused inodes and disk blocks on ext2/3 filesystem");
158 printf (" Use -h <cmd> / help <cmd> to show detailed help for a command.\n");
161 void display_command (const char *cmd)
163 if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
164 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.");
166 if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
167 pod2text ("kill-subprocess - kill the qemu subprocess", " kill-subprocess\n\nThis kills the qemu subprocess. You should never need to call this.");
169 if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
170 pod2text ("add-drive - add an image to examine or modify", " add-drive <filename>\n\nThis function adds a virtual machine disk image C<filename> to the\nguest. The first time you call this function, the disk appears as IDE\ndisk 0 (C</dev/sda>) in the guest, the second time as C</dev/sdb>, and\nso on.\n\nYou don't necessarily need to be root when using libguestfs. However\nyou obviously do need sufficient permissions to access the filename\nfor whatever operations you want to perform (ie. read access if you\njust want to read the image or write access if you want to modify the\nimage).\n\nThis is equivalent to the qemu parameter C<-drive file=filename>.\n\nYou can use 'add' as an alias for this command.");
172 if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
173 pod2text ("add-cdrom - add a CD-ROM disk image to examine", " add-cdrom <filename>\n\nThis function adds a virtual CD-ROM disk image to the guest.\n\nThis is equivalent to the qemu parameter C<-cdrom filename>.\n\nYou can use 'cdrom' as an alias for this command.");
175 if (strcasecmp (cmd, "config") == 0)
176 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.");
178 if (strcasecmp (cmd, "set_qemu") == 0 || strcasecmp (cmd, "set-qemu") == 0 || strcasecmp (cmd, "qemu") == 0)
179 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.");
181 if (strcasecmp (cmd, "get_qemu") == 0 || strcasecmp (cmd, "get-qemu") == 0)
182 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.");
184 if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
185 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.");
187 if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
188 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.");
190 if (strcasecmp (cmd, "set_append") == 0 || strcasecmp (cmd, "set-append") == 0 || strcasecmp (cmd, "append") == 0)
191 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.");
193 if (strcasecmp (cmd, "get_append") == 0 || strcasecmp (cmd, "get-append") == 0)
194 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.");
196 if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
197 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.");
199 if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
200 pod2text ("get-autosync - get autosync mode", " get-autosync\n\nGet the autosync flag.");
202 if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
203 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.");
205 if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
206 pod2text ("get-verbose - get verbose mode", " get-verbose\n\nThis returns the verbose messages flag.");
208 if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
209 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)>.");
211 if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
212 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)>.");
214 if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
215 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)>.");
217 if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
218 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)>.");
220 if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
221 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)>.");
223 if (strcasecmp (cmd, "mount") == 0)
224 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.");
226 if (strcasecmp (cmd, "sync") == 0)
227 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.");
229 if (strcasecmp (cmd, "touch") == 0)
230 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.");
232 if (strcasecmp (cmd, "cat") == 0)
233 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.");
235 if (strcasecmp (cmd, "ll") == 0)
236 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.");
238 if (strcasecmp (cmd, "ls") == 0)
239 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.");
241 if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
242 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>");
244 if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
245 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>.");
247 if (strcasecmp (cmd, "pvs") == 0)
248 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>.");
250 if (strcasecmp (cmd, "vgs") == 0)
251 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>.");
253 if (strcasecmp (cmd, "lvs") == 0)
254 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>.");
256 if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
257 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.");
259 if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
260 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.");
262 if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
263 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.");
265 if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
266 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.");
268 if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
269 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/>.");
271 if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
272 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.");
274 if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
275 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.");
277 if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
278 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.");
280 if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
281 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.");
283 if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
284 pod2text ("aug-set - set Augeas path to value", " aug-set <path> <val>\n\nSet the value associated with C<path> to C<value>.");
286 if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
287 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]>.");
289 if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
290 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.");
292 if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
293 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.");
295 if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
296 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.");
298 if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
299 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.");
301 if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
302 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.");
304 if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
305 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.");
307 if (strcasecmp (cmd, "rm") == 0)
308 pod2text ("rm - remove a file", " rm <path>\n\nRemove the single file C<path>.");
310 if (strcasecmp (cmd, "rmdir") == 0)
311 pod2text ("rmdir - remove a directory", " rmdir <path>\n\nRemove the single directory C<path>.");
313 if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
314 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.");
316 if (strcasecmp (cmd, "mkdir") == 0)
317 pod2text ("mkdir - create a directory", " mkdir <path>\n\nCreate a directory named C<path>.");
319 if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
320 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.");
322 if (strcasecmp (cmd, "chmod") == 0)
323 pod2text ("chmod - change file mode", " chmod <mode> <path>\n\nChange the mode (permissions) of C<path> to C<mode>. Only\nnumeric modes are supported.");
325 if (strcasecmp (cmd, "chown") == 0)
326 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).");
328 if (strcasecmp (cmd, "exists") == 0)
329 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>.");
331 if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
332 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>.");
334 if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
335 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>.");
337 if (strcasecmp (cmd, "pvcreate") == 0)
338 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>.");
340 if (strcasecmp (cmd, "vgcreate") == 0)
341 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>.");
343 if (strcasecmp (cmd, "lvcreate") == 0)
344 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.");
346 if (strcasecmp (cmd, "mkfs") == 0)
347 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>.");
349 if (strcasecmp (cmd, "sfdisk") == 0)
350 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>.");
352 if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
353 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.");
355 if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
356 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.");
358 if (strcasecmp (cmd, "mounts") == 0)
359 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.");
361 if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
362 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.");
364 if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
365 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>.");
367 if (strcasecmp (cmd, "file") == 0)
368 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).");
370 if (strcasecmp (cmd, "command") == 0)
371 pod2text ("command - run a command from the guest filesystem", " command <arguments>\n\nThis call runs a command from the guest filesystem. The\nfilesystem must be mounted, and must contain a compatible\noperating system (ie. something Linux, with the same\nor compatible processor architecture).\n\nThe single parameter is an argv-style list of arguments.\nThe first element is the name of the program to run.\nSubsequent elements are parameters. The list must be\nnon-empty (ie. must contain a program name).\n\nThe return value is anything printed to I<stdout> by\nthe command.\n\nIf the command returns a non-zero exit status, then\nthis function returns an error message. The error message\nstring is the content of I<stderr> from the command.\n\nThe C<$PATH> environment variable will contain at least\nC</usr/bin> and C</bin>. If you require a program from\nanother location, you should provide the full path in the\nfirst parameter.\n\nShared libraries and data files required by the program\nmust be available on filesystems which are mounted in the\ncorrect places. It is the caller's responsibility to ensure\nall filesystems that are needed are mounted at the right\nlocations.\n\nBecause of the message protocol, there is a transfer limit \nof somewhere between 2MB and 4MB. To transfer large files you should use\nFTP.");
373 if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
374 pod2text ("command-lines - run a command, returning lines", " command-lines <arguments>\n\nThis is the same as C<command>, but splits the\nresult into a list of lines.\n\nBecause of the message protocol, there is a transfer limit \nof somewhere between 2MB and 4MB. To transfer large files you should use\nFTP.");
376 if (strcasecmp (cmd, "stat") == 0)
377 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.");
379 if (strcasecmp (cmd, "lstat") == 0)
380 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.");
382 if (strcasecmp (cmd, "statvfs") == 0)
383 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.");
385 if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
386 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.");
388 if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
389 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.");
391 if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
392 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.");
394 if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
395 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.");
397 if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
398 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.");
400 if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
401 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.");
403 if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
404 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.");
406 if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
407 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.");
409 if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
410 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.");
412 if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
413 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.");
415 if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
416 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.");
418 if (strcasecmp (cmd, "upload") == 0)
419 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>.");
421 if (strcasecmp (cmd, "download") == 0)
422 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>.");
424 if (strcasecmp (cmd, "checksum") == 0)
425 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.");
427 if (strcasecmp (cmd, "tar_in") == 0 || strcasecmp (cmd, "tar-in") == 0)
428 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>.");
430 if (strcasecmp (cmd, "tar_out") == 0 || strcasecmp (cmd, "tar-out") == 0)
431 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>.");
433 if (strcasecmp (cmd, "tgz_in") == 0 || strcasecmp (cmd, "tgz-in") == 0)
434 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>.");
436 if (strcasecmp (cmd, "tgz_out") == 0 || strcasecmp (cmd, "tgz-out") == 0)
437 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>.");
439 if (strcasecmp (cmd, "mount_ro") == 0 || strcasecmp (cmd, "mount-ro") == 0)
440 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.");
442 if (strcasecmp (cmd, "mount_options") == 0 || strcasecmp (cmd, "mount-options") == 0)
443 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.");
445 if (strcasecmp (cmd, "mount_vfs") == 0 || strcasecmp (cmd, "mount-vfs") == 0)
446 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.");
448 if (strcasecmp (cmd, "debug") == 0)
449 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.");
451 if (strcasecmp (cmd, "lvremove") == 0)
452 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>.");
454 if (strcasecmp (cmd, "vgremove") == 0)
455 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).");
457 if (strcasecmp (cmd, "pvremove") == 0)
458 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.");
460 if (strcasecmp (cmd, "set_e2label") == 0 || strcasecmp (cmd, "set-e2label") == 0)
461 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.");
463 if (strcasecmp (cmd, "get_e2label") == 0 || strcasecmp (cmd, "get-e2label") == 0)
464 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>.");
466 if (strcasecmp (cmd, "set_e2uuid") == 0 || strcasecmp (cmd, "set-e2uuid") == 0)
467 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.");
469 if (strcasecmp (cmd, "get_e2uuid") == 0 || strcasecmp (cmd, "get-e2uuid") == 0)
470 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>.");
472 if (strcasecmp (cmd, "fsck") == 0)
473 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>.");
475 if (strcasecmp (cmd, "zero") == 0)
476 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.");
478 if (strcasecmp (cmd, "grub_install") == 0 || strcasecmp (cmd, "grub-install") == 0)
479 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>.");
481 if (strcasecmp (cmd, "cp") == 0)
482 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.");
484 if (strcasecmp (cmd, "cp_a") == 0 || strcasecmp (cmd, "cp-a") == 0)
485 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.");
487 if (strcasecmp (cmd, "mv") == 0)
488 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.");
490 if (strcasecmp (cmd, "drop_caches") == 0 || strcasecmp (cmd, "drop-caches") == 0)
491 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.");
493 if (strcasecmp (cmd, "dmesg") == 0)
494 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.");
496 if (strcasecmp (cmd, "ping_daemon") == 0 || strcasecmp (cmd, "ping-daemon") == 0)
497 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.");
499 if (strcasecmp (cmd, "equal") == 0)
500 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.");
502 if (strcasecmp (cmd, "strings") == 0)
503 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.");
505 if (strcasecmp (cmd, "strings_e") == 0 || strcasecmp (cmd, "strings-e") == 0)
506 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.");
508 if (strcasecmp (cmd, "hexdump") == 0)
509 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.");
511 if (strcasecmp (cmd, "zerofree") == 0)
512 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.");
514 if (strcasecmp (cmd, "pvresize") == 0)
515 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.");
517 if (strcasecmp (cmd, "sfdisk_N") == 0 || strcasecmp (cmd, "sfdisk-N") == 0)
518 pod2text ("sfdisk-N - modify a single partition on a block device", " sfdisk-N <device> <n> <cyls> <heads> <sectors> <line>\n\nThis runs L<sfdisk(8)> option to modify just the single\npartition C<n> (note: C<n> counts from 1).\n\nFor other parameters, see C<sfdisk>. You should usually\npass C<0> for the cyls/heads/sectors parameters.\n\nB<This command is dangerous. Without careful use you\ncan easily destroy all your data>.");
520 if (strcasecmp (cmd, "sfdisk_l") == 0 || strcasecmp (cmd, "sfdisk-l") == 0)
521 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.");
523 if (strcasecmp (cmd, "sfdisk_kernel_geometry") == 0 || strcasecmp (cmd, "sfdisk-kernel-geometry") == 0)
524 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.");
526 if (strcasecmp (cmd, "sfdisk_disk_geometry") == 0 || strcasecmp (cmd, "sfdisk-disk-geometry") == 0)
527 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.");
529 if (strcasecmp (cmd, "vg_activate_all") == 0 || strcasecmp (cmd, "vg-activate-all") == 0)
530 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>");
532 if (strcasecmp (cmd, "vg_activate") == 0 || strcasecmp (cmd, "vg-activate") == 0)
533 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.");
535 display_builtin_command (cmd);
538 static void print_pv (struct guestfs_lvm_pv *pv)
542 printf ("pv_name: %s\n", pv->pv_name);
543 printf ("pv_uuid: ");
544 for (i = 0; i < 32; ++i)
545 printf ("%c", pv->pv_uuid[i]);
547 printf ("pv_fmt: %s\n", pv->pv_fmt);
548 printf ("pv_size: %" PRIu64 "\n", pv->pv_size);
549 printf ("dev_size: %" PRIu64 "\n", pv->dev_size);
550 printf ("pv_free: %" PRIu64 "\n", pv->pv_free);
551 printf ("pv_used: %" PRIu64 "\n", pv->pv_used);
552 printf ("pv_attr: %s\n", pv->pv_attr);
553 printf ("pv_pe_count: %" PRIi64 "\n", pv->pv_pe_count);
554 printf ("pv_pe_alloc_count: %" PRIi64 "\n", pv->pv_pe_alloc_count);
555 printf ("pv_tags: %s\n", pv->pv_tags);
556 printf ("pe_start: %" PRIu64 "\n", pv->pe_start);
557 printf ("pv_mda_count: %" PRIi64 "\n", pv->pv_mda_count);
558 printf ("pv_mda_free: %" PRIu64 "\n", pv->pv_mda_free);
561 static void print_pv_list (struct guestfs_lvm_pv_list *pvs)
565 for (i = 0; i < pvs->len; ++i)
566 print_pv (&pvs->val[i]);
569 static void print_vg (struct guestfs_lvm_vg *vg)
573 printf ("vg_name: %s\n", vg->vg_name);
574 printf ("vg_uuid: ");
575 for (i = 0; i < 32; ++i)
576 printf ("%c", vg->vg_uuid[i]);
578 printf ("vg_fmt: %s\n", vg->vg_fmt);
579 printf ("vg_attr: %s\n", vg->vg_attr);
580 printf ("vg_size: %" PRIu64 "\n", vg->vg_size);
581 printf ("vg_free: %" PRIu64 "\n", vg->vg_free);
582 printf ("vg_sysid: %s\n", vg->vg_sysid);
583 printf ("vg_extent_size: %" PRIu64 "\n", vg->vg_extent_size);
584 printf ("vg_extent_count: %" PRIi64 "\n", vg->vg_extent_count);
585 printf ("vg_free_count: %" PRIi64 "\n", vg->vg_free_count);
586 printf ("max_lv: %" PRIi64 "\n", vg->max_lv);
587 printf ("max_pv: %" PRIi64 "\n", vg->max_pv);
588 printf ("pv_count: %" PRIi64 "\n", vg->pv_count);
589 printf ("lv_count: %" PRIi64 "\n", vg->lv_count);
590 printf ("snap_count: %" PRIi64 "\n", vg->snap_count);
591 printf ("vg_seqno: %" PRIi64 "\n", vg->vg_seqno);
592 printf ("vg_tags: %s\n", vg->vg_tags);
593 printf ("vg_mda_count: %" PRIi64 "\n", vg->vg_mda_count);
594 printf ("vg_mda_free: %" PRIu64 "\n", vg->vg_mda_free);
597 static void print_vg_list (struct guestfs_lvm_vg_list *vgs)
601 for (i = 0; i < vgs->len; ++i)
602 print_vg (&vgs->val[i]);
605 static void print_lv (struct guestfs_lvm_lv *lv)
609 printf ("lv_name: %s\n", lv->lv_name);
610 printf ("lv_uuid: ");
611 for (i = 0; i < 32; ++i)
612 printf ("%c", lv->lv_uuid[i]);
614 printf ("lv_attr: %s\n", lv->lv_attr);
615 printf ("lv_major: %" PRIi64 "\n", lv->lv_major);
616 printf ("lv_minor: %" PRIi64 "\n", lv->lv_minor);
617 printf ("lv_kernel_major: %" PRIi64 "\n", lv->lv_kernel_major);
618 printf ("lv_kernel_minor: %" PRIi64 "\n", lv->lv_kernel_minor);
619 printf ("lv_size: %" PRIu64 "\n", lv->lv_size);
620 printf ("seg_count: %" PRIi64 "\n", lv->seg_count);
621 printf ("origin: %s\n", lv->origin);
622 if (lv->snap_percent >= 0) printf ("snap_percent: %g %%\n", lv->snap_percent);
623 else printf ("snap_percent: \n");
624 if (lv->copy_percent >= 0) printf ("copy_percent: %g %%\n", lv->copy_percent);
625 else printf ("copy_percent: \n");
626 printf ("move_pv: %s\n", lv->move_pv);
627 printf ("lv_tags: %s\n", lv->lv_tags);
628 printf ("mirror_log: %s\n", lv->mirror_log);
629 printf ("modules: %s\n", lv->modules);
632 static void print_lv_list (struct guestfs_lvm_lv_list *lvs)
636 for (i = 0; i < lvs->len; ++i)
637 print_lv (&lvs->val[i]);
640 static void print_stat (struct guestfs_stat *stat)
642 printf ("dev: %" PRIi64 "\n", stat->dev);
643 printf ("ino: %" PRIi64 "\n", stat->ino);
644 printf ("mode: %" PRIi64 "\n", stat->mode);
645 printf ("nlink: %" PRIi64 "\n", stat->nlink);
646 printf ("uid: %" PRIi64 "\n", stat->uid);
647 printf ("gid: %" PRIi64 "\n", stat->gid);
648 printf ("rdev: %" PRIi64 "\n", stat->rdev);
649 printf ("size: %" PRIi64 "\n", stat->size);
650 printf ("blksize: %" PRIi64 "\n", stat->blksize);
651 printf ("blocks: %" PRIi64 "\n", stat->blocks);
652 printf ("atime: %" PRIi64 "\n", stat->atime);
653 printf ("mtime: %" PRIi64 "\n", stat->mtime);
654 printf ("ctime: %" PRIi64 "\n", stat->ctime);
657 static void print_statvfs (struct guestfs_statvfs *statvfs)
659 printf ("bsize: %" PRIi64 "\n", statvfs->bsize);
660 printf ("frsize: %" PRIi64 "\n", statvfs->frsize);
661 printf ("blocks: %" PRIi64 "\n", statvfs->blocks);
662 printf ("bfree: %" PRIi64 "\n", statvfs->bfree);
663 printf ("bavail: %" PRIi64 "\n", statvfs->bavail);
664 printf ("files: %" PRIi64 "\n", statvfs->files);
665 printf ("ffree: %" PRIi64 "\n", statvfs->ffree);
666 printf ("favail: %" PRIi64 "\n", statvfs->favail);
667 printf ("fsid: %" PRIi64 "\n", statvfs->fsid);
668 printf ("flag: %" PRIi64 "\n", statvfs->flag);
669 printf ("namemax: %" PRIi64 "\n", statvfs->namemax);
672 static int run_launch (const char *cmd, int argc, char *argv[])
676 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
677 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
684 static int run_kill_subprocess (const char *cmd, int argc, char *argv[])
688 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
689 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
692 r = guestfs_kill_subprocess (g);
696 static int run_add_drive (const char *cmd, int argc, char *argv[])
699 const char *filename;
701 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
702 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
706 r = guestfs_add_drive (g, filename);
710 static int run_add_cdrom (const char *cmd, int argc, char *argv[])
713 const char *filename;
715 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
716 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
720 r = guestfs_add_cdrom (g, filename);
724 static int run_config (const char *cmd, int argc, char *argv[])
727 const char *qemuparam;
728 const char *qemuvalue;
730 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
731 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
735 qemuvalue = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
736 r = guestfs_config (g, qemuparam, qemuvalue);
740 static int run_set_qemu (const char *cmd, int argc, char *argv[])
745 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
746 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
750 r = guestfs_set_qemu (g, qemu);
754 static int run_get_qemu (const char *cmd, int argc, char *argv[])
758 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
759 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
762 r = guestfs_get_qemu (g);
763 if (r == NULL) return -1;
768 static int run_set_path (const char *cmd, int argc, char *argv[])
773 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
774 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
778 r = guestfs_set_path (g, path);
782 static int run_get_path (const char *cmd, int argc, char *argv[])
786 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
787 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
790 r = guestfs_get_path (g);
791 if (r == NULL) return -1;
796 static int run_set_append (const char *cmd, int argc, char *argv[])
801 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
802 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
806 r = guestfs_set_append (g, append);
810 static int run_get_append (const char *cmd, int argc, char *argv[])
814 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
815 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
818 r = guestfs_get_append (g);
819 if (r == NULL) return -1;
824 static int run_set_autosync (const char *cmd, int argc, char *argv[])
829 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
830 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
833 autosync = is_true (argv[0]) ? 1 : 0;
834 r = guestfs_set_autosync (g, autosync);
838 static int run_get_autosync (const char *cmd, int argc, char *argv[])
842 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
843 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
846 r = guestfs_get_autosync (g);
847 if (r == -1) return -1;
848 if (r) printf ("true\n"); else printf ("false\n");
852 static int run_set_verbose (const char *cmd, int argc, char *argv[])
857 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
858 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
861 verbose = is_true (argv[0]) ? 1 : 0;
862 r = guestfs_set_verbose (g, verbose);
866 static int run_get_verbose (const char *cmd, int argc, char *argv[])
870 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
871 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
874 r = guestfs_get_verbose (g);
875 if (r == -1) return -1;
876 if (r) printf ("true\n"); else printf ("false\n");
880 static int run_is_ready (const char *cmd, int argc, char *argv[])
884 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
885 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
888 r = guestfs_is_ready (g);
889 if (r == -1) return -1;
890 if (r) printf ("true\n"); else printf ("false\n");
894 static int run_is_config (const char *cmd, int argc, char *argv[])
898 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
899 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
902 r = guestfs_is_config (g);
903 if (r == -1) return -1;
904 if (r) printf ("true\n"); else printf ("false\n");
908 static int run_is_launching (const char *cmd, int argc, char *argv[])
912 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
913 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
916 r = guestfs_is_launching (g);
917 if (r == -1) return -1;
918 if (r) printf ("true\n"); else printf ("false\n");
922 static int run_is_busy (const char *cmd, int argc, char *argv[])
926 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
927 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
930 r = guestfs_is_busy (g);
931 if (r == -1) return -1;
932 if (r) printf ("true\n"); else printf ("false\n");
936 static int run_get_state (const char *cmd, int argc, char *argv[])
940 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
941 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
944 r = guestfs_get_state (g);
945 if (r == -1) return -1;
950 static int run_mount (const char *cmd, int argc, char *argv[])
954 const char *mountpoint;
956 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
957 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
961 mountpoint = argv[1];
962 r = guestfs_mount (g, device, mountpoint);
966 static int run_sync (const char *cmd, int argc, char *argv[])
970 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
971 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
974 r = guestfs_sync (g);
978 static int run_touch (const char *cmd, int argc, char *argv[])
983 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
984 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
988 r = guestfs_touch (g, path);
992 static int run_cat (const char *cmd, int argc, char *argv[])
997 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
998 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1002 r = guestfs_cat (g, path);
1003 if (r == NULL) return -1;
1009 static int run_ll (const char *cmd, int argc, char *argv[])
1012 const char *directory;
1014 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1015 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1018 directory = argv[0];
1019 r = guestfs_ll (g, directory);
1020 if (r == NULL) return -1;
1026 static int run_ls (const char *cmd, int argc, char *argv[])
1029 const char *directory;
1031 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1032 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1035 directory = argv[0];
1036 r = guestfs_ls (g, directory);
1037 if (r == NULL) return -1;
1043 static int run_list_devices (const char *cmd, int argc, char *argv[])
1047 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1048 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1051 r = guestfs_list_devices (g);
1052 if (r == NULL) return -1;
1058 static int run_list_partitions (const char *cmd, int argc, char *argv[])
1062 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1063 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1066 r = guestfs_list_partitions (g);
1067 if (r == NULL) return -1;
1073 static int run_pvs (const char *cmd, int argc, char *argv[])
1077 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1078 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1081 r = guestfs_pvs (g);
1082 if (r == NULL) return -1;
1088 static int run_vgs (const char *cmd, int argc, char *argv[])
1092 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1093 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1096 r = guestfs_vgs (g);
1097 if (r == NULL) return -1;
1103 static int run_lvs (const char *cmd, int argc, char *argv[])
1107 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1108 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1111 r = guestfs_lvs (g);
1112 if (r == NULL) return -1;
1118 static int run_pvs_full (const char *cmd, int argc, char *argv[])
1120 struct guestfs_lvm_pv_list *r;
1122 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1123 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1126 r = guestfs_pvs_full (g);
1127 if (r == NULL) return -1;
1129 guestfs_free_lvm_pv_list (r);
1133 static int run_vgs_full (const char *cmd, int argc, char *argv[])
1135 struct guestfs_lvm_vg_list *r;
1137 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1138 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1141 r = guestfs_vgs_full (g);
1142 if (r == NULL) return -1;
1144 guestfs_free_lvm_vg_list (r);
1148 static int run_lvs_full (const char *cmd, int argc, char *argv[])
1150 struct guestfs_lvm_lv_list *r;
1152 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1153 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1156 r = guestfs_lvs_full (g);
1157 if (r == NULL) return -1;
1159 guestfs_free_lvm_lv_list (r);
1163 static int run_read_lines (const char *cmd, int argc, char *argv[])
1168 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1169 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1173 r = guestfs_read_lines (g, path);
1174 if (r == NULL) return -1;
1180 static int run_aug_init (const char *cmd, int argc, char *argv[])
1186 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1187 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1191 flags = atoi (argv[1]);
1192 r = guestfs_aug_init (g, root, flags);
1196 static int run_aug_close (const char *cmd, int argc, char *argv[])
1200 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1201 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1204 r = guestfs_aug_close (g);
1208 static int run_aug_defvar (const char *cmd, int argc, char *argv[])
1214 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1215 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1219 expr = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
1220 r = guestfs_aug_defvar (g, name, expr);
1221 if (r == -1) return -1;
1226 static int run_aug_defnode (const char *cmd, int argc, char *argv[])
1228 struct guestfs_int_bool *r;
1233 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1234 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1240 r = guestfs_aug_defnode (g, name, expr, val);
1241 if (r == NULL) return -1;
1242 printf ("%d, %s\n", r->i,
1243 r->b ? "true" : "false");
1244 guestfs_free_int_bool (r);
1248 static int run_aug_get (const char *cmd, int argc, char *argv[])
1253 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1254 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1258 r = guestfs_aug_get (g, path);
1259 if (r == NULL) return -1;
1265 static int run_aug_set (const char *cmd, int argc, char *argv[])
1271 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1272 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1277 r = guestfs_aug_set (g, path, val);
1281 static int run_aug_insert (const char *cmd, int argc, char *argv[])
1288 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1289 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1294 before = is_true (argv[2]) ? 1 : 0;
1295 r = guestfs_aug_insert (g, path, label, before);
1299 static int run_aug_rm (const char *cmd, int argc, char *argv[])
1304 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1305 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1309 r = guestfs_aug_rm (g, path);
1310 if (r == -1) return -1;
1315 static int run_aug_mv (const char *cmd, int argc, char *argv[])
1321 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1322 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1327 r = guestfs_aug_mv (g, src, dest);
1331 static int run_aug_match (const char *cmd, int argc, char *argv[])
1336 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1337 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1341 r = guestfs_aug_match (g, path);
1342 if (r == NULL) return -1;
1348 static int run_aug_save (const char *cmd, int argc, char *argv[])
1352 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1353 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1356 r = guestfs_aug_save (g);
1360 static int run_aug_load (const char *cmd, int argc, char *argv[])
1364 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1365 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1368 r = guestfs_aug_load (g);
1372 static int run_aug_ls (const char *cmd, int argc, char *argv[])
1377 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1378 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1382 r = guestfs_aug_ls (g, path);
1383 if (r == NULL) return -1;
1389 static int run_rm (const char *cmd, int argc, char *argv[])
1394 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1395 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1399 r = guestfs_rm (g, path);
1403 static int run_rmdir (const char *cmd, int argc, char *argv[])
1408 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1409 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1413 r = guestfs_rmdir (g, path);
1417 static int run_rm_rf (const char *cmd, int argc, char *argv[])
1422 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1423 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1427 r = guestfs_rm_rf (g, path);
1431 static int run_mkdir (const char *cmd, int argc, char *argv[])
1436 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1437 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1441 r = guestfs_mkdir (g, path);
1445 static int run_mkdir_p (const char *cmd, int argc, char *argv[])
1450 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1451 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1455 r = guestfs_mkdir_p (g, path);
1459 static int run_chmod (const char *cmd, int argc, char *argv[])
1465 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1466 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1469 mode = atoi (argv[0]);
1471 r = guestfs_chmod (g, mode, path);
1475 static int run_chown (const char *cmd, int argc, char *argv[])
1482 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1483 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1486 owner = atoi (argv[0]);
1487 group = atoi (argv[1]);
1489 r = guestfs_chown (g, owner, group, path);
1493 static int run_exists (const char *cmd, int argc, char *argv[])
1498 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1499 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1503 r = guestfs_exists (g, path);
1504 if (r == -1) return -1;
1505 if (r) printf ("true\n"); else printf ("false\n");
1509 static int run_is_file (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_is_file (g, path);
1520 if (r == -1) return -1;
1521 if (r) printf ("true\n"); else printf ("false\n");
1525 static int run_is_dir (const char *cmd, int argc, char *argv[])
1530 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1531 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1535 r = guestfs_is_dir (g, path);
1536 if (r == -1) return -1;
1537 if (r) printf ("true\n"); else printf ("false\n");
1541 static int run_pvcreate (const char *cmd, int argc, char *argv[])
1546 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1547 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1551 r = guestfs_pvcreate (g, device);
1555 static int run_vgcreate (const char *cmd, int argc, char *argv[])
1558 const char *volgroup;
1561 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1562 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1566 physvols = parse_string_list (argv[1]);
1567 r = guestfs_vgcreate (g, volgroup, physvols);
1571 static int run_lvcreate (const char *cmd, int argc, char *argv[])
1575 const char *volgroup;
1578 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1579 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1584 mbytes = atoi (argv[2]);
1585 r = guestfs_lvcreate (g, logvol, volgroup, mbytes);
1589 static int run_mkfs (const char *cmd, int argc, char *argv[])
1595 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1596 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1601 r = guestfs_mkfs (g, fstype, device);
1605 static int run_sfdisk (const char *cmd, int argc, char *argv[])
1614 fprintf (stderr, "%s should have 5 parameter(s)\n", cmd);
1615 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1619 cyls = atoi (argv[1]);
1620 heads = atoi (argv[2]);
1621 sectors = atoi (argv[3]);
1622 lines = parse_string_list (argv[4]);
1623 r = guestfs_sfdisk (g, device, cyls, heads, sectors, lines);
1627 static int run_write_file (const char *cmd, int argc, char *argv[])
1631 const char *content;
1634 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1635 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1640 size = atoi (argv[2]);
1641 r = guestfs_write_file (g, path, content, size);
1645 static int run_umount (const char *cmd, int argc, char *argv[])
1648 const char *pathordevice;
1650 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1651 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1654 pathordevice = argv[0];
1655 r = guestfs_umount (g, pathordevice);
1659 static int run_mounts (const char *cmd, int argc, char *argv[])
1663 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1664 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1667 r = guestfs_mounts (g);
1668 if (r == NULL) return -1;
1674 static int run_umount_all (const char *cmd, int argc, char *argv[])
1678 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1679 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1682 r = guestfs_umount_all (g);
1686 static int run_lvm_remove_all (const char *cmd, int argc, char *argv[])
1690 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1691 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1694 r = guestfs_lvm_remove_all (g);
1698 static int run_file (const char *cmd, int argc, char *argv[])
1703 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1704 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1708 r = guestfs_file (g, path);
1709 if (r == NULL) return -1;
1715 static int run_command (const char *cmd, int argc, char *argv[])
1720 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1721 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1724 arguments = parse_string_list (argv[0]);
1725 r = guestfs_command (g, arguments);
1726 if (r == NULL) return -1;
1732 static int run_command_lines (const char *cmd, int argc, char *argv[])
1737 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1738 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1741 arguments = parse_string_list (argv[0]);
1742 r = guestfs_command_lines (g, arguments);
1743 if (r == NULL) return -1;
1749 static int run_stat (const char *cmd, int argc, char *argv[])
1751 struct guestfs_stat *r;
1754 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1755 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1759 r = guestfs_stat (g, path);
1760 if (r == NULL) return -1;
1766 static int run_lstat (const char *cmd, int argc, char *argv[])
1768 struct guestfs_stat *r;
1771 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1772 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1776 r = guestfs_lstat (g, path);
1777 if (r == NULL) return -1;
1783 static int run_statvfs (const char *cmd, int argc, char *argv[])
1785 struct guestfs_statvfs *r;
1788 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1789 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1793 r = guestfs_statvfs (g, path);
1794 if (r == NULL) return -1;
1800 static int run_tune2fs_l (const char *cmd, int argc, char *argv[])
1805 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1806 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1810 r = guestfs_tune2fs_l (g, device);
1811 if (r == NULL) return -1;
1817 static int run_blockdev_setro (const char *cmd, int argc, char *argv[])
1822 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1823 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1827 r = guestfs_blockdev_setro (g, device);
1831 static int run_blockdev_setrw (const char *cmd, int argc, char *argv[])
1836 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1837 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1841 r = guestfs_blockdev_setrw (g, device);
1845 static int run_blockdev_getro (const char *cmd, int argc, char *argv[])
1850 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1851 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1855 r = guestfs_blockdev_getro (g, device);
1856 if (r == -1) return -1;
1857 if (r) printf ("true\n"); else printf ("false\n");
1861 static int run_blockdev_getss (const char *cmd, int argc, char *argv[])
1866 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1867 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1871 r = guestfs_blockdev_getss (g, device);
1872 if (r == -1) return -1;
1877 static int run_blockdev_getbsz (const char *cmd, int argc, char *argv[])
1882 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1883 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1887 r = guestfs_blockdev_getbsz (g, device);
1888 if (r == -1) return -1;
1893 static int run_blockdev_setbsz (const char *cmd, int argc, char *argv[])
1899 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1900 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1904 blocksize = atoi (argv[1]);
1905 r = guestfs_blockdev_setbsz (g, device, blocksize);
1909 static int run_blockdev_getsz (const char *cmd, int argc, char *argv[])
1914 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1915 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1919 r = guestfs_blockdev_getsz (g, device);
1920 if (r == -1) return -1;
1921 printf ("%" PRIi64 "\n", r);
1925 static int run_blockdev_getsize64 (const char *cmd, int argc, char *argv[])
1930 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1931 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1935 r = guestfs_blockdev_getsize64 (g, device);
1936 if (r == -1) return -1;
1937 printf ("%" PRIi64 "\n", r);
1941 static int run_blockdev_flushbufs (const char *cmd, int argc, char *argv[])
1946 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1947 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1951 r = guestfs_blockdev_flushbufs (g, device);
1955 static int run_blockdev_rereadpt (const char *cmd, int argc, char *argv[])
1960 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1961 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1965 r = guestfs_blockdev_rereadpt (g, device);
1969 static int run_upload (const char *cmd, int argc, char *argv[])
1972 const char *filename;
1973 const char *remotefilename;
1975 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1976 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1979 filename = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
1980 remotefilename = argv[1];
1981 r = guestfs_upload (g, filename, remotefilename);
1985 static int run_download (const char *cmd, int argc, char *argv[])
1988 const char *remotefilename;
1989 const char *filename;
1991 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1992 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1995 remotefilename = argv[0];
1996 filename = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
1997 r = guestfs_download (g, remotefilename, filename);
2001 static int run_checksum (const char *cmd, int argc, char *argv[])
2004 const char *csumtype;
2007 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2008 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2013 r = guestfs_checksum (g, csumtype, path);
2014 if (r == NULL) return -1;
2020 static int run_tar_in (const char *cmd, int argc, char *argv[])
2023 const char *tarfile;
2024 const char *directory;
2026 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2027 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2030 tarfile = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
2031 directory = argv[1];
2032 r = guestfs_tar_in (g, tarfile, directory);
2036 static int run_tar_out (const char *cmd, int argc, char *argv[])
2039 const char *directory;
2040 const char *tarfile;
2042 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2043 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2046 directory = argv[0];
2047 tarfile = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
2048 r = guestfs_tar_out (g, directory, tarfile);
2052 static int run_tgz_in (const char *cmd, int argc, char *argv[])
2055 const char *tarball;
2056 const char *directory;
2058 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2059 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2062 tarball = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
2063 directory = argv[1];
2064 r = guestfs_tgz_in (g, tarball, directory);
2068 static int run_tgz_out (const char *cmd, int argc, char *argv[])
2071 const char *directory;
2072 const char *tarball;
2074 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2075 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2078 directory = argv[0];
2079 tarball = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
2080 r = guestfs_tgz_out (g, directory, tarball);
2084 static int run_mount_ro (const char *cmd, int argc, char *argv[])
2088 const char *mountpoint;
2090 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2091 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2095 mountpoint = argv[1];
2096 r = guestfs_mount_ro (g, device, mountpoint);
2100 static int run_mount_options (const char *cmd, int argc, char *argv[])
2103 const char *options;
2105 const char *mountpoint;
2107 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
2108 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2113 mountpoint = argv[2];
2114 r = guestfs_mount_options (g, options, device, mountpoint);
2118 static int run_mount_vfs (const char *cmd, int argc, char *argv[])
2121 const char *options;
2122 const char *vfstype;
2124 const char *mountpoint;
2126 fprintf (stderr, "%s should have 4 parameter(s)\n", cmd);
2127 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2133 mountpoint = argv[3];
2134 r = guestfs_mount_vfs (g, options, vfstype, device, mountpoint);
2138 static int run_debug (const char *cmd, int argc, char *argv[])
2144 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2145 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2149 extraargs = parse_string_list (argv[1]);
2150 r = guestfs_debug (g, subcmd, extraargs);
2151 if (r == NULL) return -1;
2157 static int run_lvremove (const char *cmd, int argc, char *argv[])
2162 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2163 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2167 r = guestfs_lvremove (g, device);
2171 static int run_vgremove (const char *cmd, int argc, char *argv[])
2176 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2177 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2181 r = guestfs_vgremove (g, vgname);
2185 static int run_pvremove (const char *cmd, int argc, char *argv[])
2190 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2191 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2195 r = guestfs_pvremove (g, device);
2199 static int run_set_e2label (const char *cmd, int argc, char *argv[])
2205 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2206 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2211 r = guestfs_set_e2label (g, device, label);
2215 static int run_get_e2label (const char *cmd, int argc, char *argv[])
2220 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2221 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2225 r = guestfs_get_e2label (g, device);
2226 if (r == NULL) return -1;
2232 static int run_set_e2uuid (const char *cmd, int argc, char *argv[])
2238 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2239 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2244 r = guestfs_set_e2uuid (g, device, uuid);
2248 static int run_get_e2uuid (const char *cmd, int argc, char *argv[])
2253 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2254 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2258 r = guestfs_get_e2uuid (g, device);
2259 if (r == NULL) return -1;
2265 static int run_fsck (const char *cmd, int argc, char *argv[])
2271 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2272 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2277 r = guestfs_fsck (g, fstype, device);
2278 if (r == -1) return -1;
2283 static int run_zero (const char *cmd, int argc, char *argv[])
2288 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2289 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2293 r = guestfs_zero (g, device);
2297 static int run_grub_install (const char *cmd, int argc, char *argv[])
2303 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2304 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2309 r = guestfs_grub_install (g, root, device);
2313 static int run_cp (const char *cmd, int argc, char *argv[])
2319 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2320 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2325 r = guestfs_cp (g, src, dest);
2329 static int run_cp_a (const char *cmd, int argc, char *argv[])
2335 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2336 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2341 r = guestfs_cp_a (g, src, dest);
2345 static int run_mv (const char *cmd, int argc, char *argv[])
2351 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2352 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2357 r = guestfs_mv (g, src, dest);
2361 static int run_drop_caches (const char *cmd, int argc, char *argv[])
2366 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2367 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2370 whattodrop = atoi (argv[0]);
2371 r = guestfs_drop_caches (g, whattodrop);
2375 static int run_dmesg (const char *cmd, int argc, char *argv[])
2379 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
2380 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2383 r = guestfs_dmesg (g);
2384 if (r == NULL) return -1;
2390 static int run_ping_daemon (const char *cmd, int argc, char *argv[])
2394 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
2395 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2398 r = guestfs_ping_daemon (g);
2402 static int run_equal (const char *cmd, int argc, char *argv[])
2408 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2409 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2414 r = guestfs_equal (g, file1, file2);
2415 if (r == -1) return -1;
2416 if (r) printf ("true\n"); else printf ("false\n");
2420 static int run_strings (const char *cmd, int argc, char *argv[])
2425 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2426 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2430 r = guestfs_strings (g, path);
2431 if (r == NULL) return -1;
2437 static int run_strings_e (const char *cmd, int argc, char *argv[])
2440 const char *encoding;
2443 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2444 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2449 r = guestfs_strings_e (g, encoding, path);
2450 if (r == NULL) return -1;
2456 static int run_hexdump (const char *cmd, int argc, char *argv[])
2461 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2462 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2466 r = guestfs_hexdump (g, path);
2467 if (r == NULL) return -1;
2473 static int run_zerofree (const char *cmd, int argc, char *argv[])
2478 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2479 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2483 r = guestfs_zerofree (g, device);
2487 static int run_pvresize (const char *cmd, int argc, char *argv[])
2492 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2493 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2497 r = guestfs_pvresize (g, device);
2501 static int run_sfdisk_N (const char *cmd, int argc, char *argv[])
2511 fprintf (stderr, "%s should have 6 parameter(s)\n", cmd);
2512 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2517 cyls = atoi (argv[2]);
2518 heads = atoi (argv[3]);
2519 sectors = atoi (argv[4]);
2521 r = guestfs_sfdisk_N (g, device, n, cyls, heads, sectors, line);
2525 static int run_sfdisk_l (const char *cmd, int argc, char *argv[])
2530 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2531 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2535 r = guestfs_sfdisk_l (g, device);
2536 if (r == NULL) return -1;
2542 static int run_sfdisk_kernel_geometry (const char *cmd, int argc, char *argv[])
2547 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2548 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2552 r = guestfs_sfdisk_kernel_geometry (g, device);
2553 if (r == NULL) return -1;
2559 static int run_sfdisk_disk_geometry (const char *cmd, int argc, char *argv[])
2564 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2565 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2569 r = guestfs_sfdisk_disk_geometry (g, device);
2570 if (r == NULL) return -1;
2576 static int run_vg_activate_all (const char *cmd, int argc, char *argv[])
2581 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2582 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2585 activate = is_true (argv[0]) ? 1 : 0;
2586 r = guestfs_vg_activate_all (g, activate);
2590 static int run_vg_activate (const char *cmd, int argc, char *argv[])
2596 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2597 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2600 activate = is_true (argv[0]) ? 1 : 0;
2601 volgroups = parse_string_list (argv[1]);
2602 r = guestfs_vg_activate (g, activate, volgroups);
2606 int run_action (const char *cmd, int argc, char *argv[])
2608 if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
2609 return run_launch (cmd, argc, argv);
2611 if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
2612 return run_kill_subprocess (cmd, argc, argv);
2614 if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
2615 return run_add_drive (cmd, argc, argv);
2617 if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
2618 return run_add_cdrom (cmd, argc, argv);
2620 if (strcasecmp (cmd, "config") == 0)
2621 return run_config (cmd, argc, argv);
2623 if (strcasecmp (cmd, "set_qemu") == 0 || strcasecmp (cmd, "set-qemu") == 0 || strcasecmp (cmd, "qemu") == 0)
2624 return run_set_qemu (cmd, argc, argv);
2626 if (strcasecmp (cmd, "get_qemu") == 0 || strcasecmp (cmd, "get-qemu") == 0)
2627 return run_get_qemu (cmd, argc, argv);
2629 if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
2630 return run_set_path (cmd, argc, argv);
2632 if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
2633 return run_get_path (cmd, argc, argv);
2635 if (strcasecmp (cmd, "set_append") == 0 || strcasecmp (cmd, "set-append") == 0 || strcasecmp (cmd, "append") == 0)
2636 return run_set_append (cmd, argc, argv);
2638 if (strcasecmp (cmd, "get_append") == 0 || strcasecmp (cmd, "get-append") == 0)
2639 return run_get_append (cmd, argc, argv);
2641 if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
2642 return run_set_autosync (cmd, argc, argv);
2644 if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
2645 return run_get_autosync (cmd, argc, argv);
2647 if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
2648 return run_set_verbose (cmd, argc, argv);
2650 if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
2651 return run_get_verbose (cmd, argc, argv);
2653 if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
2654 return run_is_ready (cmd, argc, argv);
2656 if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
2657 return run_is_config (cmd, argc, argv);
2659 if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
2660 return run_is_launching (cmd, argc, argv);
2662 if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
2663 return run_is_busy (cmd, argc, argv);
2665 if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
2666 return run_get_state (cmd, argc, argv);
2668 if (strcasecmp (cmd, "mount") == 0)
2669 return run_mount (cmd, argc, argv);
2671 if (strcasecmp (cmd, "sync") == 0)
2672 return run_sync (cmd, argc, argv);
2674 if (strcasecmp (cmd, "touch") == 0)
2675 return run_touch (cmd, argc, argv);
2677 if (strcasecmp (cmd, "cat") == 0)
2678 return run_cat (cmd, argc, argv);
2680 if (strcasecmp (cmd, "ll") == 0)
2681 return run_ll (cmd, argc, argv);
2683 if (strcasecmp (cmd, "ls") == 0)
2684 return run_ls (cmd, argc, argv);
2686 if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
2687 return run_list_devices (cmd, argc, argv);
2689 if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
2690 return run_list_partitions (cmd, argc, argv);
2692 if (strcasecmp (cmd, "pvs") == 0)
2693 return run_pvs (cmd, argc, argv);
2695 if (strcasecmp (cmd, "vgs") == 0)
2696 return run_vgs (cmd, argc, argv);
2698 if (strcasecmp (cmd, "lvs") == 0)
2699 return run_lvs (cmd, argc, argv);
2701 if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
2702 return run_pvs_full (cmd, argc, argv);
2704 if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
2705 return run_vgs_full (cmd, argc, argv);
2707 if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
2708 return run_lvs_full (cmd, argc, argv);
2710 if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
2711 return run_read_lines (cmd, argc, argv);
2713 if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
2714 return run_aug_init (cmd, argc, argv);
2716 if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
2717 return run_aug_close (cmd, argc, argv);
2719 if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
2720 return run_aug_defvar (cmd, argc, argv);
2722 if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
2723 return run_aug_defnode (cmd, argc, argv);
2725 if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
2726 return run_aug_get (cmd, argc, argv);
2728 if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
2729 return run_aug_set (cmd, argc, argv);
2731 if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
2732 return run_aug_insert (cmd, argc, argv);
2734 if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
2735 return run_aug_rm (cmd, argc, argv);
2737 if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
2738 return run_aug_mv (cmd, argc, argv);
2740 if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
2741 return run_aug_match (cmd, argc, argv);
2743 if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
2744 return run_aug_save (cmd, argc, argv);
2746 if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
2747 return run_aug_load (cmd, argc, argv);
2749 if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
2750 return run_aug_ls (cmd, argc, argv);
2752 if (strcasecmp (cmd, "rm") == 0)
2753 return run_rm (cmd, argc, argv);
2755 if (strcasecmp (cmd, "rmdir") == 0)
2756 return run_rmdir (cmd, argc, argv);
2758 if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
2759 return run_rm_rf (cmd, argc, argv);
2761 if (strcasecmp (cmd, "mkdir") == 0)
2762 return run_mkdir (cmd, argc, argv);
2764 if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
2765 return run_mkdir_p (cmd, argc, argv);
2767 if (strcasecmp (cmd, "chmod") == 0)
2768 return run_chmod (cmd, argc, argv);
2770 if (strcasecmp (cmd, "chown") == 0)
2771 return run_chown (cmd, argc, argv);
2773 if (strcasecmp (cmd, "exists") == 0)
2774 return run_exists (cmd, argc, argv);
2776 if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
2777 return run_is_file (cmd, argc, argv);
2779 if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
2780 return run_is_dir (cmd, argc, argv);
2782 if (strcasecmp (cmd, "pvcreate") == 0)
2783 return run_pvcreate (cmd, argc, argv);
2785 if (strcasecmp (cmd, "vgcreate") == 0)
2786 return run_vgcreate (cmd, argc, argv);
2788 if (strcasecmp (cmd, "lvcreate") == 0)
2789 return run_lvcreate (cmd, argc, argv);
2791 if (strcasecmp (cmd, "mkfs") == 0)
2792 return run_mkfs (cmd, argc, argv);
2794 if (strcasecmp (cmd, "sfdisk") == 0)
2795 return run_sfdisk (cmd, argc, argv);
2797 if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
2798 return run_write_file (cmd, argc, argv);
2800 if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
2801 return run_umount (cmd, argc, argv);
2803 if (strcasecmp (cmd, "mounts") == 0)
2804 return run_mounts (cmd, argc, argv);
2806 if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
2807 return run_umount_all (cmd, argc, argv);
2809 if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
2810 return run_lvm_remove_all (cmd, argc, argv);
2812 if (strcasecmp (cmd, "file") == 0)
2813 return run_file (cmd, argc, argv);
2815 if (strcasecmp (cmd, "command") == 0)
2816 return run_command (cmd, argc, argv);
2818 if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
2819 return run_command_lines (cmd, argc, argv);
2821 if (strcasecmp (cmd, "stat") == 0)
2822 return run_stat (cmd, argc, argv);
2824 if (strcasecmp (cmd, "lstat") == 0)
2825 return run_lstat (cmd, argc, argv);
2827 if (strcasecmp (cmd, "statvfs") == 0)
2828 return run_statvfs (cmd, argc, argv);
2830 if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
2831 return run_tune2fs_l (cmd, argc, argv);
2833 if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
2834 return run_blockdev_setro (cmd, argc, argv);
2836 if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
2837 return run_blockdev_setrw (cmd, argc, argv);
2839 if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
2840 return run_blockdev_getro (cmd, argc, argv);
2842 if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
2843 return run_blockdev_getss (cmd, argc, argv);
2845 if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
2846 return run_blockdev_getbsz (cmd, argc, argv);
2848 if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
2849 return run_blockdev_setbsz (cmd, argc, argv);
2851 if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
2852 return run_blockdev_getsz (cmd, argc, argv);
2854 if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
2855 return run_blockdev_getsize64 (cmd, argc, argv);
2857 if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
2858 return run_blockdev_flushbufs (cmd, argc, argv);
2860 if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
2861 return run_blockdev_rereadpt (cmd, argc, argv);
2863 if (strcasecmp (cmd, "upload") == 0)
2864 return run_upload (cmd, argc, argv);
2866 if (strcasecmp (cmd, "download") == 0)
2867 return run_download (cmd, argc, argv);
2869 if (strcasecmp (cmd, "checksum") == 0)
2870 return run_checksum (cmd, argc, argv);
2872 if (strcasecmp (cmd, "tar_in") == 0 || strcasecmp (cmd, "tar-in") == 0)
2873 return run_tar_in (cmd, argc, argv);
2875 if (strcasecmp (cmd, "tar_out") == 0 || strcasecmp (cmd, "tar-out") == 0)
2876 return run_tar_out (cmd, argc, argv);
2878 if (strcasecmp (cmd, "tgz_in") == 0 || strcasecmp (cmd, "tgz-in") == 0)
2879 return run_tgz_in (cmd, argc, argv);
2881 if (strcasecmp (cmd, "tgz_out") == 0 || strcasecmp (cmd, "tgz-out") == 0)
2882 return run_tgz_out (cmd, argc, argv);
2884 if (strcasecmp (cmd, "mount_ro") == 0 || strcasecmp (cmd, "mount-ro") == 0)
2885 return run_mount_ro (cmd, argc, argv);
2887 if (strcasecmp (cmd, "mount_options") == 0 || strcasecmp (cmd, "mount-options") == 0)
2888 return run_mount_options (cmd, argc, argv);
2890 if (strcasecmp (cmd, "mount_vfs") == 0 || strcasecmp (cmd, "mount-vfs") == 0)
2891 return run_mount_vfs (cmd, argc, argv);
2893 if (strcasecmp (cmd, "debug") == 0)
2894 return run_debug (cmd, argc, argv);
2896 if (strcasecmp (cmd, "lvremove") == 0)
2897 return run_lvremove (cmd, argc, argv);
2899 if (strcasecmp (cmd, "vgremove") == 0)
2900 return run_vgremove (cmd, argc, argv);
2902 if (strcasecmp (cmd, "pvremove") == 0)
2903 return run_pvremove (cmd, argc, argv);
2905 if (strcasecmp (cmd, "set_e2label") == 0 || strcasecmp (cmd, "set-e2label") == 0)
2906 return run_set_e2label (cmd, argc, argv);
2908 if (strcasecmp (cmd, "get_e2label") == 0 || strcasecmp (cmd, "get-e2label") == 0)
2909 return run_get_e2label (cmd, argc, argv);
2911 if (strcasecmp (cmd, "set_e2uuid") == 0 || strcasecmp (cmd, "set-e2uuid") == 0)
2912 return run_set_e2uuid (cmd, argc, argv);
2914 if (strcasecmp (cmd, "get_e2uuid") == 0 || strcasecmp (cmd, "get-e2uuid") == 0)
2915 return run_get_e2uuid (cmd, argc, argv);
2917 if (strcasecmp (cmd, "fsck") == 0)
2918 return run_fsck (cmd, argc, argv);
2920 if (strcasecmp (cmd, "zero") == 0)
2921 return run_zero (cmd, argc, argv);
2923 if (strcasecmp (cmd, "grub_install") == 0 || strcasecmp (cmd, "grub-install") == 0)
2924 return run_grub_install (cmd, argc, argv);
2926 if (strcasecmp (cmd, "cp") == 0)
2927 return run_cp (cmd, argc, argv);
2929 if (strcasecmp (cmd, "cp_a") == 0 || strcasecmp (cmd, "cp-a") == 0)
2930 return run_cp_a (cmd, argc, argv);
2932 if (strcasecmp (cmd, "mv") == 0)
2933 return run_mv (cmd, argc, argv);
2935 if (strcasecmp (cmd, "drop_caches") == 0 || strcasecmp (cmd, "drop-caches") == 0)
2936 return run_drop_caches (cmd, argc, argv);
2938 if (strcasecmp (cmd, "dmesg") == 0)
2939 return run_dmesg (cmd, argc, argv);
2941 if (strcasecmp (cmd, "ping_daemon") == 0 || strcasecmp (cmd, "ping-daemon") == 0)
2942 return run_ping_daemon (cmd, argc, argv);
2944 if (strcasecmp (cmd, "equal") == 0)
2945 return run_equal (cmd, argc, argv);
2947 if (strcasecmp (cmd, "strings") == 0)
2948 return run_strings (cmd, argc, argv);
2950 if (strcasecmp (cmd, "strings_e") == 0 || strcasecmp (cmd, "strings-e") == 0)
2951 return run_strings_e (cmd, argc, argv);
2953 if (strcasecmp (cmd, "hexdump") == 0)
2954 return run_hexdump (cmd, argc, argv);
2956 if (strcasecmp (cmd, "zerofree") == 0)
2957 return run_zerofree (cmd, argc, argv);
2959 if (strcasecmp (cmd, "pvresize") == 0)
2960 return run_pvresize (cmd, argc, argv);
2962 if (strcasecmp (cmd, "sfdisk_N") == 0 || strcasecmp (cmd, "sfdisk-N") == 0)
2963 return run_sfdisk_N (cmd, argc, argv);
2965 if (strcasecmp (cmd, "sfdisk_l") == 0 || strcasecmp (cmd, "sfdisk-l") == 0)
2966 return run_sfdisk_l (cmd, argc, argv);
2968 if (strcasecmp (cmd, "sfdisk_kernel_geometry") == 0 || strcasecmp (cmd, "sfdisk-kernel-geometry") == 0)
2969 return run_sfdisk_kernel_geometry (cmd, argc, argv);
2971 if (strcasecmp (cmd, "sfdisk_disk_geometry") == 0 || strcasecmp (cmd, "sfdisk-disk-geometry") == 0)
2972 return run_sfdisk_disk_geometry (cmd, argc, argv);
2974 if (strcasecmp (cmd, "vg_activate_all") == 0 || strcasecmp (cmd, "vg-activate-all") == 0)
2975 return run_vg_activate_all (cmd, argc, argv);
2977 if (strcasecmp (cmd, "vg_activate") == 0 || strcasecmp (cmd, "vg-activate") == 0)
2978 return run_vg_activate (cmd, argc, argv);
2981 fprintf (stderr, "%s: unknown command\n", cmd);