mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-03 11:35:19 +00:00
virsh: Move cmdConnect from virsh-host.c to virsh.c
The function is used to establish connection so it should be in the main virsh file. This movement also enables further improvements done in next patches. Note that the "connect" command has moved from the host section of virsh to the main section. It is now listed by 'virsh help virsh' instead of 'virsh help host'.
This commit is contained in:
parent
e964ba2786
commit
ca9e73ebb6
@ -67,67 +67,6 @@ cmdCapabilities(vshControl *ctl, const vshCmd *cmd ATTRIBUTE_UNUSED)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* "connect" command
|
|
||||||
*/
|
|
||||||
static const vshCmdInfo info_connect[] = {
|
|
||||||
{.name = "help",
|
|
||||||
.data = N_("(re)connect to hypervisor")
|
|
||||||
},
|
|
||||||
{.name = "desc",
|
|
||||||
.data = N_("Connect to local hypervisor. This is built-in "
|
|
||||||
"command after shell start up.")
|
|
||||||
},
|
|
||||||
{.name = NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static const vshCmdOptDef opts_connect[] = {
|
|
||||||
{.name = "name",
|
|
||||||
.type = VSH_OT_DATA,
|
|
||||||
.flags = VSH_OFLAG_EMPTY_OK,
|
|
||||||
.help = N_("hypervisor connection URI")
|
|
||||||
},
|
|
||||||
{.name = "readonly",
|
|
||||||
.type = VSH_OT_BOOL,
|
|
||||||
.help = N_("read-only connection")
|
|
||||||
},
|
|
||||||
{.name = NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static bool
|
|
||||||
cmdConnect(vshControl *ctl, const vshCmd *cmd)
|
|
||||||
{
|
|
||||||
bool ro = vshCommandOptBool(cmd, "readonly");
|
|
||||||
const char *name = NULL;
|
|
||||||
|
|
||||||
if (ctl->conn) {
|
|
||||||
int ret;
|
|
||||||
if ((ret = virConnectClose(ctl->conn)) != 0) {
|
|
||||||
vshError(ctl, _("Failed to disconnect from the hypervisor, %d leaked reference(s)"), ret);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
ctl->conn = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
VIR_FREE(ctl->name);
|
|
||||||
if (vshCommandOptStringReq(ctl, cmd, "name", &name) < 0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
ctl->name = vshStrdup(ctl, name);
|
|
||||||
|
|
||||||
ctl->useGetInfo = false;
|
|
||||||
ctl->useSnapshotOld = false;
|
|
||||||
ctl->readonly = ro;
|
|
||||||
|
|
||||||
ctl->conn = virConnectOpenAuth(ctl->name, virConnectAuthPtrDefault,
|
|
||||||
ctl->readonly ? VIR_CONNECT_RO : 0);
|
|
||||||
|
|
||||||
if (!ctl->conn)
|
|
||||||
vshError(ctl, "%s", _("Failed to connect to the hypervisor"));
|
|
||||||
|
|
||||||
return !!ctl->conn;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* "freecell" command
|
* "freecell" command
|
||||||
*/
|
*/
|
||||||
@ -912,12 +851,6 @@ const vshCmdDef hostAndHypervisorCmds[] = {
|
|||||||
.info = info_capabilities,
|
.info = info_capabilities,
|
||||||
.flags = 0
|
.flags = 0
|
||||||
},
|
},
|
||||||
{.name = "connect",
|
|
||||||
.handler = cmdConnect,
|
|
||||||
.opts = opts_connect,
|
|
||||||
.info = info_connect,
|
|
||||||
.flags = VSH_CMD_FLAG_NOCONNECT
|
|
||||||
},
|
|
||||||
{.name = "freecell",
|
{.name = "freecell",
|
||||||
.handler = cmdFreecell,
|
.handler = cmdFreecell,
|
||||||
.opts = opts_freecell,
|
.opts = opts_freecell,
|
||||||
|
@ -355,6 +355,69 @@ vshReconnect(vshControl *ctl)
|
|||||||
ctl->useSnapshotOld = false;
|
ctl->useSnapshotOld = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* "connect" command
|
||||||
|
*/
|
||||||
|
static const vshCmdInfo info_connect[] = {
|
||||||
|
{.name = "help",
|
||||||
|
.data = N_("(re)connect to hypervisor")
|
||||||
|
},
|
||||||
|
{.name = "desc",
|
||||||
|
.data = N_("Connect to local hypervisor. This is built-in "
|
||||||
|
"command after shell start up.")
|
||||||
|
},
|
||||||
|
{.name = NULL}
|
||||||
|
};
|
||||||
|
|
||||||
|
static const vshCmdOptDef opts_connect[] = {
|
||||||
|
{.name = "name",
|
||||||
|
.type = VSH_OT_DATA,
|
||||||
|
.flags = VSH_OFLAG_EMPTY_OK,
|
||||||
|
.help = N_("hypervisor connection URI")
|
||||||
|
},
|
||||||
|
{.name = "readonly",
|
||||||
|
.type = VSH_OT_BOOL,
|
||||||
|
.help = N_("read-only connection")
|
||||||
|
},
|
||||||
|
{.name = NULL}
|
||||||
|
};
|
||||||
|
|
||||||
|
static bool
|
||||||
|
cmdConnect(vshControl *ctl, const vshCmd *cmd)
|
||||||
|
{
|
||||||
|
bool ro = vshCommandOptBool(cmd, "readonly");
|
||||||
|
const char *name = NULL;
|
||||||
|
|
||||||
|
if (ctl->conn) {
|
||||||
|
int ret;
|
||||||
|
if ((ret = virConnectClose(ctl->conn)) != 0) {
|
||||||
|
vshError(ctl, _("Failed to disconnect from the hypervisor, %d leaked reference(s)"), ret);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
ctl->conn = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
VIR_FREE(ctl->name);
|
||||||
|
if (vshCommandOptStringReq(ctl, cmd, "name", &name) < 0)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
ctl->name = vshStrdup(ctl, name);
|
||||||
|
|
||||||
|
ctl->useGetInfo = false;
|
||||||
|
ctl->useSnapshotOld = false;
|
||||||
|
ctl->readonly = ro;
|
||||||
|
|
||||||
|
ctl->conn = virConnectOpenAuth(ctl->name, virConnectAuthPtrDefault,
|
||||||
|
ctl->readonly ? VIR_CONNECT_RO : 0);
|
||||||
|
|
||||||
|
if (!ctl->conn)
|
||||||
|
vshError(ctl, "%s", _("Failed to connect to the hypervisor"));
|
||||||
|
|
||||||
|
return !!ctl->conn;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifndef WIN32
|
#ifndef WIN32
|
||||||
static void
|
static void
|
||||||
vshPrintRaw(vshControl *ctl, ...)
|
vshPrintRaw(vshControl *ctl, ...)
|
||||||
@ -3006,6 +3069,12 @@ static const vshCmdDef virshCmds[] = {
|
|||||||
.info = info_cd,
|
.info = info_cd,
|
||||||
.flags = VSH_CMD_FLAG_NOCONNECT
|
.flags = VSH_CMD_FLAG_NOCONNECT
|
||||||
},
|
},
|
||||||
|
{.name = "connect",
|
||||||
|
.handler = cmdConnect,
|
||||||
|
.opts = opts_connect,
|
||||||
|
.info = info_connect,
|
||||||
|
.flags = VSH_CMD_FLAG_NOCONNECT
|
||||||
|
},
|
||||||
{.name = "echo",
|
{.name = "echo",
|
||||||
.handler = cmdEcho,
|
.handler = cmdEcho,
|
||||||
.opts = opts_echo,
|
.opts = opts_echo,
|
||||||
|
Loading…
Reference in New Issue
Block a user