From 622ea8b6cfe8d2d171064549b9f9c842b1fc38a8 Mon Sep 17 00:00:00 2001 From: Martin Kletzander Date: Aug 29 2017 09:17:16 +0000 Subject: virsh: Honour --readonly with cmdConnect and no name Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1436042 Signed-off-by: Martin Kletzander --- diff --git a/tools/virsh.c b/tools/virsh.c index 94bb7ff..527c1a4 100644 --- a/tools/virsh.c +++ b/tools/virsh.c @@ -218,7 +218,13 @@ virshReconnect(vshControl *ctl, const char *name, bool readonly, bool force) { bool connected = false; virshControlPtr priv = ctl->privData; - bool ro = name ? readonly : priv->readonly; + + /* If the flag was not specified, then it depends on whether we are + * reconnecting to the current URI (in which case we want to keep the + * readonly flag as it was) or to a specified URI in which case it + * should stay false */ + if (!readonly && !name) + readonly = priv->readonly; if (priv->conn) { int ret; @@ -233,7 +239,7 @@ virshReconnect(vshControl *ctl, const char *name, bool readonly, bool force) "disconnect from the hypervisor")); } - priv->conn = virshConnect(ctl, name ? name : ctl->connname, ro); + priv->conn = virshConnect(ctl, name ? name : ctl->connname, readonly); if (!priv->conn) { if (disconnected)