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", "chmod", "change file mode");
61 printf ("%-20s %s\n", "chown", "change file owner and group");
62 printf ("%-20s %s\n", "command", "run a command from the guest filesystem");
63 printf ("%-20s %s\n", "command-lines", "run a command, returning lines");
64 printf ("%-20s %s\n", "config", "add qemu parameters");
65 printf ("%-20s %s\n", "download", "download a file to the local machine");
66 printf ("%-20s %s\n", "exists", "test if file or directory exists");
67 printf ("%-20s %s\n", "file", "determine file type");
68 printf ("%-20s %s\n", "get-autosync", "get autosync mode");
69 printf ("%-20s %s\n", "get-path", "get the search path");
70 printf ("%-20s %s\n", "get-state", "get the current state");
71 printf ("%-20s %s\n", "get-verbose", "get verbose mode");
72 printf ("%-20s %s\n", "is-busy", "is busy processing a command");
73 printf ("%-20s %s\n", "is-config", "is in configuration state");
74 printf ("%-20s %s\n", "is-dir", "test if file exists");
75 printf ("%-20s %s\n", "is-file", "test if file exists");
76 printf ("%-20s %s\n", "is-launching", "is launching subprocess");
77 printf ("%-20s %s\n", "is-ready", "is ready to accept commands");
78 printf ("%-20s %s\n", "kill-subprocess", "kill the qemu subprocess");
79 printf ("%-20s %s\n", "launch", "launch the qemu subprocess");
80 printf ("%-20s %s\n", "list-devices", "list the block devices");
81 printf ("%-20s %s\n", "list-partitions", "list the partitions");
82 printf ("%-20s %s\n", "ll", "list the files in a directory (long format)");
83 printf ("%-20s %s\n", "ls", "list the files in a directory");
84 printf ("%-20s %s\n", "lstat", "get file information for a symbolic link");
85 printf ("%-20s %s\n", "lvcreate", "create an LVM volume group");
86 printf ("%-20s %s\n", "lvm-remove-all", "remove all LVM LVs, VGs and PVs");
87 printf ("%-20s %s\n", "lvs", "list the LVM logical volumes (LVs)");
88 printf ("%-20s %s\n", "lvs-full", "list the LVM logical volumes (LVs)");
89 printf ("%-20s %s\n", "mkdir", "create a directory");
90 printf ("%-20s %s\n", "mkdir-p", "create a directory and parents");
91 printf ("%-20s %s\n", "mkfs", "make a filesystem");
92 printf ("%-20s %s\n", "mount", "mount a guest disk at a position in the filesystem");
93 printf ("%-20s %s\n", "mounts", "show mounted filesystems");
94 printf ("%-20s %s\n", "pvcreate", "create an LVM physical volume");
95 printf ("%-20s %s\n", "pvs", "list the LVM physical volumes (PVs)");
96 printf ("%-20s %s\n", "pvs-full", "list the LVM physical volumes (PVs)");
97 printf ("%-20s %s\n", "read-lines", "read file as lines");
98 printf ("%-20s %s\n", "rm", "remove a file");
99 printf ("%-20s %s\n", "rm-rf", "remove a file or directory recursively");
100 printf ("%-20s %s\n", "rmdir", "remove a directory");
101 printf ("%-20s %s\n", "set-autosync", "set autosync mode");
102 printf ("%-20s %s\n", "set-path", "set the search path");
103 printf ("%-20s %s\n", "set-verbose", "set verbose mode");
104 printf ("%-20s %s\n", "sfdisk", "create partitions on a block device");
105 printf ("%-20s %s\n", "stat", "get file information");
106 printf ("%-20s %s\n", "statvfs", "get file system statistics");
107 printf ("%-20s %s\n", "sync", "sync disks, writes are flushed through to the disk image");
108 printf ("%-20s %s\n", "touch", "update file timestamps or create a new file");
109 printf ("%-20s %s\n", "tune2fs-l", "get ext2/ext3 superblock details");
110 printf ("%-20s %s\n", "umount", "unmount a filesystem");
111 printf ("%-20s %s\n", "umount-all", "unmount all filesystems");
112 printf ("%-20s %s\n", "upload", "upload a file from the local machine");
113 printf ("%-20s %s\n", "vgcreate", "create an LVM volume group");
114 printf ("%-20s %s\n", "vgs", "list the LVM volume groups (VGs)");
115 printf ("%-20s %s\n", "vgs-full", "list the LVM volume groups (VGs)");
116 printf ("%-20s %s\n", "write-file", "create a file");
117 printf (" Use -h <cmd> / help <cmd> to show detailed help for a command.\n");
120 void display_command (const char *cmd)
122 if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
123 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.");
125 if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
126 pod2text ("kill-subprocess - kill the qemu subprocess", " kill-subprocess\n\nThis kills the qemu subprocess. You should never need to call this.");
128 if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
129 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.");
131 if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
132 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.");
134 if (strcasecmp (cmd, "config") == 0)
135 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.");
137 if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
138 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.");
140 if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
141 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.");
143 if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
144 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<sync> when the handle is closed\n(also if the program exits without closing handles).\n\nYou can use 'autosync' as an alias for this command.");
146 if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
147 pod2text ("get-autosync - get autosync mode", " get-autosync\n\nGet the autosync flag.");
149 if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
150 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.");
152 if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
153 pod2text ("get-verbose - get verbose mode", " get-verbose\n\nThis returns the verbose messages flag.");
155 if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
156 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)>.");
158 if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
159 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)>.");
161 if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
162 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)>.");
164 if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
165 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)>.");
167 if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
168 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)>.");
170 if (strcasecmp (cmd, "mount") == 0)
171 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.");
173 if (strcasecmp (cmd, "sync") == 0)
174 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.");
176 if (strcasecmp (cmd, "touch") == 0)
177 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.");
179 if (strcasecmp (cmd, "cat") == 0)
180 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.");
182 if (strcasecmp (cmd, "ll") == 0)
183 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.");
185 if (strcasecmp (cmd, "ls") == 0)
186 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.");
188 if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
189 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>");
191 if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
192 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>.");
194 if (strcasecmp (cmd, "pvs") == 0)
195 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>.");
197 if (strcasecmp (cmd, "vgs") == 0)
198 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>.");
200 if (strcasecmp (cmd, "lvs") == 0)
201 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>.");
203 if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
204 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.");
206 if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
207 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.");
209 if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
210 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.");
212 if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
213 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.");
215 if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
216 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/>.");
218 if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
219 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.");
221 if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
222 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.");
224 if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
225 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.");
227 if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
228 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.");
230 if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
231 pod2text ("aug-set - set Augeas path to value", " aug-set <path> <val>\n\nSet the value associated with C<path> to C<value>.");
233 if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
234 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]>.");
236 if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
237 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.");
239 if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
240 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.");
242 if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
243 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.");
245 if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
246 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.");
248 if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
249 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.");
251 if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
252 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.");
254 if (strcasecmp (cmd, "rm") == 0)
255 pod2text ("rm - remove a file", " rm <path>\n\nRemove the single file C<path>.");
257 if (strcasecmp (cmd, "rmdir") == 0)
258 pod2text ("rmdir - remove a directory", " rmdir <path>\n\nRemove the single directory C<path>.");
260 if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
261 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.");
263 if (strcasecmp (cmd, "mkdir") == 0)
264 pod2text ("mkdir - create a directory", " mkdir <path>\n\nCreate a directory named C<path>.");
266 if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
267 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.");
269 if (strcasecmp (cmd, "chmod") == 0)
270 pod2text ("chmod - change file mode", " chmod <mode> <path>\n\nChange the mode (permissions) of C<path> to C<mode>. Only\nnumeric modes are supported.");
272 if (strcasecmp (cmd, "chown") == 0)
273 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).");
275 if (strcasecmp (cmd, "exists") == 0)
276 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>.");
278 if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
279 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>.");
281 if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
282 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>.");
284 if (strcasecmp (cmd, "pvcreate") == 0)
285 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>.");
287 if (strcasecmp (cmd, "vgcreate") == 0)
288 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>.");
290 if (strcasecmp (cmd, "lvcreate") == 0)
291 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.");
293 if (strcasecmp (cmd, "mkfs") == 0)
294 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>.");
296 if (strcasecmp (cmd, "sfdisk") == 0)
297 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>.");
299 if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
300 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.");
302 if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
303 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.");
305 if (strcasecmp (cmd, "mounts") == 0)
306 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.");
308 if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
309 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.");
311 if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
312 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>.");
314 if (strcasecmp (cmd, "file") == 0)
315 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).");
317 if (strcasecmp (cmd, "command") == 0)
318 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.");
320 if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
321 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.");
323 if (strcasecmp (cmd, "stat") == 0)
324 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.");
326 if (strcasecmp (cmd, "lstat") == 0)
327 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.");
329 if (strcasecmp (cmd, "statvfs") == 0)
330 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.");
332 if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
333 pod2text ("tune2fs-l - get ext2/ext3 superblock details", " tune2fs-l <device>\n\nThis returns the contents of the ext2 or ext3 filesystem superblock\non 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.");
335 if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
336 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.");
338 if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
339 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.");
341 if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
342 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.");
344 if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
345 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.");
347 if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
348 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.");
350 if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
351 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.");
353 if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
354 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.");
356 if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
357 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.");
359 if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
360 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.");
362 if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
363 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.");
365 if (strcasecmp (cmd, "upload") == 0)
366 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>.");
368 if (strcasecmp (cmd, "download") == 0)
369 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>.");
371 display_builtin_command (cmd);
374 static void print_pv (struct guestfs_lvm_pv *pv)
378 printf ("pv_name: %s\n", pv->pv_name);
379 printf ("pv_uuid: ");
380 for (i = 0; i < 32; ++i)
381 printf ("%c", pv->pv_uuid[i]);
383 printf ("pv_fmt: %s\n", pv->pv_fmt);
384 printf ("pv_size: %" PRIu64 "\n", pv->pv_size);
385 printf ("dev_size: %" PRIu64 "\n", pv->dev_size);
386 printf ("pv_free: %" PRIu64 "\n", pv->pv_free);
387 printf ("pv_used: %" PRIu64 "\n", pv->pv_used);
388 printf ("pv_attr: %s\n", pv->pv_attr);
389 printf ("pv_pe_count: %" PRIi64 "\n", pv->pv_pe_count);
390 printf ("pv_pe_alloc_count: %" PRIi64 "\n", pv->pv_pe_alloc_count);
391 printf ("pv_tags: %s\n", pv->pv_tags);
392 printf ("pe_start: %" PRIu64 "\n", pv->pe_start);
393 printf ("pv_mda_count: %" PRIi64 "\n", pv->pv_mda_count);
394 printf ("pv_mda_free: %" PRIu64 "\n", pv->pv_mda_free);
397 static void print_pv_list (struct guestfs_lvm_pv_list *pvs)
401 for (i = 0; i < pvs->len; ++i)
402 print_pv (&pvs->val[i]);
405 static void print_vg (struct guestfs_lvm_vg *vg)
409 printf ("vg_name: %s\n", vg->vg_name);
410 printf ("vg_uuid: ");
411 for (i = 0; i < 32; ++i)
412 printf ("%c", vg->vg_uuid[i]);
414 printf ("vg_fmt: %s\n", vg->vg_fmt);
415 printf ("vg_attr: %s\n", vg->vg_attr);
416 printf ("vg_size: %" PRIu64 "\n", vg->vg_size);
417 printf ("vg_free: %" PRIu64 "\n", vg->vg_free);
418 printf ("vg_sysid: %s\n", vg->vg_sysid);
419 printf ("vg_extent_size: %" PRIu64 "\n", vg->vg_extent_size);
420 printf ("vg_extent_count: %" PRIi64 "\n", vg->vg_extent_count);
421 printf ("vg_free_count: %" PRIi64 "\n", vg->vg_free_count);
422 printf ("max_lv: %" PRIi64 "\n", vg->max_lv);
423 printf ("max_pv: %" PRIi64 "\n", vg->max_pv);
424 printf ("pv_count: %" PRIi64 "\n", vg->pv_count);
425 printf ("lv_count: %" PRIi64 "\n", vg->lv_count);
426 printf ("snap_count: %" PRIi64 "\n", vg->snap_count);
427 printf ("vg_seqno: %" PRIi64 "\n", vg->vg_seqno);
428 printf ("vg_tags: %s\n", vg->vg_tags);
429 printf ("vg_mda_count: %" PRIi64 "\n", vg->vg_mda_count);
430 printf ("vg_mda_free: %" PRIu64 "\n", vg->vg_mda_free);
433 static void print_vg_list (struct guestfs_lvm_vg_list *vgs)
437 for (i = 0; i < vgs->len; ++i)
438 print_vg (&vgs->val[i]);
441 static void print_lv (struct guestfs_lvm_lv *lv)
445 printf ("lv_name: %s\n", lv->lv_name);
446 printf ("lv_uuid: ");
447 for (i = 0; i < 32; ++i)
448 printf ("%c", lv->lv_uuid[i]);
450 printf ("lv_attr: %s\n", lv->lv_attr);
451 printf ("lv_major: %" PRIi64 "\n", lv->lv_major);
452 printf ("lv_minor: %" PRIi64 "\n", lv->lv_minor);
453 printf ("lv_kernel_major: %" PRIi64 "\n", lv->lv_kernel_major);
454 printf ("lv_kernel_minor: %" PRIi64 "\n", lv->lv_kernel_minor);
455 printf ("lv_size: %" PRIu64 "\n", lv->lv_size);
456 printf ("seg_count: %" PRIi64 "\n", lv->seg_count);
457 printf ("origin: %s\n", lv->origin);
458 if (lv->snap_percent >= 0) printf ("snap_percent: %g %%\n", lv->snap_percent);
459 else printf ("snap_percent: \n");
460 if (lv->copy_percent >= 0) printf ("copy_percent: %g %%\n", lv->copy_percent);
461 else printf ("copy_percent: \n");
462 printf ("move_pv: %s\n", lv->move_pv);
463 printf ("lv_tags: %s\n", lv->lv_tags);
464 printf ("mirror_log: %s\n", lv->mirror_log);
465 printf ("modules: %s\n", lv->modules);
468 static void print_lv_list (struct guestfs_lvm_lv_list *lvs)
472 for (i = 0; i < lvs->len; ++i)
473 print_lv (&lvs->val[i]);
476 static void print_stat (struct guestfs_stat *stat)
478 printf ("dev: %" PRIi64 "\n", stat->dev);
479 printf ("ino: %" PRIi64 "\n", stat->ino);
480 printf ("mode: %" PRIi64 "\n", stat->mode);
481 printf ("nlink: %" PRIi64 "\n", stat->nlink);
482 printf ("uid: %" PRIi64 "\n", stat->uid);
483 printf ("gid: %" PRIi64 "\n", stat->gid);
484 printf ("rdev: %" PRIi64 "\n", stat->rdev);
485 printf ("size: %" PRIi64 "\n", stat->size);
486 printf ("blksize: %" PRIi64 "\n", stat->blksize);
487 printf ("blocks: %" PRIi64 "\n", stat->blocks);
488 printf ("atime: %" PRIi64 "\n", stat->atime);
489 printf ("mtime: %" PRIi64 "\n", stat->mtime);
490 printf ("ctime: %" PRIi64 "\n", stat->ctime);
493 static void print_statvfs (struct guestfs_statvfs *statvfs)
495 printf ("bsize: %" PRIi64 "\n", statvfs->bsize);
496 printf ("frsize: %" PRIi64 "\n", statvfs->frsize);
497 printf ("blocks: %" PRIi64 "\n", statvfs->blocks);
498 printf ("bfree: %" PRIi64 "\n", statvfs->bfree);
499 printf ("bavail: %" PRIi64 "\n", statvfs->bavail);
500 printf ("files: %" PRIi64 "\n", statvfs->files);
501 printf ("ffree: %" PRIi64 "\n", statvfs->ffree);
502 printf ("favail: %" PRIi64 "\n", statvfs->favail);
503 printf ("fsid: %" PRIi64 "\n", statvfs->fsid);
504 printf ("flag: %" PRIi64 "\n", statvfs->flag);
505 printf ("namemax: %" PRIi64 "\n", statvfs->namemax);
508 static int run_launch (const char *cmd, int argc, char *argv[])
512 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
513 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
520 static int run_kill_subprocess (const char *cmd, int argc, char *argv[])
524 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
525 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
528 r = guestfs_kill_subprocess (g);
532 static int run_add_drive (const char *cmd, int argc, char *argv[])
535 const char *filename;
537 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
538 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
542 r = guestfs_add_drive (g, filename);
546 static int run_add_cdrom (const char *cmd, int argc, char *argv[])
549 const char *filename;
551 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
552 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
556 r = guestfs_add_cdrom (g, filename);
560 static int run_config (const char *cmd, int argc, char *argv[])
563 const char *qemuparam;
564 const char *qemuvalue;
566 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
567 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
571 qemuvalue = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
572 r = guestfs_config (g, qemuparam, qemuvalue);
576 static int run_set_path (const char *cmd, int argc, char *argv[])
581 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
582 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
586 r = guestfs_set_path (g, path);
590 static int run_get_path (const char *cmd, int argc, char *argv[])
594 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
595 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
598 r = guestfs_get_path (g);
599 if (r == NULL) return -1;
604 static int run_set_autosync (const char *cmd, int argc, char *argv[])
609 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
610 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
613 autosync = is_true (argv[0]) ? 1 : 0;
614 r = guestfs_set_autosync (g, autosync);
618 static int run_get_autosync (const char *cmd, int argc, char *argv[])
622 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
623 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
626 r = guestfs_get_autosync (g);
627 if (r == -1) return -1;
628 if (r) printf ("true\n"); else printf ("false\n");
632 static int run_set_verbose (const char *cmd, int argc, char *argv[])
637 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
638 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
641 verbose = is_true (argv[0]) ? 1 : 0;
642 r = guestfs_set_verbose (g, verbose);
646 static int run_get_verbose (const char *cmd, int argc, char *argv[])
650 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
651 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
654 r = guestfs_get_verbose (g);
655 if (r == -1) return -1;
656 if (r) printf ("true\n"); else printf ("false\n");
660 static int run_is_ready (const char *cmd, int argc, char *argv[])
664 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
665 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
668 r = guestfs_is_ready (g);
669 if (r == -1) return -1;
670 if (r) printf ("true\n"); else printf ("false\n");
674 static int run_is_config (const char *cmd, int argc, char *argv[])
678 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
679 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
682 r = guestfs_is_config (g);
683 if (r == -1) return -1;
684 if (r) printf ("true\n"); else printf ("false\n");
688 static int run_is_launching (const char *cmd, int argc, char *argv[])
692 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
693 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
696 r = guestfs_is_launching (g);
697 if (r == -1) return -1;
698 if (r) printf ("true\n"); else printf ("false\n");
702 static int run_is_busy (const char *cmd, int argc, char *argv[])
706 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
707 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
710 r = guestfs_is_busy (g);
711 if (r == -1) return -1;
712 if (r) printf ("true\n"); else printf ("false\n");
716 static int run_get_state (const char *cmd, int argc, char *argv[])
720 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
721 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
724 r = guestfs_get_state (g);
725 if (r == -1) return -1;
730 static int run_mount (const char *cmd, int argc, char *argv[])
734 const char *mountpoint;
736 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
737 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
741 mountpoint = argv[1];
742 r = guestfs_mount (g, device, mountpoint);
746 static int run_sync (const char *cmd, int argc, char *argv[])
750 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
751 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
754 r = guestfs_sync (g);
758 static int run_touch (const char *cmd, int argc, char *argv[])
763 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
764 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
768 r = guestfs_touch (g, path);
772 static int run_cat (const char *cmd, int argc, char *argv[])
777 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
778 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
782 r = guestfs_cat (g, path);
783 if (r == NULL) return -1;
789 static int run_ll (const char *cmd, int argc, char *argv[])
792 const char *directory;
794 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
795 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
799 r = guestfs_ll (g, directory);
800 if (r == NULL) return -1;
806 static int run_ls (const char *cmd, int argc, char *argv[])
809 const char *directory;
811 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
812 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
816 r = guestfs_ls (g, directory);
817 if (r == NULL) return -1;
823 static int run_list_devices (const char *cmd, int argc, char *argv[])
827 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
828 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
831 r = guestfs_list_devices (g);
832 if (r == NULL) return -1;
838 static int run_list_partitions (const char *cmd, int argc, char *argv[])
842 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
843 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
846 r = guestfs_list_partitions (g);
847 if (r == NULL) return -1;
853 static int run_pvs (const char *cmd, int argc, char *argv[])
857 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
858 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
862 if (r == NULL) return -1;
868 static int run_vgs (const char *cmd, int argc, char *argv[])
872 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
873 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
877 if (r == NULL) return -1;
883 static int run_lvs (const char *cmd, int argc, char *argv[])
887 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
888 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
892 if (r == NULL) return -1;
898 static int run_pvs_full (const char *cmd, int argc, char *argv[])
900 struct guestfs_lvm_pv_list *r;
902 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
903 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
906 r = guestfs_pvs_full (g);
907 if (r == NULL) return -1;
909 guestfs_free_lvm_pv_list (r);
913 static int run_vgs_full (const char *cmd, int argc, char *argv[])
915 struct guestfs_lvm_vg_list *r;
917 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
918 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
921 r = guestfs_vgs_full (g);
922 if (r == NULL) return -1;
924 guestfs_free_lvm_vg_list (r);
928 static int run_lvs_full (const char *cmd, int argc, char *argv[])
930 struct guestfs_lvm_lv_list *r;
932 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
933 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
936 r = guestfs_lvs_full (g);
937 if (r == NULL) return -1;
939 guestfs_free_lvm_lv_list (r);
943 static int run_read_lines (const char *cmd, int argc, char *argv[])
948 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
949 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
953 r = guestfs_read_lines (g, path);
954 if (r == NULL) return -1;
960 static int run_aug_init (const char *cmd, int argc, char *argv[])
966 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
967 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
971 flags = atoi (argv[1]);
972 r = guestfs_aug_init (g, root, flags);
976 static int run_aug_close (const char *cmd, int argc, char *argv[])
980 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
981 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
984 r = guestfs_aug_close (g);
988 static int run_aug_defvar (const char *cmd, int argc, char *argv[])
994 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
995 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
999 expr = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
1000 r = guestfs_aug_defvar (g, name, expr);
1001 if (r == -1) return -1;
1006 static int run_aug_defnode (const char *cmd, int argc, char *argv[])
1008 struct guestfs_int_bool *r;
1013 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1014 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1020 r = guestfs_aug_defnode (g, name, expr, val);
1021 if (r == NULL) return -1;
1022 printf ("%d, %s\n", r->i,
1023 r->b ? "true" : "false");
1024 guestfs_free_int_bool (r);
1028 static int run_aug_get (const char *cmd, int argc, char *argv[])
1033 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1034 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1038 r = guestfs_aug_get (g, path);
1039 if (r == NULL) return -1;
1045 static int run_aug_set (const char *cmd, int argc, char *argv[])
1051 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1052 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1057 r = guestfs_aug_set (g, path, val);
1061 static int run_aug_insert (const char *cmd, int argc, char *argv[])
1068 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1069 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1074 before = is_true (argv[2]) ? 1 : 0;
1075 r = guestfs_aug_insert (g, path, label, before);
1079 static int run_aug_rm (const char *cmd, int argc, char *argv[])
1084 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1085 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1089 r = guestfs_aug_rm (g, path);
1090 if (r == -1) return -1;
1095 static int run_aug_mv (const char *cmd, int argc, char *argv[])
1101 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1102 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1107 r = guestfs_aug_mv (g, src, dest);
1111 static int run_aug_match (const char *cmd, int argc, char *argv[])
1116 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1117 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1121 r = guestfs_aug_match (g, path);
1122 if (r == NULL) return -1;
1128 static int run_aug_save (const char *cmd, int argc, char *argv[])
1132 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1133 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1136 r = guestfs_aug_save (g);
1140 static int run_aug_load (const char *cmd, int argc, char *argv[])
1144 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1145 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1148 r = guestfs_aug_load (g);
1152 static int run_aug_ls (const char *cmd, int argc, char *argv[])
1157 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1158 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1162 r = guestfs_aug_ls (g, path);
1163 if (r == NULL) return -1;
1169 static int run_rm (const char *cmd, int argc, char *argv[])
1174 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1175 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1179 r = guestfs_rm (g, path);
1183 static int run_rmdir (const char *cmd, int argc, char *argv[])
1188 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1189 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1193 r = guestfs_rmdir (g, path);
1197 static int run_rm_rf (const char *cmd, int argc, char *argv[])
1202 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1203 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1207 r = guestfs_rm_rf (g, path);
1211 static int run_mkdir (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_mkdir (g, path);
1225 static int run_mkdir_p (const char *cmd, int argc, char *argv[])
1230 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1231 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1235 r = guestfs_mkdir_p (g, path);
1239 static int run_chmod (const char *cmd, int argc, char *argv[])
1245 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1246 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1249 mode = atoi (argv[0]);
1251 r = guestfs_chmod (g, mode, path);
1255 static int run_chown (const char *cmd, int argc, char *argv[])
1262 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1263 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1266 owner = atoi (argv[0]);
1267 group = atoi (argv[1]);
1269 r = guestfs_chown (g, owner, group, path);
1273 static int run_exists (const char *cmd, int argc, char *argv[])
1278 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1279 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1283 r = guestfs_exists (g, path);
1284 if (r == -1) return -1;
1285 if (r) printf ("true\n"); else printf ("false\n");
1289 static int run_is_file (const char *cmd, int argc, char *argv[])
1294 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1295 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1299 r = guestfs_is_file (g, path);
1300 if (r == -1) return -1;
1301 if (r) printf ("true\n"); else printf ("false\n");
1305 static int run_is_dir (const char *cmd, int argc, char *argv[])
1310 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1311 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1315 r = guestfs_is_dir (g, path);
1316 if (r == -1) return -1;
1317 if (r) printf ("true\n"); else printf ("false\n");
1321 static int run_pvcreate (const char *cmd, int argc, char *argv[])
1326 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1327 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1331 r = guestfs_pvcreate (g, device);
1335 static int run_vgcreate (const char *cmd, int argc, char *argv[])
1338 const char *volgroup;
1341 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1342 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1346 physvols = parse_string_list (argv[1]);
1347 r = guestfs_vgcreate (g, volgroup, physvols);
1351 static int run_lvcreate (const char *cmd, int argc, char *argv[])
1355 const char *volgroup;
1358 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1359 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1364 mbytes = atoi (argv[2]);
1365 r = guestfs_lvcreate (g, logvol, volgroup, mbytes);
1369 static int run_mkfs (const char *cmd, int argc, char *argv[])
1375 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1376 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1381 r = guestfs_mkfs (g, fstype, device);
1385 static int run_sfdisk (const char *cmd, int argc, char *argv[])
1394 fprintf (stderr, "%s should have 5 parameter(s)\n", cmd);
1395 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1399 cyls = atoi (argv[1]);
1400 heads = atoi (argv[2]);
1401 sectors = atoi (argv[3]);
1402 lines = parse_string_list (argv[4]);
1403 r = guestfs_sfdisk (g, device, cyls, heads, sectors, lines);
1407 static int run_write_file (const char *cmd, int argc, char *argv[])
1411 const char *content;
1414 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1415 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1420 size = atoi (argv[2]);
1421 r = guestfs_write_file (g, path, content, size);
1425 static int run_umount (const char *cmd, int argc, char *argv[])
1428 const char *pathordevice;
1430 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1431 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1434 pathordevice = argv[0];
1435 r = guestfs_umount (g, pathordevice);
1439 static int run_mounts (const char *cmd, int argc, char *argv[])
1443 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1444 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1447 r = guestfs_mounts (g);
1448 if (r == NULL) return -1;
1454 static int run_umount_all (const char *cmd, int argc, char *argv[])
1458 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1459 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1462 r = guestfs_umount_all (g);
1466 static int run_lvm_remove_all (const char *cmd, int argc, char *argv[])
1470 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1471 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1474 r = guestfs_lvm_remove_all (g);
1478 static int run_file (const char *cmd, int argc, char *argv[])
1483 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1484 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1488 r = guestfs_file (g, path);
1489 if (r == NULL) return -1;
1495 static int run_command (const char *cmd, int argc, char *argv[])
1500 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1501 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1504 arguments = parse_string_list (argv[0]);
1505 r = guestfs_command (g, arguments);
1506 if (r == NULL) return -1;
1512 static int run_command_lines (const char *cmd, int argc, char *argv[])
1517 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1518 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1521 arguments = parse_string_list (argv[0]);
1522 r = guestfs_command_lines (g, arguments);
1523 if (r == NULL) return -1;
1529 static int run_stat (const char *cmd, int argc, char *argv[])
1531 struct guestfs_stat *r;
1534 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1535 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1539 r = guestfs_stat (g, path);
1540 if (r == NULL) return -1;
1546 static int run_lstat (const char *cmd, int argc, char *argv[])
1548 struct guestfs_stat *r;
1551 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1552 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1556 r = guestfs_lstat (g, path);
1557 if (r == NULL) return -1;
1563 static int run_statvfs (const char *cmd, int argc, char *argv[])
1565 struct guestfs_statvfs *r;
1568 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1569 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1573 r = guestfs_statvfs (g, path);
1574 if (r == NULL) return -1;
1580 static int run_tune2fs_l (const char *cmd, int argc, char *argv[])
1585 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1586 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1590 r = guestfs_tune2fs_l (g, device);
1591 if (r == NULL) return -1;
1597 static int run_blockdev_setro (const char *cmd, int argc, char *argv[])
1602 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1603 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1607 r = guestfs_blockdev_setro (g, device);
1611 static int run_blockdev_setrw (const char *cmd, int argc, char *argv[])
1616 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1617 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1621 r = guestfs_blockdev_setrw (g, device);
1625 static int run_blockdev_getro (const char *cmd, int argc, char *argv[])
1630 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1631 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1635 r = guestfs_blockdev_getro (g, device);
1636 if (r == -1) return -1;
1637 if (r) printf ("true\n"); else printf ("false\n");
1641 static int run_blockdev_getss (const char *cmd, int argc, char *argv[])
1646 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1647 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1651 r = guestfs_blockdev_getss (g, device);
1652 if (r == -1) return -1;
1657 static int run_blockdev_getbsz (const char *cmd, int argc, char *argv[])
1662 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1663 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1667 r = guestfs_blockdev_getbsz (g, device);
1668 if (r == -1) return -1;
1673 static int run_blockdev_setbsz (const char *cmd, int argc, char *argv[])
1679 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1680 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1684 blocksize = atoi (argv[1]);
1685 r = guestfs_blockdev_setbsz (g, device, blocksize);
1689 static int run_blockdev_getsz (const char *cmd, int argc, char *argv[])
1694 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1695 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1699 r = guestfs_blockdev_getsz (g, device);
1700 if (r == -1) return -1;
1701 printf ("%" PRIi64 "\n", r);
1705 static int run_blockdev_getsize64 (const char *cmd, int argc, char *argv[])
1710 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1711 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1715 r = guestfs_blockdev_getsize64 (g, device);
1716 if (r == -1) return -1;
1717 printf ("%" PRIi64 "\n", r);
1721 static int run_blockdev_flushbufs (const char *cmd, int argc, char *argv[])
1726 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1727 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1731 r = guestfs_blockdev_flushbufs (g, device);
1735 static int run_blockdev_rereadpt (const char *cmd, int argc, char *argv[])
1740 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1741 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1745 r = guestfs_blockdev_rereadpt (g, device);
1749 static int run_upload (const char *cmd, int argc, char *argv[])
1752 const char *filename;
1753 const char *remotefilename;
1755 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1756 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1759 filename = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
1760 remotefilename = argv[1];
1761 r = guestfs_upload (g, filename, remotefilename);
1765 static int run_download (const char *cmd, int argc, char *argv[])
1768 const char *remotefilename;
1769 const char *filename;
1771 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1772 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1775 remotefilename = argv[0];
1776 filename = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
1777 r = guestfs_download (g, remotefilename, filename);
1781 int run_action (const char *cmd, int argc, char *argv[])
1783 if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
1784 return run_launch (cmd, argc, argv);
1786 if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
1787 return run_kill_subprocess (cmd, argc, argv);
1789 if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
1790 return run_add_drive (cmd, argc, argv);
1792 if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
1793 return run_add_cdrom (cmd, argc, argv);
1795 if (strcasecmp (cmd, "config") == 0)
1796 return run_config (cmd, argc, argv);
1798 if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
1799 return run_set_path (cmd, argc, argv);
1801 if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
1802 return run_get_path (cmd, argc, argv);
1804 if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
1805 return run_set_autosync (cmd, argc, argv);
1807 if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
1808 return run_get_autosync (cmd, argc, argv);
1810 if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
1811 return run_set_verbose (cmd, argc, argv);
1813 if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
1814 return run_get_verbose (cmd, argc, argv);
1816 if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
1817 return run_is_ready (cmd, argc, argv);
1819 if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
1820 return run_is_config (cmd, argc, argv);
1822 if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
1823 return run_is_launching (cmd, argc, argv);
1825 if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
1826 return run_is_busy (cmd, argc, argv);
1828 if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
1829 return run_get_state (cmd, argc, argv);
1831 if (strcasecmp (cmd, "mount") == 0)
1832 return run_mount (cmd, argc, argv);
1834 if (strcasecmp (cmd, "sync") == 0)
1835 return run_sync (cmd, argc, argv);
1837 if (strcasecmp (cmd, "touch") == 0)
1838 return run_touch (cmd, argc, argv);
1840 if (strcasecmp (cmd, "cat") == 0)
1841 return run_cat (cmd, argc, argv);
1843 if (strcasecmp (cmd, "ll") == 0)
1844 return run_ll (cmd, argc, argv);
1846 if (strcasecmp (cmd, "ls") == 0)
1847 return run_ls (cmd, argc, argv);
1849 if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
1850 return run_list_devices (cmd, argc, argv);
1852 if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
1853 return run_list_partitions (cmd, argc, argv);
1855 if (strcasecmp (cmd, "pvs") == 0)
1856 return run_pvs (cmd, argc, argv);
1858 if (strcasecmp (cmd, "vgs") == 0)
1859 return run_vgs (cmd, argc, argv);
1861 if (strcasecmp (cmd, "lvs") == 0)
1862 return run_lvs (cmd, argc, argv);
1864 if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
1865 return run_pvs_full (cmd, argc, argv);
1867 if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
1868 return run_vgs_full (cmd, argc, argv);
1870 if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
1871 return run_lvs_full (cmd, argc, argv);
1873 if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
1874 return run_read_lines (cmd, argc, argv);
1876 if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
1877 return run_aug_init (cmd, argc, argv);
1879 if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
1880 return run_aug_close (cmd, argc, argv);
1882 if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
1883 return run_aug_defvar (cmd, argc, argv);
1885 if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
1886 return run_aug_defnode (cmd, argc, argv);
1888 if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
1889 return run_aug_get (cmd, argc, argv);
1891 if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
1892 return run_aug_set (cmd, argc, argv);
1894 if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
1895 return run_aug_insert (cmd, argc, argv);
1897 if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
1898 return run_aug_rm (cmd, argc, argv);
1900 if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
1901 return run_aug_mv (cmd, argc, argv);
1903 if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
1904 return run_aug_match (cmd, argc, argv);
1906 if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
1907 return run_aug_save (cmd, argc, argv);
1909 if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
1910 return run_aug_load (cmd, argc, argv);
1912 if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
1913 return run_aug_ls (cmd, argc, argv);
1915 if (strcasecmp (cmd, "rm") == 0)
1916 return run_rm (cmd, argc, argv);
1918 if (strcasecmp (cmd, "rmdir") == 0)
1919 return run_rmdir (cmd, argc, argv);
1921 if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
1922 return run_rm_rf (cmd, argc, argv);
1924 if (strcasecmp (cmd, "mkdir") == 0)
1925 return run_mkdir (cmd, argc, argv);
1927 if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
1928 return run_mkdir_p (cmd, argc, argv);
1930 if (strcasecmp (cmd, "chmod") == 0)
1931 return run_chmod (cmd, argc, argv);
1933 if (strcasecmp (cmd, "chown") == 0)
1934 return run_chown (cmd, argc, argv);
1936 if (strcasecmp (cmd, "exists") == 0)
1937 return run_exists (cmd, argc, argv);
1939 if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
1940 return run_is_file (cmd, argc, argv);
1942 if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
1943 return run_is_dir (cmd, argc, argv);
1945 if (strcasecmp (cmd, "pvcreate") == 0)
1946 return run_pvcreate (cmd, argc, argv);
1948 if (strcasecmp (cmd, "vgcreate") == 0)
1949 return run_vgcreate (cmd, argc, argv);
1951 if (strcasecmp (cmd, "lvcreate") == 0)
1952 return run_lvcreate (cmd, argc, argv);
1954 if (strcasecmp (cmd, "mkfs") == 0)
1955 return run_mkfs (cmd, argc, argv);
1957 if (strcasecmp (cmd, "sfdisk") == 0)
1958 return run_sfdisk (cmd, argc, argv);
1960 if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
1961 return run_write_file (cmd, argc, argv);
1963 if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
1964 return run_umount (cmd, argc, argv);
1966 if (strcasecmp (cmd, "mounts") == 0)
1967 return run_mounts (cmd, argc, argv);
1969 if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
1970 return run_umount_all (cmd, argc, argv);
1972 if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
1973 return run_lvm_remove_all (cmd, argc, argv);
1975 if (strcasecmp (cmd, "file") == 0)
1976 return run_file (cmd, argc, argv);
1978 if (strcasecmp (cmd, "command") == 0)
1979 return run_command (cmd, argc, argv);
1981 if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
1982 return run_command_lines (cmd, argc, argv);
1984 if (strcasecmp (cmd, "stat") == 0)
1985 return run_stat (cmd, argc, argv);
1987 if (strcasecmp (cmd, "lstat") == 0)
1988 return run_lstat (cmd, argc, argv);
1990 if (strcasecmp (cmd, "statvfs") == 0)
1991 return run_statvfs (cmd, argc, argv);
1993 if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
1994 return run_tune2fs_l (cmd, argc, argv);
1996 if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
1997 return run_blockdev_setro (cmd, argc, argv);
1999 if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
2000 return run_blockdev_setrw (cmd, argc, argv);
2002 if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
2003 return run_blockdev_getro (cmd, argc, argv);
2005 if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
2006 return run_blockdev_getss (cmd, argc, argv);
2008 if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
2009 return run_blockdev_getbsz (cmd, argc, argv);
2011 if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
2012 return run_blockdev_setbsz (cmd, argc, argv);
2014 if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
2015 return run_blockdev_getsz (cmd, argc, argv);
2017 if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
2018 return run_blockdev_getsize64 (cmd, argc, argv);
2020 if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
2021 return run_blockdev_flushbufs (cmd, argc, argv);
2023 if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
2024 return run_blockdev_rereadpt (cmd, argc, argv);
2026 if (strcasecmp (cmd, "upload") == 0)
2027 return run_upload (cmd, argc, argv);
2029 if (strcasecmp (cmd, "download") == 0)
2030 return run_download (cmd, argc, argv);
2033 fprintf (stderr, "%s: unknown command\n", cmd);