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", "download", "download a file to the local machine");
67 printf ("%-20s %s\n", "exists", "test if file or directory exists");
68 printf ("%-20s %s\n", "file", "determine file type");
69 printf ("%-20s %s\n", "get-autosync", "get autosync mode");
70 printf ("%-20s %s\n", "get-path", "get the search path");
71 printf ("%-20s %s\n", "get-qemu", "get the qemu binary");
72 printf ("%-20s %s\n", "get-state", "get the current state");
73 printf ("%-20s %s\n", "get-verbose", "get verbose mode");
74 printf ("%-20s %s\n", "is-busy", "is busy processing a command");
75 printf ("%-20s %s\n", "is-config", "is in configuration state");
76 printf ("%-20s %s\n", "is-dir", "test if file exists");
77 printf ("%-20s %s\n", "is-file", "test if file exists");
78 printf ("%-20s %s\n", "is-launching", "is launching subprocess");
79 printf ("%-20s %s\n", "is-ready", "is ready to accept commands");
80 printf ("%-20s %s\n", "kill-subprocess", "kill the qemu subprocess");
81 printf ("%-20s %s\n", "launch", "launch the qemu subprocess");
82 printf ("%-20s %s\n", "list-devices", "list the block devices");
83 printf ("%-20s %s\n", "list-partitions", "list the partitions");
84 printf ("%-20s %s\n", "ll", "list the files in a directory (long format)");
85 printf ("%-20s %s\n", "ls", "list the files in a directory");
86 printf ("%-20s %s\n", "lstat", "get file information for a symbolic link");
87 printf ("%-20s %s\n", "lvcreate", "create an LVM volume group");
88 printf ("%-20s %s\n", "lvm-remove-all", "remove all LVM LVs, VGs and PVs");
89 printf ("%-20s %s\n", "lvs", "list the LVM logical volumes (LVs)");
90 printf ("%-20s %s\n", "lvs-full", "list the LVM logical volumes (LVs)");
91 printf ("%-20s %s\n", "mkdir", "create a directory");
92 printf ("%-20s %s\n", "mkdir-p", "create a directory and parents");
93 printf ("%-20s %s\n", "mkfs", "make a filesystem");
94 printf ("%-20s %s\n", "mount", "mount a guest disk at a position in the filesystem");
95 printf ("%-20s %s\n", "mounts", "show mounted filesystems");
96 printf ("%-20s %s\n", "pvcreate", "create an LVM physical volume");
97 printf ("%-20s %s\n", "pvs", "list the LVM physical volumes (PVs)");
98 printf ("%-20s %s\n", "pvs-full", "list the LVM physical volumes (PVs)");
99 printf ("%-20s %s\n", "read-lines", "read file as lines");
100 printf ("%-20s %s\n", "rm", "remove a file");
101 printf ("%-20s %s\n", "rm-rf", "remove a file or directory recursively");
102 printf ("%-20s %s\n", "rmdir", "remove a directory");
103 printf ("%-20s %s\n", "set-autosync", "set autosync mode");
104 printf ("%-20s %s\n", "set-path", "set the search path");
105 printf ("%-20s %s\n", "set-qemu", "set the qemu binary");
106 printf ("%-20s %s\n", "set-verbose", "set verbose mode");
107 printf ("%-20s %s\n", "sfdisk", "create partitions on a block device");
108 printf ("%-20s %s\n", "stat", "get file information");
109 printf ("%-20s %s\n", "statvfs", "get file system statistics");
110 printf ("%-20s %s\n", "sync", "sync disks, writes are flushed through to the disk image");
111 printf ("%-20s %s\n", "tar-in", "unpack tarfile to directory");
112 printf ("%-20s %s\n", "tar-out", "pack directory into tarfile");
113 printf ("%-20s %s\n", "tgz-in", "unpack compressed tarball to directory");
114 printf ("%-20s %s\n", "tgz-out", "pack directory into compressed tarball");
115 printf ("%-20s %s\n", "touch", "update file timestamps or create a new file");
116 printf ("%-20s %s\n", "tune2fs-l", "get ext2/ext3 superblock details");
117 printf ("%-20s %s\n", "umount", "unmount a filesystem");
118 printf ("%-20s %s\n", "umount-all", "unmount all filesystems");
119 printf ("%-20s %s\n", "upload", "upload a file from the local machine");
120 printf ("%-20s %s\n", "vgcreate", "create an LVM volume group");
121 printf ("%-20s %s\n", "vgs", "list the LVM volume groups (VGs)");
122 printf ("%-20s %s\n", "vgs-full", "list the LVM volume groups (VGs)");
123 printf ("%-20s %s\n", "write-file", "create a file");
124 printf (" Use -h <cmd> / help <cmd> to show detailed help for a command.\n");
127 void display_command (const char *cmd)
129 if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
130 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.");
132 if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
133 pod2text ("kill-subprocess - kill the qemu subprocess", " kill-subprocess\n\nThis kills the qemu subprocess. You should never need to call this.");
135 if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
136 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.");
138 if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
139 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.");
141 if (strcasecmp (cmd, "config") == 0)
142 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.");
144 if (strcasecmp (cmd, "set_qemu") == 0 || strcasecmp (cmd, "set-qemu") == 0 || strcasecmp (cmd, "qemu") == 0)
145 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.");
147 if (strcasecmp (cmd, "get_qemu") == 0 || strcasecmp (cmd, "get-qemu") == 0)
148 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.");
150 if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
151 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.");
153 if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
154 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.");
156 if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
157 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.");
159 if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
160 pod2text ("get-autosync - get autosync mode", " get-autosync\n\nGet the autosync flag.");
162 if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
163 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.");
165 if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
166 pod2text ("get-verbose - get verbose mode", " get-verbose\n\nThis returns the verbose messages flag.");
168 if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
169 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)>.");
171 if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
172 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)>.");
174 if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
175 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)>.");
177 if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
178 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)>.");
180 if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
181 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)>.");
183 if (strcasecmp (cmd, "mount") == 0)
184 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.");
186 if (strcasecmp (cmd, "sync") == 0)
187 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.");
189 if (strcasecmp (cmd, "touch") == 0)
190 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.");
192 if (strcasecmp (cmd, "cat") == 0)
193 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.");
195 if (strcasecmp (cmd, "ll") == 0)
196 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.");
198 if (strcasecmp (cmd, "ls") == 0)
199 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.");
201 if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
202 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>");
204 if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
205 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>.");
207 if (strcasecmp (cmd, "pvs") == 0)
208 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>.");
210 if (strcasecmp (cmd, "vgs") == 0)
211 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>.");
213 if (strcasecmp (cmd, "lvs") == 0)
214 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>.");
216 if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
217 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.");
219 if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
220 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.");
222 if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
223 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.");
225 if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
226 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.");
228 if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
229 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/>.");
231 if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
232 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.");
234 if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
235 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.");
237 if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
238 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.");
240 if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
241 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.");
243 if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
244 pod2text ("aug-set - set Augeas path to value", " aug-set <path> <val>\n\nSet the value associated with C<path> to C<value>.");
246 if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
247 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]>.");
249 if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
250 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.");
252 if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
253 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.");
255 if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
256 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.");
258 if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
259 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.");
261 if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
262 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.");
264 if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
265 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.");
267 if (strcasecmp (cmd, "rm") == 0)
268 pod2text ("rm - remove a file", " rm <path>\n\nRemove the single file C<path>.");
270 if (strcasecmp (cmd, "rmdir") == 0)
271 pod2text ("rmdir - remove a directory", " rmdir <path>\n\nRemove the single directory C<path>.");
273 if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
274 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.");
276 if (strcasecmp (cmd, "mkdir") == 0)
277 pod2text ("mkdir - create a directory", " mkdir <path>\n\nCreate a directory named C<path>.");
279 if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
280 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.");
282 if (strcasecmp (cmd, "chmod") == 0)
283 pod2text ("chmod - change file mode", " chmod <mode> <path>\n\nChange the mode (permissions) of C<path> to C<mode>. Only\nnumeric modes are supported.");
285 if (strcasecmp (cmd, "chown") == 0)
286 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).");
288 if (strcasecmp (cmd, "exists") == 0)
289 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>.");
291 if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
292 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>.");
294 if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
295 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>.");
297 if (strcasecmp (cmd, "pvcreate") == 0)
298 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>.");
300 if (strcasecmp (cmd, "vgcreate") == 0)
301 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>.");
303 if (strcasecmp (cmd, "lvcreate") == 0)
304 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.");
306 if (strcasecmp (cmd, "mkfs") == 0)
307 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>.");
309 if (strcasecmp (cmd, "sfdisk") == 0)
310 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>.");
312 if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
313 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.");
315 if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
316 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.");
318 if (strcasecmp (cmd, "mounts") == 0)
319 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.");
321 if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
322 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.");
324 if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
325 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>.");
327 if (strcasecmp (cmd, "file") == 0)
328 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).");
330 if (strcasecmp (cmd, "command") == 0)
331 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.");
333 if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
334 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.");
336 if (strcasecmp (cmd, "stat") == 0)
337 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.");
339 if (strcasecmp (cmd, "lstat") == 0)
340 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.");
342 if (strcasecmp (cmd, "statvfs") == 0)
343 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.");
345 if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
346 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.");
348 if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
349 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.");
351 if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
352 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.");
354 if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
355 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.");
357 if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
358 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.");
360 if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
361 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.");
363 if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
364 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.");
366 if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
367 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.");
369 if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
370 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.");
372 if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
373 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.");
375 if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
376 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.");
378 if (strcasecmp (cmd, "upload") == 0)
379 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>.");
381 if (strcasecmp (cmd, "download") == 0)
382 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>.");
384 if (strcasecmp (cmd, "checksum") == 0)
385 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.");
387 if (strcasecmp (cmd, "tar_in") == 0 || strcasecmp (cmd, "tar-in") == 0)
388 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>.");
390 if (strcasecmp (cmd, "tar_out") == 0 || strcasecmp (cmd, "tar-out") == 0)
391 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>.");
393 if (strcasecmp (cmd, "tgz_in") == 0 || strcasecmp (cmd, "tgz-in") == 0)
394 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>.");
396 if (strcasecmp (cmd, "tgz_out") == 0 || strcasecmp (cmd, "tgz-out") == 0)
397 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>.");
399 display_builtin_command (cmd);
402 static void print_pv (struct guestfs_lvm_pv *pv)
406 printf ("pv_name: %s\n", pv->pv_name);
407 printf ("pv_uuid: ");
408 for (i = 0; i < 32; ++i)
409 printf ("%c", pv->pv_uuid[i]);
411 printf ("pv_fmt: %s\n", pv->pv_fmt);
412 printf ("pv_size: %" PRIu64 "\n", pv->pv_size);
413 printf ("dev_size: %" PRIu64 "\n", pv->dev_size);
414 printf ("pv_free: %" PRIu64 "\n", pv->pv_free);
415 printf ("pv_used: %" PRIu64 "\n", pv->pv_used);
416 printf ("pv_attr: %s\n", pv->pv_attr);
417 printf ("pv_pe_count: %" PRIi64 "\n", pv->pv_pe_count);
418 printf ("pv_pe_alloc_count: %" PRIi64 "\n", pv->pv_pe_alloc_count);
419 printf ("pv_tags: %s\n", pv->pv_tags);
420 printf ("pe_start: %" PRIu64 "\n", pv->pe_start);
421 printf ("pv_mda_count: %" PRIi64 "\n", pv->pv_mda_count);
422 printf ("pv_mda_free: %" PRIu64 "\n", pv->pv_mda_free);
425 static void print_pv_list (struct guestfs_lvm_pv_list *pvs)
429 for (i = 0; i < pvs->len; ++i)
430 print_pv (&pvs->val[i]);
433 static void print_vg (struct guestfs_lvm_vg *vg)
437 printf ("vg_name: %s\n", vg->vg_name);
438 printf ("vg_uuid: ");
439 for (i = 0; i < 32; ++i)
440 printf ("%c", vg->vg_uuid[i]);
442 printf ("vg_fmt: %s\n", vg->vg_fmt);
443 printf ("vg_attr: %s\n", vg->vg_attr);
444 printf ("vg_size: %" PRIu64 "\n", vg->vg_size);
445 printf ("vg_free: %" PRIu64 "\n", vg->vg_free);
446 printf ("vg_sysid: %s\n", vg->vg_sysid);
447 printf ("vg_extent_size: %" PRIu64 "\n", vg->vg_extent_size);
448 printf ("vg_extent_count: %" PRIi64 "\n", vg->vg_extent_count);
449 printf ("vg_free_count: %" PRIi64 "\n", vg->vg_free_count);
450 printf ("max_lv: %" PRIi64 "\n", vg->max_lv);
451 printf ("max_pv: %" PRIi64 "\n", vg->max_pv);
452 printf ("pv_count: %" PRIi64 "\n", vg->pv_count);
453 printf ("lv_count: %" PRIi64 "\n", vg->lv_count);
454 printf ("snap_count: %" PRIi64 "\n", vg->snap_count);
455 printf ("vg_seqno: %" PRIi64 "\n", vg->vg_seqno);
456 printf ("vg_tags: %s\n", vg->vg_tags);
457 printf ("vg_mda_count: %" PRIi64 "\n", vg->vg_mda_count);
458 printf ("vg_mda_free: %" PRIu64 "\n", vg->vg_mda_free);
461 static void print_vg_list (struct guestfs_lvm_vg_list *vgs)
465 for (i = 0; i < vgs->len; ++i)
466 print_vg (&vgs->val[i]);
469 static void print_lv (struct guestfs_lvm_lv *lv)
473 printf ("lv_name: %s\n", lv->lv_name);
474 printf ("lv_uuid: ");
475 for (i = 0; i < 32; ++i)
476 printf ("%c", lv->lv_uuid[i]);
478 printf ("lv_attr: %s\n", lv->lv_attr);
479 printf ("lv_major: %" PRIi64 "\n", lv->lv_major);
480 printf ("lv_minor: %" PRIi64 "\n", lv->lv_minor);
481 printf ("lv_kernel_major: %" PRIi64 "\n", lv->lv_kernel_major);
482 printf ("lv_kernel_minor: %" PRIi64 "\n", lv->lv_kernel_minor);
483 printf ("lv_size: %" PRIu64 "\n", lv->lv_size);
484 printf ("seg_count: %" PRIi64 "\n", lv->seg_count);
485 printf ("origin: %s\n", lv->origin);
486 if (lv->snap_percent >= 0) printf ("snap_percent: %g %%\n", lv->snap_percent);
487 else printf ("snap_percent: \n");
488 if (lv->copy_percent >= 0) printf ("copy_percent: %g %%\n", lv->copy_percent);
489 else printf ("copy_percent: \n");
490 printf ("move_pv: %s\n", lv->move_pv);
491 printf ("lv_tags: %s\n", lv->lv_tags);
492 printf ("mirror_log: %s\n", lv->mirror_log);
493 printf ("modules: %s\n", lv->modules);
496 static void print_lv_list (struct guestfs_lvm_lv_list *lvs)
500 for (i = 0; i < lvs->len; ++i)
501 print_lv (&lvs->val[i]);
504 static void print_stat (struct guestfs_stat *stat)
506 printf ("dev: %" PRIi64 "\n", stat->dev);
507 printf ("ino: %" PRIi64 "\n", stat->ino);
508 printf ("mode: %" PRIi64 "\n", stat->mode);
509 printf ("nlink: %" PRIi64 "\n", stat->nlink);
510 printf ("uid: %" PRIi64 "\n", stat->uid);
511 printf ("gid: %" PRIi64 "\n", stat->gid);
512 printf ("rdev: %" PRIi64 "\n", stat->rdev);
513 printf ("size: %" PRIi64 "\n", stat->size);
514 printf ("blksize: %" PRIi64 "\n", stat->blksize);
515 printf ("blocks: %" PRIi64 "\n", stat->blocks);
516 printf ("atime: %" PRIi64 "\n", stat->atime);
517 printf ("mtime: %" PRIi64 "\n", stat->mtime);
518 printf ("ctime: %" PRIi64 "\n", stat->ctime);
521 static void print_statvfs (struct guestfs_statvfs *statvfs)
523 printf ("bsize: %" PRIi64 "\n", statvfs->bsize);
524 printf ("frsize: %" PRIi64 "\n", statvfs->frsize);
525 printf ("blocks: %" PRIi64 "\n", statvfs->blocks);
526 printf ("bfree: %" PRIi64 "\n", statvfs->bfree);
527 printf ("bavail: %" PRIi64 "\n", statvfs->bavail);
528 printf ("files: %" PRIi64 "\n", statvfs->files);
529 printf ("ffree: %" PRIi64 "\n", statvfs->ffree);
530 printf ("favail: %" PRIi64 "\n", statvfs->favail);
531 printf ("fsid: %" PRIi64 "\n", statvfs->fsid);
532 printf ("flag: %" PRIi64 "\n", statvfs->flag);
533 printf ("namemax: %" PRIi64 "\n", statvfs->namemax);
536 static int run_launch (const char *cmd, int argc, char *argv[])
540 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
541 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
548 static int run_kill_subprocess (const char *cmd, int argc, char *argv[])
552 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
553 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
556 r = guestfs_kill_subprocess (g);
560 static int run_add_drive (const char *cmd, int argc, char *argv[])
563 const char *filename;
565 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
566 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
570 r = guestfs_add_drive (g, filename);
574 static int run_add_cdrom (const char *cmd, int argc, char *argv[])
577 const char *filename;
579 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
580 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
584 r = guestfs_add_cdrom (g, filename);
588 static int run_config (const char *cmd, int argc, char *argv[])
591 const char *qemuparam;
592 const char *qemuvalue;
594 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
595 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
599 qemuvalue = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
600 r = guestfs_config (g, qemuparam, qemuvalue);
604 static int run_set_qemu (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);
614 r = guestfs_set_qemu (g, qemu);
618 static int run_get_qemu (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_qemu (g);
627 if (r == NULL) return -1;
632 static int run_set_path (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);
642 r = guestfs_set_path (g, path);
646 static int run_get_path (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_path (g);
655 if (r == NULL) return -1;
660 static int run_set_autosync (const char *cmd, int argc, char *argv[])
665 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
666 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
669 autosync = is_true (argv[0]) ? 1 : 0;
670 r = guestfs_set_autosync (g, autosync);
674 static int run_get_autosync (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_get_autosync (g);
683 if (r == -1) return -1;
684 if (r) printf ("true\n"); else printf ("false\n");
688 static int run_set_verbose (const char *cmd, int argc, char *argv[])
693 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
694 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
697 verbose = is_true (argv[0]) ? 1 : 0;
698 r = guestfs_set_verbose (g, verbose);
702 static int run_get_verbose (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_get_verbose (g);
711 if (r == -1) return -1;
712 if (r) printf ("true\n"); else printf ("false\n");
716 static int run_is_ready (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_is_ready (g);
725 if (r == -1) return -1;
726 if (r) printf ("true\n"); else printf ("false\n");
730 static int run_is_config (const char *cmd, int argc, char *argv[])
734 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
735 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
738 r = guestfs_is_config (g);
739 if (r == -1) return -1;
740 if (r) printf ("true\n"); else printf ("false\n");
744 static int run_is_launching (const char *cmd, int argc, char *argv[])
748 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
749 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
752 r = guestfs_is_launching (g);
753 if (r == -1) return -1;
754 if (r) printf ("true\n"); else printf ("false\n");
758 static int run_is_busy (const char *cmd, int argc, char *argv[])
762 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
763 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
766 r = guestfs_is_busy (g);
767 if (r == -1) return -1;
768 if (r) printf ("true\n"); else printf ("false\n");
772 static int run_get_state (const char *cmd, int argc, char *argv[])
776 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
777 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
780 r = guestfs_get_state (g);
781 if (r == -1) return -1;
786 static int run_mount (const char *cmd, int argc, char *argv[])
790 const char *mountpoint;
792 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
793 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
797 mountpoint = argv[1];
798 r = guestfs_mount (g, device, mountpoint);
802 static int run_sync (const char *cmd, int argc, char *argv[])
806 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
807 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
810 r = guestfs_sync (g);
814 static int run_touch (const char *cmd, int argc, char *argv[])
819 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
820 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
824 r = guestfs_touch (g, path);
828 static int run_cat (const char *cmd, int argc, char *argv[])
833 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
834 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
838 r = guestfs_cat (g, path);
839 if (r == NULL) return -1;
845 static int run_ll (const char *cmd, int argc, char *argv[])
848 const char *directory;
850 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
851 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
855 r = guestfs_ll (g, directory);
856 if (r == NULL) return -1;
862 static int run_ls (const char *cmd, int argc, char *argv[])
865 const char *directory;
867 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
868 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
872 r = guestfs_ls (g, directory);
873 if (r == NULL) return -1;
879 static int run_list_devices (const char *cmd, int argc, char *argv[])
883 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
884 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
887 r = guestfs_list_devices (g);
888 if (r == NULL) return -1;
894 static int run_list_partitions (const char *cmd, int argc, char *argv[])
898 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
899 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
902 r = guestfs_list_partitions (g);
903 if (r == NULL) return -1;
909 static int run_pvs (const char *cmd, int argc, char *argv[])
913 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
914 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
918 if (r == NULL) return -1;
924 static int run_vgs (const char *cmd, int argc, char *argv[])
928 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
929 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
933 if (r == NULL) return -1;
939 static int run_lvs (const char *cmd, int argc, char *argv[])
943 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
944 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
948 if (r == NULL) return -1;
954 static int run_pvs_full (const char *cmd, int argc, char *argv[])
956 struct guestfs_lvm_pv_list *r;
958 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
959 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
962 r = guestfs_pvs_full (g);
963 if (r == NULL) return -1;
965 guestfs_free_lvm_pv_list (r);
969 static int run_vgs_full (const char *cmd, int argc, char *argv[])
971 struct guestfs_lvm_vg_list *r;
973 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
974 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
977 r = guestfs_vgs_full (g);
978 if (r == NULL) return -1;
980 guestfs_free_lvm_vg_list (r);
984 static int run_lvs_full (const char *cmd, int argc, char *argv[])
986 struct guestfs_lvm_lv_list *r;
988 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
989 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
992 r = guestfs_lvs_full (g);
993 if (r == NULL) return -1;
995 guestfs_free_lvm_lv_list (r);
999 static int run_read_lines (const char *cmd, int argc, char *argv[])
1004 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1005 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1009 r = guestfs_read_lines (g, path);
1010 if (r == NULL) return -1;
1016 static int run_aug_init (const char *cmd, int argc, char *argv[])
1022 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1023 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1027 flags = atoi (argv[1]);
1028 r = guestfs_aug_init (g, root, flags);
1032 static int run_aug_close (const char *cmd, int argc, char *argv[])
1036 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1037 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1040 r = guestfs_aug_close (g);
1044 static int run_aug_defvar (const char *cmd, int argc, char *argv[])
1050 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1051 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1055 expr = strcmp (argv[1], "") != 0 ? argv[1] : NULL;
1056 r = guestfs_aug_defvar (g, name, expr);
1057 if (r == -1) return -1;
1062 static int run_aug_defnode (const char *cmd, int argc, char *argv[])
1064 struct guestfs_int_bool *r;
1069 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1070 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1076 r = guestfs_aug_defnode (g, name, expr, val);
1077 if (r == NULL) return -1;
1078 printf ("%d, %s\n", r->i,
1079 r->b ? "true" : "false");
1080 guestfs_free_int_bool (r);
1084 static int run_aug_get (const char *cmd, int argc, char *argv[])
1089 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1090 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1094 r = guestfs_aug_get (g, path);
1095 if (r == NULL) return -1;
1101 static int run_aug_set (const char *cmd, int argc, char *argv[])
1107 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1108 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1113 r = guestfs_aug_set (g, path, val);
1117 static int run_aug_insert (const char *cmd, int argc, char *argv[])
1124 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1125 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1130 before = is_true (argv[2]) ? 1 : 0;
1131 r = guestfs_aug_insert (g, path, label, before);
1135 static int run_aug_rm (const char *cmd, int argc, char *argv[])
1140 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1141 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1145 r = guestfs_aug_rm (g, path);
1146 if (r == -1) return -1;
1151 static int run_aug_mv (const char *cmd, int argc, char *argv[])
1157 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1158 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1163 r = guestfs_aug_mv (g, src, dest);
1167 static int run_aug_match (const char *cmd, int argc, char *argv[])
1172 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1173 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1177 r = guestfs_aug_match (g, path);
1178 if (r == NULL) return -1;
1184 static int run_aug_save (const char *cmd, int argc, char *argv[])
1188 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1189 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1192 r = guestfs_aug_save (g);
1196 static int run_aug_load (const char *cmd, int argc, char *argv[])
1200 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1201 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1204 r = guestfs_aug_load (g);
1208 static int run_aug_ls (const char *cmd, int argc, char *argv[])
1213 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1214 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1218 r = guestfs_aug_ls (g, path);
1219 if (r == NULL) return -1;
1225 static int run_rm (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_rm (g, path);
1239 static int run_rmdir (const char *cmd, int argc, char *argv[])
1244 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1245 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1249 r = guestfs_rmdir (g, path);
1253 static int run_rm_rf (const char *cmd, int argc, char *argv[])
1258 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1259 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1263 r = guestfs_rm_rf (g, path);
1267 static int run_mkdir (const char *cmd, int argc, char *argv[])
1272 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1273 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1277 r = guestfs_mkdir (g, path);
1281 static int run_mkdir_p (const char *cmd, int argc, char *argv[])
1286 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1287 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1291 r = guestfs_mkdir_p (g, path);
1295 static int run_chmod (const char *cmd, int argc, char *argv[])
1301 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1302 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1305 mode = atoi (argv[0]);
1307 r = guestfs_chmod (g, mode, path);
1311 static int run_chown (const char *cmd, int argc, char *argv[])
1318 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1319 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1322 owner = atoi (argv[0]);
1323 group = atoi (argv[1]);
1325 r = guestfs_chown (g, owner, group, path);
1329 static int run_exists (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_exists (g, path);
1340 if (r == -1) return -1;
1341 if (r) printf ("true\n"); else printf ("false\n");
1345 static int run_is_file (const char *cmd, int argc, char *argv[])
1350 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1351 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1355 r = guestfs_is_file (g, path);
1356 if (r == -1) return -1;
1357 if (r) printf ("true\n"); else printf ("false\n");
1361 static int run_is_dir (const char *cmd, int argc, char *argv[])
1366 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1367 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1371 r = guestfs_is_dir (g, path);
1372 if (r == -1) return -1;
1373 if (r) printf ("true\n"); else printf ("false\n");
1377 static int run_pvcreate (const char *cmd, int argc, char *argv[])
1382 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1383 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1387 r = guestfs_pvcreate (g, device);
1391 static int run_vgcreate (const char *cmd, int argc, char *argv[])
1394 const char *volgroup;
1397 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1398 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1402 physvols = parse_string_list (argv[1]);
1403 r = guestfs_vgcreate (g, volgroup, physvols);
1407 static int run_lvcreate (const char *cmd, int argc, char *argv[])
1411 const char *volgroup;
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 mbytes = atoi (argv[2]);
1421 r = guestfs_lvcreate (g, logvol, volgroup, mbytes);
1425 static int run_mkfs (const char *cmd, int argc, char *argv[])
1431 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1432 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1437 r = guestfs_mkfs (g, fstype, device);
1441 static int run_sfdisk (const char *cmd, int argc, char *argv[])
1450 fprintf (stderr, "%s should have 5 parameter(s)\n", cmd);
1451 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1455 cyls = atoi (argv[1]);
1456 heads = atoi (argv[2]);
1457 sectors = atoi (argv[3]);
1458 lines = parse_string_list (argv[4]);
1459 r = guestfs_sfdisk (g, device, cyls, heads, sectors, lines);
1463 static int run_write_file (const char *cmd, int argc, char *argv[])
1467 const char *content;
1470 fprintf (stderr, "%s should have 3 parameter(s)\n", cmd);
1471 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1476 size = atoi (argv[2]);
1477 r = guestfs_write_file (g, path, content, size);
1481 static int run_umount (const char *cmd, int argc, char *argv[])
1484 const char *pathordevice;
1486 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1487 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1490 pathordevice = argv[0];
1491 r = guestfs_umount (g, pathordevice);
1495 static int run_mounts (const char *cmd, int argc, char *argv[])
1499 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1500 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1503 r = guestfs_mounts (g);
1504 if (r == NULL) return -1;
1510 static int run_umount_all (const char *cmd, int argc, char *argv[])
1514 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1515 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1518 r = guestfs_umount_all (g);
1522 static int run_lvm_remove_all (const char *cmd, int argc, char *argv[])
1526 fprintf (stderr, "%s should have 0 parameter(s)\n", cmd);
1527 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1530 r = guestfs_lvm_remove_all (g);
1534 static int run_file (const char *cmd, int argc, char *argv[])
1539 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1540 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1544 r = guestfs_file (g, path);
1545 if (r == NULL) return -1;
1551 static int run_command (const char *cmd, int argc, char *argv[])
1556 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1557 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1560 arguments = parse_string_list (argv[0]);
1561 r = guestfs_command (g, arguments);
1562 if (r == NULL) return -1;
1568 static int run_command_lines (const char *cmd, int argc, char *argv[])
1573 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1574 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1577 arguments = parse_string_list (argv[0]);
1578 r = guestfs_command_lines (g, arguments);
1579 if (r == NULL) return -1;
1585 static int run_stat (const char *cmd, int argc, char *argv[])
1587 struct guestfs_stat *r;
1590 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1591 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1595 r = guestfs_stat (g, path);
1596 if (r == NULL) return -1;
1602 static int run_lstat (const char *cmd, int argc, char *argv[])
1604 struct guestfs_stat *r;
1607 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1608 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1612 r = guestfs_lstat (g, path);
1613 if (r == NULL) return -1;
1619 static int run_statvfs (const char *cmd, int argc, char *argv[])
1621 struct guestfs_statvfs *r;
1624 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1625 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1629 r = guestfs_statvfs (g, path);
1630 if (r == NULL) return -1;
1636 static int run_tune2fs_l (const char *cmd, int argc, char *argv[])
1641 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1642 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1646 r = guestfs_tune2fs_l (g, device);
1647 if (r == NULL) return -1;
1653 static int run_blockdev_setro (const char *cmd, int argc, char *argv[])
1658 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1659 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1663 r = guestfs_blockdev_setro (g, device);
1667 static int run_blockdev_setrw (const char *cmd, int argc, char *argv[])
1672 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1673 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1677 r = guestfs_blockdev_setrw (g, device);
1681 static int run_blockdev_getro (const char *cmd, int argc, char *argv[])
1686 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1687 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1691 r = guestfs_blockdev_getro (g, device);
1692 if (r == -1) return -1;
1693 if (r) printf ("true\n"); else printf ("false\n");
1697 static int run_blockdev_getss (const char *cmd, int argc, char *argv[])
1702 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1703 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1707 r = guestfs_blockdev_getss (g, device);
1708 if (r == -1) return -1;
1713 static int run_blockdev_getbsz (const char *cmd, int argc, char *argv[])
1718 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1719 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1723 r = guestfs_blockdev_getbsz (g, device);
1724 if (r == -1) return -1;
1729 static int run_blockdev_setbsz (const char *cmd, int argc, char *argv[])
1735 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1736 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1740 blocksize = atoi (argv[1]);
1741 r = guestfs_blockdev_setbsz (g, device, blocksize);
1745 static int run_blockdev_getsz (const char *cmd, int argc, char *argv[])
1750 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1751 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1755 r = guestfs_blockdev_getsz (g, device);
1756 if (r == -1) return -1;
1757 printf ("%" PRIi64 "\n", r);
1761 static int run_blockdev_getsize64 (const char *cmd, int argc, char *argv[])
1766 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1767 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1771 r = guestfs_blockdev_getsize64 (g, device);
1772 if (r == -1) return -1;
1773 printf ("%" PRIi64 "\n", r);
1777 static int run_blockdev_flushbufs (const char *cmd, int argc, char *argv[])
1782 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1783 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1787 r = guestfs_blockdev_flushbufs (g, device);
1791 static int run_blockdev_rereadpt (const char *cmd, int argc, char *argv[])
1796 fprintf (stderr, "%s should have 1 parameter(s)\n", cmd);
1797 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1801 r = guestfs_blockdev_rereadpt (g, device);
1805 static int run_upload (const char *cmd, int argc, char *argv[])
1808 const char *filename;
1809 const char *remotefilename;
1811 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1812 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1815 filename = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
1816 remotefilename = argv[1];
1817 r = guestfs_upload (g, filename, remotefilename);
1821 static int run_download (const char *cmd, int argc, char *argv[])
1824 const char *remotefilename;
1825 const char *filename;
1827 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1828 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1831 remotefilename = argv[0];
1832 filename = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
1833 r = guestfs_download (g, remotefilename, filename);
1837 static int run_checksum (const char *cmd, int argc, char *argv[])
1840 const char *csumtype;
1843 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1844 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1849 r = guestfs_checksum (g, csumtype, path);
1850 if (r == NULL) return -1;
1856 static int run_tar_in (const char *cmd, int argc, char *argv[])
1859 const char *tarfile;
1860 const char *directory;
1862 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1863 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1866 tarfile = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
1867 directory = argv[1];
1868 r = guestfs_tar_in (g, tarfile, directory);
1872 static int run_tar_out (const char *cmd, int argc, char *argv[])
1875 const char *directory;
1876 const char *tarfile;
1878 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1879 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1882 directory = argv[0];
1883 tarfile = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
1884 r = guestfs_tar_out (g, directory, tarfile);
1888 static int run_tgz_in (const char *cmd, int argc, char *argv[])
1891 const char *tarball;
1892 const char *directory;
1894 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1895 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1898 tarball = strcmp (argv[0], "-") != 0 ? argv[0] : "/dev/stdin";
1899 directory = argv[1];
1900 r = guestfs_tgz_in (g, tarball, directory);
1904 static int run_tgz_out (const char *cmd, int argc, char *argv[])
1907 const char *directory;
1908 const char *tarball;
1910 fprintf (stderr, "%s should have 2 parameter(s)\n", cmd);
1911 fprintf (stderr, "type 'help %s' for help on %s\n", cmd, cmd);
1914 directory = argv[0];
1915 tarball = strcmp (argv[1], "-") != 0 ? argv[1] : "/dev/stdout";
1916 r = guestfs_tgz_out (g, directory, tarball);
1920 int run_action (const char *cmd, int argc, char *argv[])
1922 if (strcasecmp (cmd, "launch") == 0 || strcasecmp (cmd, "run") == 0)
1923 return run_launch (cmd, argc, argv);
1925 if (strcasecmp (cmd, "kill_subprocess") == 0 || strcasecmp (cmd, "kill-subprocess") == 0)
1926 return run_kill_subprocess (cmd, argc, argv);
1928 if (strcasecmp (cmd, "add_drive") == 0 || strcasecmp (cmd, "add-drive") == 0 || strcasecmp (cmd, "add") == 0)
1929 return run_add_drive (cmd, argc, argv);
1931 if (strcasecmp (cmd, "add_cdrom") == 0 || strcasecmp (cmd, "add-cdrom") == 0 || strcasecmp (cmd, "cdrom") == 0)
1932 return run_add_cdrom (cmd, argc, argv);
1934 if (strcasecmp (cmd, "config") == 0)
1935 return run_config (cmd, argc, argv);
1937 if (strcasecmp (cmd, "set_qemu") == 0 || strcasecmp (cmd, "set-qemu") == 0 || strcasecmp (cmd, "qemu") == 0)
1938 return run_set_qemu (cmd, argc, argv);
1940 if (strcasecmp (cmd, "get_qemu") == 0 || strcasecmp (cmd, "get-qemu") == 0)
1941 return run_get_qemu (cmd, argc, argv);
1943 if (strcasecmp (cmd, "set_path") == 0 || strcasecmp (cmd, "set-path") == 0 || strcasecmp (cmd, "path") == 0)
1944 return run_set_path (cmd, argc, argv);
1946 if (strcasecmp (cmd, "get_path") == 0 || strcasecmp (cmd, "get-path") == 0)
1947 return run_get_path (cmd, argc, argv);
1949 if (strcasecmp (cmd, "set_autosync") == 0 || strcasecmp (cmd, "set-autosync") == 0 || strcasecmp (cmd, "autosync") == 0)
1950 return run_set_autosync (cmd, argc, argv);
1952 if (strcasecmp (cmd, "get_autosync") == 0 || strcasecmp (cmd, "get-autosync") == 0)
1953 return run_get_autosync (cmd, argc, argv);
1955 if (strcasecmp (cmd, "set_verbose") == 0 || strcasecmp (cmd, "set-verbose") == 0 || strcasecmp (cmd, "verbose") == 0)
1956 return run_set_verbose (cmd, argc, argv);
1958 if (strcasecmp (cmd, "get_verbose") == 0 || strcasecmp (cmd, "get-verbose") == 0)
1959 return run_get_verbose (cmd, argc, argv);
1961 if (strcasecmp (cmd, "is_ready") == 0 || strcasecmp (cmd, "is-ready") == 0)
1962 return run_is_ready (cmd, argc, argv);
1964 if (strcasecmp (cmd, "is_config") == 0 || strcasecmp (cmd, "is-config") == 0)
1965 return run_is_config (cmd, argc, argv);
1967 if (strcasecmp (cmd, "is_launching") == 0 || strcasecmp (cmd, "is-launching") == 0)
1968 return run_is_launching (cmd, argc, argv);
1970 if (strcasecmp (cmd, "is_busy") == 0 || strcasecmp (cmd, "is-busy") == 0)
1971 return run_is_busy (cmd, argc, argv);
1973 if (strcasecmp (cmd, "get_state") == 0 || strcasecmp (cmd, "get-state") == 0)
1974 return run_get_state (cmd, argc, argv);
1976 if (strcasecmp (cmd, "mount") == 0)
1977 return run_mount (cmd, argc, argv);
1979 if (strcasecmp (cmd, "sync") == 0)
1980 return run_sync (cmd, argc, argv);
1982 if (strcasecmp (cmd, "touch") == 0)
1983 return run_touch (cmd, argc, argv);
1985 if (strcasecmp (cmd, "cat") == 0)
1986 return run_cat (cmd, argc, argv);
1988 if (strcasecmp (cmd, "ll") == 0)
1989 return run_ll (cmd, argc, argv);
1991 if (strcasecmp (cmd, "ls") == 0)
1992 return run_ls (cmd, argc, argv);
1994 if (strcasecmp (cmd, "list_devices") == 0 || strcasecmp (cmd, "list-devices") == 0)
1995 return run_list_devices (cmd, argc, argv);
1997 if (strcasecmp (cmd, "list_partitions") == 0 || strcasecmp (cmd, "list-partitions") == 0)
1998 return run_list_partitions (cmd, argc, argv);
2000 if (strcasecmp (cmd, "pvs") == 0)
2001 return run_pvs (cmd, argc, argv);
2003 if (strcasecmp (cmd, "vgs") == 0)
2004 return run_vgs (cmd, argc, argv);
2006 if (strcasecmp (cmd, "lvs") == 0)
2007 return run_lvs (cmd, argc, argv);
2009 if (strcasecmp (cmd, "pvs_full") == 0 || strcasecmp (cmd, "pvs-full") == 0)
2010 return run_pvs_full (cmd, argc, argv);
2012 if (strcasecmp (cmd, "vgs_full") == 0 || strcasecmp (cmd, "vgs-full") == 0)
2013 return run_vgs_full (cmd, argc, argv);
2015 if (strcasecmp (cmd, "lvs_full") == 0 || strcasecmp (cmd, "lvs-full") == 0)
2016 return run_lvs_full (cmd, argc, argv);
2018 if (strcasecmp (cmd, "read_lines") == 0 || strcasecmp (cmd, "read-lines") == 0)
2019 return run_read_lines (cmd, argc, argv);
2021 if (strcasecmp (cmd, "aug_init") == 0 || strcasecmp (cmd, "aug-init") == 0)
2022 return run_aug_init (cmd, argc, argv);
2024 if (strcasecmp (cmd, "aug_close") == 0 || strcasecmp (cmd, "aug-close") == 0)
2025 return run_aug_close (cmd, argc, argv);
2027 if (strcasecmp (cmd, "aug_defvar") == 0 || strcasecmp (cmd, "aug-defvar") == 0)
2028 return run_aug_defvar (cmd, argc, argv);
2030 if (strcasecmp (cmd, "aug_defnode") == 0 || strcasecmp (cmd, "aug-defnode") == 0)
2031 return run_aug_defnode (cmd, argc, argv);
2033 if (strcasecmp (cmd, "aug_get") == 0 || strcasecmp (cmd, "aug-get") == 0)
2034 return run_aug_get (cmd, argc, argv);
2036 if (strcasecmp (cmd, "aug_set") == 0 || strcasecmp (cmd, "aug-set") == 0)
2037 return run_aug_set (cmd, argc, argv);
2039 if (strcasecmp (cmd, "aug_insert") == 0 || strcasecmp (cmd, "aug-insert") == 0)
2040 return run_aug_insert (cmd, argc, argv);
2042 if (strcasecmp (cmd, "aug_rm") == 0 || strcasecmp (cmd, "aug-rm") == 0)
2043 return run_aug_rm (cmd, argc, argv);
2045 if (strcasecmp (cmd, "aug_mv") == 0 || strcasecmp (cmd, "aug-mv") == 0)
2046 return run_aug_mv (cmd, argc, argv);
2048 if (strcasecmp (cmd, "aug_match") == 0 || strcasecmp (cmd, "aug-match") == 0)
2049 return run_aug_match (cmd, argc, argv);
2051 if (strcasecmp (cmd, "aug_save") == 0 || strcasecmp (cmd, "aug-save") == 0)
2052 return run_aug_save (cmd, argc, argv);
2054 if (strcasecmp (cmd, "aug_load") == 0 || strcasecmp (cmd, "aug-load") == 0)
2055 return run_aug_load (cmd, argc, argv);
2057 if (strcasecmp (cmd, "aug_ls") == 0 || strcasecmp (cmd, "aug-ls") == 0)
2058 return run_aug_ls (cmd, argc, argv);
2060 if (strcasecmp (cmd, "rm") == 0)
2061 return run_rm (cmd, argc, argv);
2063 if (strcasecmp (cmd, "rmdir") == 0)
2064 return run_rmdir (cmd, argc, argv);
2066 if (strcasecmp (cmd, "rm_rf") == 0 || strcasecmp (cmd, "rm-rf") == 0)
2067 return run_rm_rf (cmd, argc, argv);
2069 if (strcasecmp (cmd, "mkdir") == 0)
2070 return run_mkdir (cmd, argc, argv);
2072 if (strcasecmp (cmd, "mkdir_p") == 0 || strcasecmp (cmd, "mkdir-p") == 0)
2073 return run_mkdir_p (cmd, argc, argv);
2075 if (strcasecmp (cmd, "chmod") == 0)
2076 return run_chmod (cmd, argc, argv);
2078 if (strcasecmp (cmd, "chown") == 0)
2079 return run_chown (cmd, argc, argv);
2081 if (strcasecmp (cmd, "exists") == 0)
2082 return run_exists (cmd, argc, argv);
2084 if (strcasecmp (cmd, "is_file") == 0 || strcasecmp (cmd, "is-file") == 0)
2085 return run_is_file (cmd, argc, argv);
2087 if (strcasecmp (cmd, "is_dir") == 0 || strcasecmp (cmd, "is-dir") == 0)
2088 return run_is_dir (cmd, argc, argv);
2090 if (strcasecmp (cmd, "pvcreate") == 0)
2091 return run_pvcreate (cmd, argc, argv);
2093 if (strcasecmp (cmd, "vgcreate") == 0)
2094 return run_vgcreate (cmd, argc, argv);
2096 if (strcasecmp (cmd, "lvcreate") == 0)
2097 return run_lvcreate (cmd, argc, argv);
2099 if (strcasecmp (cmd, "mkfs") == 0)
2100 return run_mkfs (cmd, argc, argv);
2102 if (strcasecmp (cmd, "sfdisk") == 0)
2103 return run_sfdisk (cmd, argc, argv);
2105 if (strcasecmp (cmd, "write_file") == 0 || strcasecmp (cmd, "write-file") == 0)
2106 return run_write_file (cmd, argc, argv);
2108 if (strcasecmp (cmd, "umount") == 0 || strcasecmp (cmd, "unmount") == 0)
2109 return run_umount (cmd, argc, argv);
2111 if (strcasecmp (cmd, "mounts") == 0)
2112 return run_mounts (cmd, argc, argv);
2114 if (strcasecmp (cmd, "umount_all") == 0 || strcasecmp (cmd, "umount-all") == 0 || strcasecmp (cmd, "unmount-all") == 0)
2115 return run_umount_all (cmd, argc, argv);
2117 if (strcasecmp (cmd, "lvm_remove_all") == 0 || strcasecmp (cmd, "lvm-remove-all") == 0)
2118 return run_lvm_remove_all (cmd, argc, argv);
2120 if (strcasecmp (cmd, "file") == 0)
2121 return run_file (cmd, argc, argv);
2123 if (strcasecmp (cmd, "command") == 0)
2124 return run_command (cmd, argc, argv);
2126 if (strcasecmp (cmd, "command_lines") == 0 || strcasecmp (cmd, "command-lines") == 0)
2127 return run_command_lines (cmd, argc, argv);
2129 if (strcasecmp (cmd, "stat") == 0)
2130 return run_stat (cmd, argc, argv);
2132 if (strcasecmp (cmd, "lstat") == 0)
2133 return run_lstat (cmd, argc, argv);
2135 if (strcasecmp (cmd, "statvfs") == 0)
2136 return run_statvfs (cmd, argc, argv);
2138 if (strcasecmp (cmd, "tune2fs_l") == 0 || strcasecmp (cmd, "tune2fs-l") == 0)
2139 return run_tune2fs_l (cmd, argc, argv);
2141 if (strcasecmp (cmd, "blockdev_setro") == 0 || strcasecmp (cmd, "blockdev-setro") == 0)
2142 return run_blockdev_setro (cmd, argc, argv);
2144 if (strcasecmp (cmd, "blockdev_setrw") == 0 || strcasecmp (cmd, "blockdev-setrw") == 0)
2145 return run_blockdev_setrw (cmd, argc, argv);
2147 if (strcasecmp (cmd, "blockdev_getro") == 0 || strcasecmp (cmd, "blockdev-getro") == 0)
2148 return run_blockdev_getro (cmd, argc, argv);
2150 if (strcasecmp (cmd, "blockdev_getss") == 0 || strcasecmp (cmd, "blockdev-getss") == 0)
2151 return run_blockdev_getss (cmd, argc, argv);
2153 if (strcasecmp (cmd, "blockdev_getbsz") == 0 || strcasecmp (cmd, "blockdev-getbsz") == 0)
2154 return run_blockdev_getbsz (cmd, argc, argv);
2156 if (strcasecmp (cmd, "blockdev_setbsz") == 0 || strcasecmp (cmd, "blockdev-setbsz") == 0)
2157 return run_blockdev_setbsz (cmd, argc, argv);
2159 if (strcasecmp (cmd, "blockdev_getsz") == 0 || strcasecmp (cmd, "blockdev-getsz") == 0)
2160 return run_blockdev_getsz (cmd, argc, argv);
2162 if (strcasecmp (cmd, "blockdev_getsize64") == 0 || strcasecmp (cmd, "blockdev-getsize64") == 0)
2163 return run_blockdev_getsize64 (cmd, argc, argv);
2165 if (strcasecmp (cmd, "blockdev_flushbufs") == 0 || strcasecmp (cmd, "blockdev-flushbufs") == 0)
2166 return run_blockdev_flushbufs (cmd, argc, argv);
2168 if (strcasecmp (cmd, "blockdev_rereadpt") == 0 || strcasecmp (cmd, "blockdev-rereadpt") == 0)
2169 return run_blockdev_rereadpt (cmd, argc, argv);
2171 if (strcasecmp (cmd, "upload") == 0)
2172 return run_upload (cmd, argc, argv);
2174 if (strcasecmp (cmd, "download") == 0)
2175 return run_download (cmd, argc, argv);
2177 if (strcasecmp (cmd, "checksum") == 0)
2178 return run_checksum (cmd, argc, argv);
2180 if (strcasecmp (cmd, "tar_in") == 0 || strcasecmp (cmd, "tar-in") == 0)
2181 return run_tar_in (cmd, argc, argv);
2183 if (strcasecmp (cmd, "tar_out") == 0 || strcasecmp (cmd, "tar-out") == 0)
2184 return run_tar_out (cmd, argc, argv);
2186 if (strcasecmp (cmd, "tgz_in") == 0 || strcasecmp (cmd, "tgz-in") == 0)
2187 return run_tgz_in (cmd, argc, argv);
2189 if (strcasecmp (cmd, "tgz_out") == 0 || strcasecmp (cmd, "tgz-out") == 0)
2190 return run_tgz_out (cmd, argc, argv);
2193 fprintf (stderr, "%s: unknown command\n", cmd);