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", "exists", "test if file or directory exists");
73 printf ("%-20s %s\n", "file", "determine file type");
74 printf ("%-20s %s\n", "fsck", "run the filesystem checker");
75 printf ("%-20s %s\n", "get-autosync", "get autosync mode");
76 printf ("%-20s %s\n", "get-e2label", "get the ext2/3/4 filesystem label");
77 printf ("%-20s %s\n", "get-e2uuid", "get the ext2/3/4 filesystem UUID");
78 printf ("%-20s %s\n", "get-path", "get the search path");
79 printf ("%-20s %s\n", "get-qemu", "get the qemu binary");
80 printf ("%-20s %s\n", "get-state", "get the current state");
81 printf ("%-20s %s\n", "get-verbose", "get verbose mode");
82 printf ("%-20s %s\n", "grub-install", "install GRUB");
83 printf ("%-20s %s\n", "is-busy", "is busy processing a command");
84 printf ("%-20s %s\n", "is-config", "is in configuration state");
85 printf ("%-20s %s\n", "is-dir", "test if file exists");
86 printf ("%-20s %s\n", "is-file", "test if file exists");
87 printf ("%-20s %s\n", "is-launching", "is launching subprocess");
88 printf ("%-20s %s\n", "is-ready", "is ready to accept commands");
89 printf ("%-20s %s\n", "kill-subprocess", "kill the qemu subprocess");
90 printf ("%-20s %s\n", "launch", "launch the qemu subprocess");
91 printf ("%-20s %s\n", "list-devices", "list the block devices");
92 printf ("%-20s %s\n", "list-partitions", "list the partitions");
93 printf ("%-20s %s\n", "ll", "list the files in a directory (long format)");
94 printf ("%-20s %s\n", "ls", "list the files in a directory");
95 printf ("%-20s %s\n", "lstat", "get file information for a symbolic link");
96 printf ("%-20s %s\n", "lvcreate", "create an LVM volume group");
97 printf ("%-20s %s\n", "lvm-remove-all", "remove all LVM LVs, VGs and PVs");
98 printf ("%-20s %s\n", "lvremove", "remove an LVM logical volume");
99 printf ("%-20s %s\n", "lvs", "list the LVM logical volumes (LVs)");
100 printf ("%-20s %s\n", "lvs-full", "list the LVM logical volumes (LVs)");
101 printf ("%-20s %s\n", "mkdir", "create a directory");
102 printf ("%-20s %s\n", "mkdir-p", "create a directory and parents");
103 printf ("%-20s %s\n", "mkfs", "make a filesystem");
104 printf ("%-20s %s\n", "mount", "mount a guest disk at a position in the filesystem");
105 printf ("%-20s %s\n", "mount-options", "mount a guest disk with mount options");
106 printf ("%-20s %s\n", "mount-ro", "mount a guest disk, read-only");
107 printf ("%-20s %s\n", "mount-vfs", "mount a guest disk with mount options and vfstype");
108 printf ("%-20s %s\n", "mounts", "show mounted filesystems");
109 printf ("%-20s %s\n", "mv", "move a file");
110 printf ("%-20s %s\n", "pvcreate", "create an LVM physical volume");
111 printf ("%-20s %s\n", "pvremove", "remove an LVM physical volume");
112 printf ("%-20s %s\n", "pvs", "list the LVM physical volumes (PVs)");
113 printf ("%-20s %s\n", "pvs-full", "list the LVM physical volumes (PVs)");
114 printf ("%-20s %s\n", "read-lines", "read file as lines");
115 printf ("%-20s %s\n", "rm", "remove a file");
116 printf ("%-20s %s\n", "rm-rf", "remove a file or directory recursively");
117 printf ("%-20s %s\n", "rmdir", "remove a directory");
118 printf ("%-20s %s\n", "set-autosync", "set autosync mode");
119 printf ("%-20s %s\n", "set-e2label", "set the ext2/3/4 filesystem label");
120 printf ("%-20s %s\n", "set-e2uuid", "set the ext2/3/4 filesystem UUID");
121 printf ("%-20s %s\n", "set-path", "set the search path");
122 printf ("%-20s %s\n", "set-qemu", "set the qemu binary");
123 printf ("%-20s %s\n", "set-verbose", "set verbose mode");
124 printf ("%-20s %s\n", "sfdisk", "create partitions on a block device");
125 printf ("%-20s %s\n", "stat", "get file information");
126 printf ("%-20s %s\n", "statvfs", "get file system statistics");
127 printf ("%-20s %s\n", "sync", "sync disks, writes are flushed through to the disk image");
128 printf ("%-20s %s\n", "tar-in", "unpack tarfile to directory");
129 printf ("%-20s %s\n", "tar-out", "pack directory into tarfile");
130 printf ("%-20s %s\n", "tgz-in", "unpack compressed tarball to directory");
131 printf ("%-20s %s\n", "tgz-out", "pack directory into compressed tarball");
132 printf ("%-20s %s\n", "touch", "update file timestamps or create a new file");
133 printf ("%-20s %s\n", "tune2fs-l", "get ext2/ext3/ext4 superblock details");
134 printf ("%-20s %s\n", "umount", "unmount a filesystem");
135 printf ("%-20s %s\n", "umount-all", "unmount all filesystems");
136 printf ("%-20s %s\n", "upload", "upload a file from the local machine");
137 printf ("%-20s %s\n", "vgcreate", "create an LVM volume group");
138 printf ("%-20s %s\n", "vgremove", "remove an LVM volume group");
139 printf ("%-20s %s\n", "vgs", "list the LVM volume groups (VGs)");
140 printf ("%-20s %s\n", "vgs-full", "list the LVM volume groups (VGs)");
141 printf ("%-20s %s\n", "write-file", "create a file");
142 printf ("%-20s %s\n", "zero", "write zeroes to the device");
143 printf (" Use -h <cmd> / help <cmd> to show detailed help for a command.\n");
146 void display_command (const char *cmd)
148 if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
149 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.");
151 if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
152 pod2text ("kill-subprocess - kill the qemu subprocess", " kill-subprocess\n\nThis kills the qemu subprocess. You should never need to call this.");
154 if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
155 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.");
157 if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
158 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.");
160 if (strcasecmp (cmd, "config") == 0)
161 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.");
163 if (strcasecmp (cmd, "set_qemu") == 0 || strcasecmp (cmd, "set-qemu") == 0 || strcasecmp (cmd, "qemu") == 0)
164 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\nThe string C<qemu> is stashed in the libguestfs handle, so the caller\nmust make sure it remains valid for the lifetime of the handle.\n\nSetting C<qemu> to C<NULL> restores the default qemu binary.\n\nYou can use 'qemu' as an alias for this command.");
166 if (strcasecmp (cmd, "get_qemu") == 0 || strcasecmp (cmd, "get-qemu") == 0)
167 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.");
169 if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
170 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\nThe string C<path> is stashed in the libguestfs handle, so the caller\nmust make sure it remains valid for the lifetime of the handle.\n\nSetting C<path> to C<NULL> restores the default path.\n\nYou can use 'path' as an alias for this command.");
172 if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
173 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.");
175 if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
176 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.");
178 if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
179 pod2text ("get-autosync - get autosync mode", " get-autosync\n\nGet the autosync flag.");
181 if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
182 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.");
184 if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
185 pod2text ("get-verbose - get verbose mode", " get-verbose\n\nThis returns the verbose messages flag.");
187 if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
188 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)>.");
190 if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
191 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)>.");
193 if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
194 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)>.");
196 if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
197 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)>.");
199 if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
200 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)>.");
202 if (strcasecmp (cmd, "mount") == 0)
203 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.");
205 if (strcasecmp (cmd, "sync") == 0)
206 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.");
208 if (strcasecmp (cmd, "touch") == 0)
209 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.");
211 if (strcasecmp (cmd, "cat") == 0)
212 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.");
214 if (strcasecmp (cmd, "ll") == 0)
215 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.");
217 if (strcasecmp (cmd, "ls") == 0)
218 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.");
220 if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
221 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>");
223 if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
224 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>.");
226 if (strcasecmp (cmd, "pvs") == 0)
227 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>.");
229 if (strcasecmp (cmd, "vgs") == 0)
230 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>.");
232 if (strcasecmp (cmd, "lvs") == 0)
233 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>.");
235 if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
236 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.");
238 if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
239 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.");
241 if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
242 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.");
244 if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
245 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.");
247 if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
248 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/>.");
250 if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
251 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.");
253 if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
254 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.");
256 if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
257 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.");
259 if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
260 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.");
262 if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
263 pod2text ("aug-set - set Augeas path to value", " aug-set <path> <val>\n\nSet the value associated with C<path> to C<value>.");
265 if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
266 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]>.");
268 if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
269 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.");
271 if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
272 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.");
274 if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
275 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.");
277 if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
278 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.");
280 if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
281 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.");
283 if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
284 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.");
286 if (strcasecmp (cmd, "rm") == 0)
287 pod2text ("rm - remove a file", " rm <path>\n\nRemove the single file C<path>.");
289 if (strcasecmp (cmd, "rmdir") == 0)
290 pod2text ("rmdir - remove a directory", " rmdir <path>\n\nRemove the single directory C<path>.");
292 if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
293 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.");
295 if (strcasecmp (cmd, "mkdir") == 0)
296 pod2text ("mkdir - create a directory", " mkdir <path>\n\nCreate a directory named C<path>.");
298 if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
299 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.");
301 if (strcasecmp (cmd, "chmod") == 0)
302 pod2text ("chmod - change file mode", " chmod <mode> <path>\n\nChange the mode (permissions) of C<path> to C<mode>. Only\nnumeric modes are supported.");
304 if (strcasecmp (cmd, "chown") == 0)
305 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).");
307 if (strcasecmp (cmd, "exists") == 0)
308 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>.");
310 if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
311 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>.");
313 if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
314 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>.");
316 if (strcasecmp (cmd, "pvcreate") == 0)
317 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>.");
319 if (strcasecmp (cmd, "vgcreate") == 0)
320 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>.");
322 if (strcasecmp (cmd, "lvcreate") == 0)
323 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.");
325 if (strcasecmp (cmd, "mkfs") == 0)
326 pod2text ("mkfs - make a filesystem", " mkfs <fstype> <device>\n\nThis creates a filesystem on C<device> (usually a partition\nof LVM logical volume). The filesystem type is C<fstype>, for\nexample C<ext3>.");
328 if (strcasecmp (cmd, "sfdisk") == 0)
329 pod2text ("sfdisk - create partitions on a block device", " sfdisk <device> <cyls> <heads> <sectors> <lines>\n\nThis is a direct interface to the L<sfdisk(8)> program for creating\npartitions on block devices.\n\nC<device> should be a block device, for example C</dev/sda>.\n\nC<cyls>, C<heads> and C<sectors> are the number of cylinders, heads\nand sectors on the device, which are passed directly to sfdisk as\nthe I<-C>, I<-H> and I<-S> parameters. If you pass C<0> for any\nof these, then the corresponding parameter is omitted. Usually for\n'large' disks, you can just pass C<0> for these, but for small\n(floppy-sized) disks, sfdisk (or rather, the kernel) cannot work\nout the right geometry and you will need to tell it.\n\nC<lines> is a list of lines that we feed to C<sfdisk>. For more\ninformation refer to the L<sfdisk(8)> manpage.\n\nTo create a single partition occupying the whole disk, you would\npass C<lines> as a single element list, when the single element being\nthe string C<,> (comma).\n\nB<This command is dangerous. Without careful use you\ncan easily destroy all your data>.");
331 if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
332 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\nBecause of the message protocol, there is a transfer limit \nof somewhere between 2MB and 4MB. To transfer large files you should use\nFTP.");
334 if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
335 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.");
337 if (strcasecmp (cmd, "mounts") == 0)
338 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.");
340 if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
341 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.");
343 if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
344 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>.");
346 if (strcasecmp (cmd, "file") == 0)
347 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).");
349 if (strcasecmp (cmd, "command") == 0)
350 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 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.");
352 if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
353 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.");
355 if (strcasecmp (cmd, "stat") == 0)
356 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.");
358 if (strcasecmp (cmd, "lstat") == 0)
359 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.");
361 if (strcasecmp (cmd, "statvfs") == 0)
362 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.");
364 if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
365 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.");
367 if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
368 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.");
370 if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
371 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.");
373 if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
374 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.");
376 if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
377 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.");
379 if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
380 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.");
382 if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
383 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.");
385 if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
386 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.");
388 if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
389 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.");
391 if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
392 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.");
394 if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
395 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.");
397 if (strcasecmp (cmd, "upload") == 0)
398 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>.");
400 if (strcasecmp (cmd, "download") == 0)
401 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>.");
403 if (strcasecmp (cmd, "checksum") == 0)
404 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.");
406 if (strcasecmp (cmd, "tar_in") == 0 || strcasecmp (cmd, "tar-in") == 0)
407 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>.");
409 if (strcasecmp (cmd, "tar_out") == 0 || strcasecmp (cmd, "tar-out") == 0)
410 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>.");
412 if (strcasecmp (cmd, "tgz_in") == 0 || strcasecmp (cmd, "tgz-in") == 0)
413 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>.");
415 if (strcasecmp (cmd, "tgz_out") == 0 || strcasecmp (cmd, "tgz-out") == 0)
416 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>.");
418 if (strcasecmp (cmd, "mount_ro") == 0 || strcasecmp (cmd, "mount-ro") == 0)
419 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.");
421 if (strcasecmp (cmd, "mount_options") == 0 || strcasecmp (cmd, "mount-options") == 0)
422 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.");
424 if (strcasecmp (cmd, "mount_vfs") == 0 || strcasecmp (cmd, "mount-vfs") == 0)
425 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.");
427 if (strcasecmp (cmd, "debug") == 0)
428 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.");
430 if (strcasecmp (cmd, "lvremove") == 0)
431 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>.");
433 if (strcasecmp (cmd, "vgremove") == 0)
434 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).");
436 if (strcasecmp (cmd, "pvremove") == 0)
437 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.");
439 if (strcasecmp (cmd, "set_e2label") == 0 || strcasecmp (cmd, "set-e2label") == 0)
440 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.");
442 if (strcasecmp (cmd, "get_e2label") == 0 || strcasecmp (cmd, "get-e2label") == 0)
443 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>.");
445 if (strcasecmp (cmd, "set_e2uuid") == 0 || strcasecmp (cmd, "set-e2uuid") == 0)
446 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.");
448 if (strcasecmp (cmd, "get_e2uuid") == 0 || strcasecmp (cmd, "get-e2uuid") == 0)
449 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>.");
451 if (strcasecmp (cmd, "fsck") == 0)
452 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>.");
454 if (strcasecmp (cmd, "zero") == 0)
455 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.");
457 if (strcasecmp (cmd, "grub_install") == 0 || strcasecmp (cmd, "grub-install") == 0)
458 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>.");
460 if (strcasecmp (cmd, "cp") == 0)
461 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.");
463 if (strcasecmp (cmd, "cp_a") == 0 || strcasecmp (cmd, "cp-a") == 0)
464 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.");
466 if (strcasecmp (cmd, "mv") == 0)
467 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.");
469 if (strcasecmp (cmd, "drop_caches") == 0 || strcasecmp (cmd, "drop-caches") == 0)
470 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.");
472 if (strcasecmp (cmd, "dmesg") == 0)
473 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.");
475 display_builtin_command (cmd);
478 static void print_pv (struct guestfs_lvm_pv *pv)
482 printf ("pv_name: %s\n", pv->pv_name);
483 printf ("pv_uuid: ");
484 for (i = 0; i < 32; ++i)
485 printf ("%c", pv->pv_uuid[i]);
487 printf ("pv_fmt: %s\n", pv->pv_fmt);
488 printf ("pv_size: %" PRIu64 "\n", pv->pv_size);
489 printf ("dev_size: %" PRIu64 "\n", pv->dev_size);
490 printf ("pv_free: %" PRIu64 "\n", pv->pv_free);
491 printf ("pv_used: %" PRIu64 "\n", pv->pv_used);
492 printf ("pv_attr: %s\n", pv->pv_attr);
493 printf ("pv_pe_count: %" PRIi64 "\n", pv->pv_pe_count);
494 printf ("pv_pe_alloc_count: %" PRIi64 "\n", pv->pv_pe_alloc_count);
495 printf ("pv_tags: %s\n", pv->pv_tags);
496 printf ("pe_start: %" PRIu64 "\n", pv->pe_start);
497 printf ("pv_mda_count: %" PRIi64 "\n", pv->pv_mda_count);
498 printf ("pv_mda_free: %" PRIu64 "\n", pv->pv_mda_free);
501 static void print_pv_list (struct guestfs_lvm_pv_list *pvs)
505 for (i = 0; i < pvs->len; ++i)
506 print_pv (&pvs->val[i]);
509 static void print_vg (struct guestfs_lvm_vg *vg)
513 printf ("vg_name: %s\n", vg->vg_name);
514 printf ("vg_uuid: ");
515 for (i = 0; i < 32; ++i)
516 printf ("%c", vg->vg_uuid[i]);
518 printf ("vg_fmt: %s\n", vg->vg_fmt);
519 printf ("vg_attr: %s\n", vg->vg_attr);
520 printf ("vg_size: %" PRIu64 "\n", vg->vg_size);
521 printf ("vg_free: %" PRIu64 "\n", vg->vg_free);
522 printf ("vg_sysid: %s\n", vg->vg_sysid);
523 printf ("vg_extent_size: %" PRIu64 "\n", vg->vg_extent_size);
524 printf ("vg_extent_count: %" PRIi64 "\n", vg->vg_extent_count);
525 printf ("vg_free_count: %" PRIi64 "\n", vg->vg_free_count);
526 printf ("max_lv: %" PRIi64 "\n", vg->max_lv);
527 printf ("max_pv: %" PRIi64 "\n", vg->max_pv);
528 printf ("pv_count: %" PRIi64 "\n", vg->pv_count);
529 printf ("lv_count: %" PRIi64 "\n", vg->lv_count);
530 printf ("snap_count: %" PRIi64 "\n", vg->snap_count);
531 printf ("vg_seqno: %" PRIi64 "\n", vg->vg_seqno);
532 printf ("vg_tags: %s\n", vg->vg_tags);
533 printf ("vg_mda_count: %" PRIi64 "\n", vg->vg_mda_count);
534 printf ("vg_mda_free: %" PRIu64 "\n", vg->vg_mda_free);
537 static void print_vg_list (struct guestfs_lvm_vg_list *vgs)
541 for (i = 0; i < vgs->len; ++i)
542 print_vg (&vgs->val[i]);
545 static void print_lv (struct guestfs_lvm_lv *lv)
549 printf ("lv_name: %s\n", lv->lv_name);
550 printf ("lv_uuid: ");
551 for (i = 0; i < 32; ++i)
552 printf ("%c", lv->lv_uuid[i]);
554 printf ("lv_attr: %s\n", lv->lv_attr);
555 printf ("lv_major: %" PRIi64 "\n", lv->lv_major);
556 printf ("lv_minor: %" PRIi64 "\n", lv->lv_minor);
557 printf ("lv_kernel_major: %" PRIi64 "\n", lv->lv_kernel_major);
558 printf ("lv_kernel_minor: %" PRIi64 "\n", lv->lv_kernel_minor);
559 printf ("lv_size: %" PRIu64 "\n", lv->lv_size);
560 printf ("seg_count: %" PRIi64 "\n", lv->seg_count);
561 printf ("origin: %s\n", lv->origin);
562 if (lv->snap_percent >= 0) printf ("snap_percent: %g %%\n", lv->snap_percent);
563 else printf ("snap_percent: \n");
564 if (lv->copy_percent >= 0) printf ("copy_percent: %g %%\n", lv->copy_percent);
565 else printf ("copy_percent: \n");
566 printf ("move_pv: %s\n", lv->move_pv);
567 printf ("lv_tags: %s\n", lv->lv_tags);
568 printf ("mirror_log: %s\n", lv->mirror_log);
569 printf ("modules: %s\n", lv->modules);
572 static void print_lv_list (struct guestfs_lvm_lv_list *lvs)
576 for (i = 0; i < lvs->len; ++i)
577 print_lv (&lvs->val[i]);
580 static void print_stat (struct guestfs_stat *stat)
582 printf ("dev: %" PRIi64 "\n", stat->dev);
583 printf ("ino: %" PRIi64 "\n", stat->ino);
584 printf ("mode: %" PRIi64 "\n", stat->mode);
585 printf ("nlink: %" PRIi64 "\n", stat->nlink);
586 printf ("uid: %" PRIi64 "\n", stat->uid);
587 printf ("gid: %" PRIi64 "\n", stat->gid);
588 printf ("rdev: %" PRIi64 "\n", stat->rdev);
589 printf ("size: %" PRIi64 "\n", stat->size);
590 printf ("blksize: %" PRIi64 "\n", stat->blksize);
591 printf ("blocks: %" PRIi64 "\n", stat->blocks);
592 printf ("atime: %" PRIi64 "\n", stat->atime);
593 printf ("mtime: %" PRIi64 "\n", stat->mtime);
594 printf ("ctime: %" PRIi64 "\n", stat->ctime);
597 static void print_statvfs (struct guestfs_statvfs *statvfs)
599 printf ("bsize: %" PRIi64 "\n", statvfs->bsize);
600 printf ("frsize: %" PRIi64 "\n", statvfs->frsize);
601 printf ("blocks: %" PRIi64 "\n", statvfs->blocks);
602 printf ("bfree: %" PRIi64 "\n", statvfs->bfree);
603 printf ("bavail: %" PRIi64 "\n", statvfs->bavail);
604 printf ("files: %" PRIi64 "\n", statvfs->files);
605 printf ("ffree: %" PRIi64 "\n", statvfs->ffree);
606 printf ("favail: %" PRIi64 "\n", statvfs->favail);
607 printf ("fsid: %" PRIi64 "\n", statvfs->fsid);
608 printf ("flag: %" PRIi64 "\n", statvfs->flag);
609 printf ("namemax: %" PRIi64 "\n", statvfs->namemax);
612 static int run_launch (const char *cmd, int argc, char *argv[])
616 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
617 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
624 static int run_kill_subprocess (const char *cmd, int argc, char *argv[])
628 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
629 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
632 r = guestfs_kill_subprocess (g);
636 static int run_add_drive (const char *cmd, int argc, char *argv[])
639 const char *filename;
641 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
642 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
646 r = guestfs_add_drive (g, filename);
650 static int run_add_cdrom (const char *cmd, int argc, char *argv[])
653 const char *filename;
655 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
656 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
660 r = guestfs_add_cdrom (g, filename);
664 static int run_config (const char *cmd, int argc, char *argv[])
667 const char *qemuparam;
668 const char *qemuvalue;
670 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
671 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
675 qemuvalue = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
676 r = guestfs_config (g, qemuparam, qemuvalue);
680 static int run_set_qemu (const char *cmd, int argc, char *argv[])
685 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
686 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
690 r = guestfs_set_qemu (g, qemu);
694 static int run_get_qemu (const char *cmd, int argc, char *argv[])
698 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
699 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
702 r = guestfs_get_qemu (g);
703 if (r == NULL) return -1;
708 static int run_set_path (const char *cmd, int argc, char *argv[])
713 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
714 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
718 r = guestfs_set_path (g, path);
722 static int run_get_path (const char *cmd, int argc, char *argv[])
726 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
727 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
730 r = guestfs_get_path (g);
731 if (r == NULL) return -1;
736 static int run_set_autosync (const char *cmd, int argc, char *argv[])
741 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
742 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
745 autosync = is_true (argv[0]) ? 1 : 0;
746 r = guestfs_set_autosync (g, autosync);
750 static int run_get_autosync (const char *cmd, int argc, char *argv[])
754 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
755 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
758 r = guestfs_get_autosync (g);
759 if (r == -1) return -1;
760 if (r) printf ("true\n"); else printf ("false\n");
764 static int run_set_verbose (const char *cmd, int argc, char *argv[])
769 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
770 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
773 verbose = is_true (argv[0]) ? 1 : 0;
774 r = guestfs_set_verbose (g, verbose);
778 static int run_get_verbose (const char *cmd, int argc, char *argv[])
782 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
783 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
786 r = guestfs_get_verbose (g);
787 if (r == -1) return -1;
788 if (r) printf ("true\n"); else printf ("false\n");
792 static int run_is_ready (const char *cmd, int argc, char *argv[])
796 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
797 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
800 r = guestfs_is_ready (g);
801 if (r == -1) return -1;
802 if (r) printf ("true\n"); else printf ("false\n");
806 static int run_is_config (const char *cmd, int argc, char *argv[])
810 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
811 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
814 r = guestfs_is_config (g);
815 if (r == -1) return -1;
816 if (r) printf ("true\n"); else printf ("false\n");
820 static int run_is_launching (const char *cmd, int argc, char *argv[])
824 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
825 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
828 r = guestfs_is_launching (g);
829 if (r == -1) return -1;
830 if (r) printf ("true\n"); else printf ("false\n");
834 static int run_is_busy (const char *cmd, int argc, char *argv[])
838 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
839 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
842 r = guestfs_is_busy (g);
843 if (r == -1) return -1;
844 if (r) printf ("true\n"); else printf ("false\n");
848 static int run_get_state (const char *cmd, int argc, char *argv[])
852 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
853 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
856 r = guestfs_get_state (g);
857 if (r == -1) return -1;
862 static int run_mount (const char *cmd, int argc, char *argv[])
866 const char *mountpoint;
868 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
869 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
873 mountpoint = argv[1];
874 r = guestfs_mount (g, device, mountpoint);
878 static int run_sync (const char *cmd, int argc, char *argv[])
882 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
883 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
886 r = guestfs_sync (g);
890 static int run_touch (const char *cmd, int argc, char *argv[])
895 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
896 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
900 r = guestfs_touch (g, path);
904 static int run_cat (const char *cmd, int argc, char *argv[])
909 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
910 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
914 r = guestfs_cat (g, path);
915 if (r == NULL) return -1;
921 static int run_ll (const char *cmd, int argc, char *argv[])
924 const char *directory;
926 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
927 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
931 r = guestfs_ll (g, directory);
932 if (r == NULL) return -1;
938 static int run_ls (const char *cmd, int argc, char *argv[])
941 const char *directory;
943 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
944 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
948 r = guestfs_ls (g, directory);
949 if (r == NULL) return -1;
955 static int run_list_devices (const char *cmd, int argc, char *argv[])
959 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
960 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
963 r = guestfs_list_devices (g);
964 if (r == NULL) return -1;
970 static int run_list_partitions (const char *cmd, int argc, char *argv[])
974 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
975 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
978 r = guestfs_list_partitions (g);
979 if (r == NULL) return -1;
985 static int run_pvs (const char *cmd, int argc, char *argv[])
989 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
990 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
994 if (r == NULL) return -1;
1000 static int run_vgs (const char *cmd, int argc, char *argv[])
1004 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1005 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1008 r = guestfs_vgs (g);
1009 if (r == NULL) return -1;
1015 static int run_lvs (const char *cmd, int argc, char *argv[])
1019 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1020 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1023 r = guestfs_lvs (g);
1024 if (r == NULL) return -1;
1030 static int run_pvs_full (const char *cmd, int argc, char *argv[])
1032 struct guestfs_lvm_pv_list *r;
1034 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1035 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1038 r = guestfs_pvs_full (g);
1039 if (r == NULL) return -1;
1041 guestfs_free_lvm_pv_list (r);
1045 static int run_vgs_full (const char *cmd, int argc, char *argv[])
1047 struct guestfs_lvm_vg_list *r;
1049 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1050 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1053 r = guestfs_vgs_full (g);
1054 if (r == NULL) return -1;
1056 guestfs_free_lvm_vg_list (r);
1060 static int run_lvs_full (const char *cmd, int argc, char *argv[])
1062 struct guestfs_lvm_lv_list *r;
1064 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1065 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1068 r = guestfs_lvs_full (g);
1069 if (r == NULL) return -1;
1071 guestfs_free_lvm_lv_list (r);
1075 static int run_read_lines (const char *cmd, int argc, char *argv[])
1080 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1081 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1085 r = guestfs_read_lines (g, path);
1086 if (r == NULL) return -1;
1092 static int run_aug_init (const char *cmd, int argc, char *argv[])
1098 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1099 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1103 flags = atoi (argv[1]);
1104 r = guestfs_aug_init (g, root, flags);
1108 static int run_aug_close (const char *cmd, int argc, char *argv[])
1112 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1113 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1116 r = guestfs_aug_close (g);
1120 static int run_aug_defvar (const char *cmd, int argc, char *argv[])
1126 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1127 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1131 expr = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
1132 r = guestfs_aug_defvar (g, name, expr);
1133 if (r == -1) return -1;
1138 static int run_aug_defnode (const char *cmd, int argc, char *argv[])
1140 struct guestfs_int_bool *r;
1145 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1146 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1152 r = guestfs_aug_defnode (g, name, expr, val);
1153 if (r == NULL) return -1;
1154 printf ("%d, %s\n", r->i,
1155 r->b ? "true" : "false");
1156 guestfs_free_int_bool (r);
1160 static int run_aug_get (const char *cmd, int argc, char *argv[])
1165 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1166 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1170 r = guestfs_aug_get (g, path);
1171 if (r == NULL) return -1;
1177 static int run_aug_set (const char *cmd, int argc, char *argv[])
1183 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1184 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1189 r = guestfs_aug_set (g, path, val);
1193 static int run_aug_insert (const char *cmd, int argc, char *argv[])
1200 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1201 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1206 before = is_true (argv[2]) ? 1 : 0;
1207 r = guestfs_aug_insert (g, path, label, before);
1211 static int run_aug_rm (const char *cmd, int argc, char *argv[])
1216 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1217 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1221 r = guestfs_aug_rm (g, path);
1222 if (r == -1) return -1;
1227 static int run_aug_mv (const char *cmd, int argc, char *argv[])
1233 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1234 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1239 r = guestfs_aug_mv (g, src, dest);
1243 static int run_aug_match (const char *cmd, int argc, char *argv[])
1248 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1249 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1253 r = guestfs_aug_match (g, path);
1254 if (r == NULL) return -1;
1260 static int run_aug_save (const char *cmd, int argc, char *argv[])
1264 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1265 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1268 r = guestfs_aug_save (g);
1272 static int run_aug_load (const char *cmd, int argc, char *argv[])
1276 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1277 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1280 r = guestfs_aug_load (g);
1284 static int run_aug_ls (const char *cmd, int argc, char *argv[])
1289 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1290 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1294 r = guestfs_aug_ls (g, path);
1295 if (r == NULL) return -1;
1301 static int run_rm (const char *cmd, int argc, char *argv[])
1306 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1307 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1311 r = guestfs_rm (g, path);
1315 static int run_rmdir (const char *cmd, int argc, char *argv[])
1320 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1321 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1325 r = guestfs_rmdir (g, path);
1329 static int run_rm_rf (const char *cmd, int argc, char *argv[])
1334 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1335 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1339 r = guestfs_rm_rf (g, path);
1343 static int run_mkdir (const char *cmd, int argc, char *argv[])
1348 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1349 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1353 r = guestfs_mkdir (g, path);
1357 static int run_mkdir_p (const char *cmd, int argc, char *argv[])
1362 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1363 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1367 r = guestfs_mkdir_p (g, path);
1371 static int run_chmod (const char *cmd, int argc, char *argv[])
1377 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1378 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1381 mode = atoi (argv[0]);
1383 r = guestfs_chmod (g, mode, path);
1387 static int run_chown (const char *cmd, int argc, char *argv[])
1394 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1395 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1398 owner = atoi (argv[0]);
1399 group = atoi (argv[1]);
1401 r = guestfs_chown (g, owner, group, path);
1405 static int run_exists (const char *cmd, int argc, char *argv[])
1410 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1411 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1415 r = guestfs_exists (g, path);
1416 if (r == -1) return -1;
1417 if (r) printf ("true\n"); else printf ("false\n");
1421 static int run_is_file (const char *cmd, int argc, char *argv[])
1426 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1427 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1431 r = guestfs_is_file (g, path);
1432 if (r == -1) return -1;
1433 if (r) printf ("true\n"); else printf ("false\n");
1437 static int run_is_dir (const char *cmd, int argc, char *argv[])
1442 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1443 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1447 r = guestfs_is_dir (g, path);
1448 if (r == -1) return -1;
1449 if (r) printf ("true\n"); else printf ("false\n");
1453 static int run_pvcreate (const char *cmd, int argc, char *argv[])
1458 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1459 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1463 r = guestfs_pvcreate (g, device);
1467 static int run_vgcreate (const char *cmd, int argc, char *argv[])
1470 const char *volgroup;
1473 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1474 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1478 physvols = parse_string_list (argv[1]);
1479 r = guestfs_vgcreate (g, volgroup, physvols);
1483 static int run_lvcreate (const char *cmd, int argc, char *argv[])
1487 const char *volgroup;
1490 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1491 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1496 mbytes = atoi (argv[2]);
1497 r = guestfs_lvcreate (g, logvol, volgroup, mbytes);
1501 static int run_mkfs (const char *cmd, int argc, char *argv[])
1507 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1508 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1513 r = guestfs_mkfs (g, fstype, device);
1517 static int run_sfdisk (const char *cmd, int argc, char *argv[])
1526 fprintf (stderr, "%s should have 5 parameter(s)\n", cmd);
1527 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1531 cyls = atoi (argv[1]);
1532 heads = atoi (argv[2]);
1533 sectors = atoi (argv[3]);
1534 lines = parse_string_list (argv[4]);
1535 r = guestfs_sfdisk (g, device, cyls, heads, sectors, lines);
1539 static int run_write_file (const char *cmd, int argc, char *argv[])
1543 const char *content;
1546 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1547 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1552 size = atoi (argv[2]);
1553 r = guestfs_write_file (g, path, content, size);
1557 static int run_umount (const char *cmd, int argc, char *argv[])
1560 const char *pathordevice;
1562 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1563 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1566 pathordevice = argv[0];
1567 r = guestfs_umount (g, pathordevice);
1571 static int run_mounts (const char *cmd, int argc, char *argv[])
1575 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1576 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1579 r = guestfs_mounts (g);
1580 if (r == NULL) return -1;
1586 static int run_umount_all (const char *cmd, int argc, char *argv[])
1590 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1591 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1594 r = guestfs_umount_all (g);
1598 static int run_lvm_remove_all (const char *cmd, int argc, char *argv[])
1602 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1603 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1606 r = guestfs_lvm_remove_all (g);
1610 static int run_file (const char *cmd, int argc, char *argv[])
1615 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1616 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1620 r = guestfs_file (g, path);
1621 if (r == NULL) return -1;
1627 static int run_command (const char *cmd, int argc, char *argv[])
1632 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1633 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1636 arguments = parse_string_list (argv[0]);
1637 r = guestfs_command (g, arguments);
1638 if (r == NULL) return -1;
1644 static int run_command_lines (const char *cmd, int argc, char *argv[])
1649 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1650 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1653 arguments = parse_string_list (argv[0]);
1654 r = guestfs_command_lines (g, arguments);
1655 if (r == NULL) return -1;
1661 static int run_stat (const char *cmd, int argc, char *argv[])
1663 struct guestfs_stat *r;
1666 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1667 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1671 r = guestfs_stat (g, path);
1672 if (r == NULL) return -1;
1678 static int run_lstat (const char *cmd, int argc, char *argv[])
1680 struct guestfs_stat *r;
1683 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1684 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1688 r = guestfs_lstat (g, path);
1689 if (r == NULL) return -1;
1695 static int run_statvfs (const char *cmd, int argc, char *argv[])
1697 struct guestfs_statvfs *r;
1700 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1701 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1705 r = guestfs_statvfs (g, path);
1706 if (r == NULL) return -1;
1712 static int run_tune2fs_l (const char *cmd, int argc, char *argv[])
1717 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1718 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1722 r = guestfs_tune2fs_l (g, device);
1723 if (r == NULL) return -1;
1729 static int run_blockdev_setro (const char *cmd, int argc, char *argv[])
1734 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1735 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1739 r = guestfs_blockdev_setro (g, device);
1743 static int run_blockdev_setrw (const char *cmd, int argc, char *argv[])
1748 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1749 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1753 r = guestfs_blockdev_setrw (g, device);
1757 static int run_blockdev_getro (const char *cmd, int argc, char *argv[])
1762 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1763 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1767 r = guestfs_blockdev_getro (g, device);
1768 if (r == -1) return -1;
1769 if (r) printf ("true\n"); else printf ("false\n");
1773 static int run_blockdev_getss (const char *cmd, int argc, char *argv[])
1778 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1779 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1783 r = guestfs_blockdev_getss (g, device);
1784 if (r == -1) return -1;
1789 static int run_blockdev_getbsz (const char *cmd, int argc, char *argv[])
1794 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1795 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1799 r = guestfs_blockdev_getbsz (g, device);
1800 if (r == -1) return -1;
1805 static int run_blockdev_setbsz (const char *cmd, int argc, char *argv[])
1811 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1812 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1816 blocksize = atoi (argv[1]);
1817 r = guestfs_blockdev_setbsz (g, device, blocksize);
1821 static int run_blockdev_getsz (const char *cmd, int argc, char *argv[])
1826 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1827 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1831 r = guestfs_blockdev_getsz (g, device);
1832 if (r == -1) return -1;
1833 printf ("%" PRIi64 "\n", r);
1837 static int run_blockdev_getsize64 (const char *cmd, int argc, char *argv[])
1842 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1843 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1847 r = guestfs_blockdev_getsize64 (g, device);
1848 if (r == -1) return -1;
1849 printf ("%" PRIi64 "\n", r);
1853 static int run_blockdev_flushbufs (const char *cmd, int argc, char *argv[])
1858 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1859 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1863 r = guestfs_blockdev_flushbufs (g, device);
1867 static int run_blockdev_rereadpt (const char *cmd, int argc, char *argv[])
1872 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1873 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1877 r = guestfs_blockdev_rereadpt (g, device);
1881 static int run_upload (const char *cmd, int argc, char *argv[])
1884 const char *filename;
1885 const char *remotefilename;
1887 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1888 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1891 filename = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
1892 remotefilename = argv[1];
1893 r = guestfs_upload (g, filename, remotefilename);
1897 static int run_download (const char *cmd, int argc, char *argv[])
1900 const char *remotefilename;
1901 const char *filename;
1903 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1904 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1907 remotefilename = argv[0];
1908 filename = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
1909 r = guestfs_download (g, remotefilename, filename);
1913 static int run_checksum (const char *cmd, int argc, char *argv[])
1916 const char *csumtype;
1919 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1920 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1925 r = guestfs_checksum (g, csumtype, path);
1926 if (r == NULL) return -1;
1932 static int run_tar_in (const char *cmd, int argc, char *argv[])
1935 const char *tarfile;
1936 const char *directory;
1938 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1939 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1942 tarfile = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
1943 directory = argv[1];
1944 r = guestfs_tar_in (g, tarfile, directory);
1948 static int run_tar_out (const char *cmd, int argc, char *argv[])
1951 const char *directory;
1952 const char *tarfile;
1954 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1955 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1958 directory = argv[0];
1959 tarfile = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
1960 r = guestfs_tar_out (g, directory, tarfile);
1964 static int run_tgz_in (const char *cmd, int argc, char *argv[])
1967 const char *tarball;
1968 const char *directory;
1970 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1971 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1974 tarball = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
1975 directory = argv[1];
1976 r = guestfs_tgz_in (g, tarball, directory);
1980 static int run_tgz_out (const char *cmd, int argc, char *argv[])
1983 const char *directory;
1984 const char *tarball;
1986 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1987 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1990 directory = argv[0];
1991 tarball = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
1992 r = guestfs_tgz_out (g, directory, tarball);
1996 static int run_mount_ro (const char *cmd, int argc, char *argv[])
2000 const char *mountpoint;
2002 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2003 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2007 mountpoint = argv[1];
2008 r = guestfs_mount_ro (g, device, mountpoint);
2012 static int run_mount_options (const char *cmd, int argc, char *argv[])
2015 const char *options;
2017 const char *mountpoint;
2019 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
2020 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2025 mountpoint = argv[2];
2026 r = guestfs_mount_options (g, options, device, mountpoint);
2030 static int run_mount_vfs (const char *cmd, int argc, char *argv[])
2033 const char *options;
2034 const char *vfstype;
2036 const char *mountpoint;
2038 fprintf (stderr, "%s should have 4 parameter(s)\n", cmd);
2039 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2045 mountpoint = argv[3];
2046 r = guestfs_mount_vfs (g, options, vfstype, device, mountpoint);
2050 static int run_debug (const char *cmd, int argc, char *argv[])
2056 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2057 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2061 extraargs = parse_string_list (argv[1]);
2062 r = guestfs_debug (g, subcmd, extraargs);
2063 if (r == NULL) return -1;
2069 static int run_lvremove (const char *cmd, int argc, char *argv[])
2074 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2075 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2079 r = guestfs_lvremove (g, device);
2083 static int run_vgremove (const char *cmd, int argc, char *argv[])
2088 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2089 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2093 r = guestfs_vgremove (g, vgname);
2097 static int run_pvremove (const char *cmd, int argc, char *argv[])
2102 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2103 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2107 r = guestfs_pvremove (g, device);
2111 static int run_set_e2label (const char *cmd, int argc, char *argv[])
2117 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2118 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2123 r = guestfs_set_e2label (g, device, label);
2127 static int run_get_e2label (const char *cmd, int argc, char *argv[])
2132 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2133 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2137 r = guestfs_get_e2label (g, device);
2138 if (r == NULL) return -1;
2144 static int run_set_e2uuid (const char *cmd, int argc, char *argv[])
2150 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2151 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2156 r = guestfs_set_e2uuid (g, device, uuid);
2160 static int run_get_e2uuid (const char *cmd, int argc, char *argv[])
2165 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2166 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2170 r = guestfs_get_e2uuid (g, device);
2171 if (r == NULL) return -1;
2177 static int run_fsck (const char *cmd, int argc, char *argv[])
2183 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2184 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2189 r = guestfs_fsck (g, fstype, device);
2190 if (r == -1) return -1;
2195 static int run_zero (const char *cmd, int argc, char *argv[])
2200 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2201 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2205 r = guestfs_zero (g, device);
2209 static int run_grub_install (const char *cmd, int argc, char *argv[])
2215 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2216 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2221 r = guestfs_grub_install (g, root, device);
2225 static int run_cp (const char *cmd, int argc, char *argv[])
2231 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2232 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2237 r = guestfs_cp (g, src, dest);
2241 static int run_cp_a (const char *cmd, int argc, char *argv[])
2247 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2248 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2253 r = guestfs_cp_a (g, src, dest);
2257 static int run_mv (const char *cmd, int argc, char *argv[])
2263 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
2264 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2269 r = guestfs_mv (g, src, dest);
2273 static int run_drop_caches (const char *cmd, int argc, char *argv[])
2278 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
2279 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2282 whattodrop = atoi (argv[0]);
2283 r = guestfs_drop_caches (g, whattodrop);
2287 static int run_dmesg (const char *cmd, int argc, char *argv[])
2291 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
2292 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
2295 r = guestfs_dmesg (g);
2296 if (r == NULL) return -1;
2302 int run_action (const char *cmd, int argc, char *argv[])
2304 if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
2305 return run_launch (cmd, argc, argv);
2307 if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
2308 return run_kill_subprocess (cmd, argc, argv);
2310 if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
2311 return run_add_drive (cmd, argc, argv);
2313 if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
2314 return run_add_cdrom (cmd, argc, argv);
2316 if (strcasecmp (cmd, "config") == 0)
2317 return run_config (cmd, argc, argv);
2319 if (strcasecmp (cmd, "set_qemu") == 0 || strcasecmp (cmd, "set-qemu") == 0 || strcasecmp (cmd, "qemu") == 0)
2320 return run_set_qemu (cmd, argc, argv);
2322 if (strcasecmp (cmd, "get_qemu") == 0 || strcasecmp (cmd, "get-qemu") == 0)
2323 return run_get_qemu (cmd, argc, argv);
2325 if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
2326 return run_set_path (cmd, argc, argv);
2328 if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
2329 return run_get_path (cmd, argc, argv);
2331 if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
2332 return run_set_autosync (cmd, argc, argv);
2334 if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
2335 return run_get_autosync (cmd, argc, argv);
2337 if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
2338 return run_set_verbose (cmd, argc, argv);
2340 if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
2341 return run_get_verbose (cmd, argc, argv);
2343 if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
2344 return run_is_ready (cmd, argc, argv);
2346 if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
2347 return run_is_config (cmd, argc, argv);
2349 if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
2350 return run_is_launching (cmd, argc, argv);
2352 if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
2353 return run_is_busy (cmd, argc, argv);
2355 if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
2356 return run_get_state (cmd, argc, argv);
2358 if (strcasecmp (cmd, "mount") == 0)
2359 return run_mount (cmd, argc, argv);
2361 if (strcasecmp (cmd, "sync") == 0)
2362 return run_sync (cmd, argc, argv);
2364 if (strcasecmp (cmd, "touch") == 0)
2365 return run_touch (cmd, argc, argv);
2367 if (strcasecmp (cmd, "cat") == 0)
2368 return run_cat (cmd, argc, argv);
2370 if (strcasecmp (cmd, "ll") == 0)
2371 return run_ll (cmd, argc, argv);
2373 if (strcasecmp (cmd, "ls") == 0)
2374 return run_ls (cmd, argc, argv);
2376 if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
2377 return run_list_devices (cmd, argc, argv);
2379 if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
2380 return run_list_partitions (cmd, argc, argv);
2382 if (strcasecmp (cmd, "pvs") == 0)
2383 return run_pvs (cmd, argc, argv);
2385 if (strcasecmp (cmd, "vgs") == 0)
2386 return run_vgs (cmd, argc, argv);
2388 if (strcasecmp (cmd, "lvs") == 0)
2389 return run_lvs (cmd, argc, argv);
2391 if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
2392 return run_pvs_full (cmd, argc, argv);
2394 if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
2395 return run_vgs_full (cmd, argc, argv);
2397 if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
2398 return run_lvs_full (cmd, argc, argv);
2400 if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
2401 return run_read_lines (cmd, argc, argv);
2403 if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
2404 return run_aug_init (cmd, argc, argv);
2406 if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
2407 return run_aug_close (cmd, argc, argv);
2409 if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
2410 return run_aug_defvar (cmd, argc, argv);
2412 if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
2413 return run_aug_defnode (cmd, argc, argv);
2415 if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
2416 return run_aug_get (cmd, argc, argv);
2418 if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
2419 return run_aug_set (cmd, argc, argv);
2421 if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
2422 return run_aug_insert (cmd, argc, argv);
2424 if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
2425 return run_aug_rm (cmd, argc, argv);
2427 if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
2428 return run_aug_mv (cmd, argc, argv);
2430 if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
2431 return run_aug_match (cmd, argc, argv);
2433 if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
2434 return run_aug_save (cmd, argc, argv);
2436 if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
2437 return run_aug_load (cmd, argc, argv);
2439 if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
2440 return run_aug_ls (cmd, argc, argv);
2442 if (strcasecmp (cmd, "rm") == 0)
2443 return run_rm (cmd, argc, argv);
2445 if (strcasecmp (cmd, "rmdir") == 0)
2446 return run_rmdir (cmd, argc, argv);
2448 if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
2449 return run_rm_rf (cmd, argc, argv);
2451 if (strcasecmp (cmd, "mkdir") == 0)
2452 return run_mkdir (cmd, argc, argv);
2454 if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
2455 return run_mkdir_p (cmd, argc, argv);
2457 if (strcasecmp (cmd, "chmod") == 0)
2458 return run_chmod (cmd, argc, argv);
2460 if (strcasecmp (cmd, "chown") == 0)
2461 return run_chown (cmd, argc, argv);
2463 if (strcasecmp (cmd, "exists") == 0)
2464 return run_exists (cmd, argc, argv);
2466 if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
2467 return run_is_file (cmd, argc, argv);
2469 if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
2470 return run_is_dir (cmd, argc, argv);
2472 if (strcasecmp (cmd, "pvcreate") == 0)
2473 return run_pvcreate (cmd, argc, argv);
2475 if (strcasecmp (cmd, "vgcreate") == 0)
2476 return run_vgcreate (cmd, argc, argv);
2478 if (strcasecmp (cmd, "lvcreate") == 0)
2479 return run_lvcreate (cmd, argc, argv);
2481 if (strcasecmp (cmd, "mkfs") == 0)
2482 return run_mkfs (cmd, argc, argv);
2484 if (strcasecmp (cmd, "sfdisk") == 0)
2485 return run_sfdisk (cmd, argc, argv);
2487 if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
2488 return run_write_file (cmd, argc, argv);
2490 if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
2491 return run_umount (cmd, argc, argv);
2493 if (strcasecmp (cmd, "mounts") == 0)
2494 return run_mounts (cmd, argc, argv);
2496 if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
2497 return run_umount_all (cmd, argc, argv);
2499 if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
2500 return run_lvm_remove_all (cmd, argc, argv);
2502 if (strcasecmp (cmd, "file") == 0)
2503 return run_file (cmd, argc, argv);
2505 if (strcasecmp (cmd, "command") == 0)
2506 return run_command (cmd, argc, argv);
2508 if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
2509 return run_command_lines (cmd, argc, argv);
2511 if (strcasecmp (cmd, "stat") == 0)
2512 return run_stat (cmd, argc, argv);
2514 if (strcasecmp (cmd, "lstat") == 0)
2515 return run_lstat (cmd, argc, argv);
2517 if (strcasecmp (cmd, "statvfs") == 0)
2518 return run_statvfs (cmd, argc, argv);
2520 if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
2521 return run_tune2fs_l (cmd, argc, argv);
2523 if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
2524 return run_blockdev_setro (cmd, argc, argv);
2526 if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
2527 return run_blockdev_setrw (cmd, argc, argv);
2529 if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
2530 return run_blockdev_getro (cmd, argc, argv);
2532 if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
2533 return run_blockdev_getss (cmd, argc, argv);
2535 if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
2536 return run_blockdev_getbsz (cmd, argc, argv);
2538 if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
2539 return run_blockdev_setbsz (cmd, argc, argv);
2541 if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
2542 return run_blockdev_getsz (cmd, argc, argv);
2544 if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
2545 return run_blockdev_getsize64 (cmd, argc, argv);
2547 if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
2548 return run_blockdev_flushbufs (cmd, argc, argv);
2550 if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
2551 return run_blockdev_rereadpt (cmd, argc, argv);
2553 if (strcasecmp (cmd, "upload") == 0)
2554 return run_upload (cmd, argc, argv);
2556 if (strcasecmp (cmd, "download") == 0)
2557 return run_download (cmd, argc, argv);
2559 if (strcasecmp (cmd, "checksum") == 0)
2560 return run_checksum (cmd, argc, argv);
2562 if (strcasecmp (cmd, "tar_in") == 0 || strcasecmp (cmd, "tar-in") == 0)
2563 return run_tar_in (cmd, argc, argv);
2565 if (strcasecmp (cmd, "tar_out") == 0 || strcasecmp (cmd, "tar-out") == 0)
2566 return run_tar_out (cmd, argc, argv);
2568 if (strcasecmp (cmd, "tgz_in") == 0 || strcasecmp (cmd, "tgz-in") == 0)
2569 return run_tgz_in (cmd, argc, argv);
2571 if (strcasecmp (cmd, "tgz_out") == 0 || strcasecmp (cmd, "tgz-out") == 0)
2572 return run_tgz_out (cmd, argc, argv);
2574 if (strcasecmp (cmd, "mount_ro") == 0 || strcasecmp (cmd, "mount-ro") == 0)
2575 return run_mount_ro (cmd, argc, argv);
2577 if (strcasecmp (cmd, "mount_options") == 0 || strcasecmp (cmd, "mount-options") == 0)
2578 return run_mount_options (cmd, argc, argv);
2580 if (strcasecmp (cmd, "mount_vfs") == 0 || strcasecmp (cmd, "mount-vfs") == 0)
2581 return run_mount_vfs (cmd, argc, argv);
2583 if (strcasecmp (cmd, "debug") == 0)
2584 return run_debug (cmd, argc, argv);
2586 if (strcasecmp (cmd, "lvremove") == 0)
2587 return run_lvremove (cmd, argc, argv);
2589 if (strcasecmp (cmd, "vgremove") == 0)
2590 return run_vgremove (cmd, argc, argv);
2592 if (strcasecmp (cmd, "pvremove") == 0)
2593 return run_pvremove (cmd, argc, argv);
2595 if (strcasecmp (cmd, "set_e2label") == 0 || strcasecmp (cmd, "set-e2label") == 0)
2596 return run_set_e2label (cmd, argc, argv);
2598 if (strcasecmp (cmd, "get_e2label") == 0 || strcasecmp (cmd, "get-e2label") == 0)
2599 return run_get_e2label (cmd, argc, argv);
2601 if (strcasecmp (cmd, "set_e2uuid") == 0 || strcasecmp (cmd, "set-e2uuid") == 0)
2602 return run_set_e2uuid (cmd, argc, argv);
2604 if (strcasecmp (cmd, "get_e2uuid") == 0 || strcasecmp (cmd, "get-e2uuid") == 0)
2605 return run_get_e2uuid (cmd, argc, argv);
2607 if (strcasecmp (cmd, "fsck") == 0)
2608 return run_fsck (cmd, argc, argv);
2610 if (strcasecmp (cmd, "zero") == 0)
2611 return run_zero (cmd, argc, argv);
2613 if (strcasecmp (cmd, "grub_install") == 0 || strcasecmp (cmd, "grub-install") == 0)
2614 return run_grub_install (cmd, argc, argv);
2616 if (strcasecmp (cmd, "cp") == 0)
2617 return run_cp (cmd, argc, argv);
2619 if (strcasecmp (cmd, "cp_a") == 0 || strcasecmp (cmd, "cp-a") == 0)
2620 return run_cp_a (cmd, argc, argv);
2622 if (strcasecmp (cmd, "mv") == 0)
2623 return run_mv (cmd, argc, argv);
2625 if (strcasecmp (cmd, "drop_caches") == 0 || strcasecmp (cmd, "drop-caches") == 0)
2626 return run_drop_caches (cmd, argc, argv);
2628 if (strcasecmp (cmd, "dmesg") == 0)
2629 return run_dmesg (cmd, argc, argv);
2632 fprintf (stderr, "%s: unknown command\n", cmd);