---
tools/virsh.c | 13 ++++++++++++-
tools/virsh.pod | 11 ++++++++++-
2 files changed, 22 insertions(+), 2 deletions(-)
diff --git a/tools/virsh.c b/tools/virsh.c
index 863b2de..f9e2fd4 100644
--- a/tools/virsh.c
+++ b/tools/virsh.c
@@ -6183,6 +6183,8 @@ static const vshCmdInfo info_pool_build[] = {
static const vshCmdOptDef opts_pool_build[] = {
{"pool", VSH_OT_DATA, VSH_OFLAG_REQ, N_("pool name or uuid")},
+ {"no-overwrite", VSH_OT_BOOL, 0, N_("do not overwrite an existing pool
of this type")},
+ {"overwrite", VSH_OT_BOOL, 0, N_("overwrite any existing
data")},
{NULL, 0, 0, NULL}
};
@@ -6192,6 +6194,7 @@ cmdPoolBuild(vshControl *ctl, const vshCmd *cmd)
virStoragePoolPtr pool;
bool ret = true;
const char *name;
+ unsigned int flags = 0;
if (!vshConnectionUsability(ctl, ctl->conn))
return false;
@@ -6199,7 +6202,15 @@ cmdPoolBuild(vshControl *ctl, const vshCmd *cmd)
if (!(pool = vshCommandOptPool(ctl, cmd, "pool", &name)))
return false;
- if (virStoragePoolBuild(pool, 0) == 0) {
+ if (vshCommandOptBool (cmd, "no-overwrite")) {
+ flags |= VIR_STORAGE_POOL_BUILD_NO_OVERWRITE;
+ }
+
+ if (vshCommandOptBool (cmd, "overwrite")) {
+ flags |= VIR_STORAGE_POOL_BUILD_OVERWRITE;
+ }
+
+ if (virStoragePoolBuild(pool, flags) == 0) {
vshPrint(ctl, _("Pool %s built\n"), name);
} else {
vshError(ctl, _("Failed to build pool %s"), name);
diff --git a/tools/virsh.pod b/tools/virsh.pod
index 50571cd..0ee8bbc 100644
--- a/tools/virsh.pod
+++ b/tools/virsh.pod
@@ -1084,10 +1084,19 @@ query is performed.
Configure whether I<pool> should automatically start at boot.
-=item B<pool-build> I<pool-or-uuid>
+=item B<pool-build> I<pool-or-uuid> optional I<--overwrite>
Build a given pool.
+Options I<--overwrite> and I<--no-overwrite> can only be used for
+B<pool-build> a filesystem pool. If neither of them is specified,
+B<pool-build> on a filesystem pool only makes the directory; If
+I<--no-overwrite> is specified, it probes to determine if a
+filesystem already exists on the target device, returning an error
+if exists, or using mkfs to format the target device if not; If
+I<--overwrite> is specified, mkfs is always executed, any existed
+data on the target device is overwritten unconditionally.
+
=item B<pool-create> I<file>
Create and start a pool object from the XML I<file>.
--
1.7.4