mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-10 05:17:59 +03:00
hellolibvirt: Adjust code to use new APIs
Change the order of some conditions and use the AllDomains API to get a list of all the active and defined domains, then use the Active and Name API's in order to print. This changes here adjust the output from: Attempting to connect to hypervisor Connected to hypervisor at "qemu:///system" Hypervisor: "QEMU" version: 0.32.656 There are 0 active and 2 inactive domains Inactive domains: foo bar Disconnected from hypervisor to Attempting to connect to hypervisor Connected to hypervisor at "qemu:///system" Hypervisor: "QEMU" version: 0.32.656 There are 0 active and 2 inactive domains foo (non-active) bar (non-active) Disconnected from hypervisor
This commit is contained in:
parent
f7e7429416
commit
b421c35c98
@ -1,5 +1,6 @@
|
||||
/* This file contains trivial example code to connect to the running
|
||||
* hypervisor and gather a few bits of information. */
|
||||
* hypervisor and gather a few bits of information about domains.
|
||||
* Similar API's exist for storage pools, networks, and interfaces. */
|
||||
|
||||
#include <config.h>
|
||||
|
||||
@ -15,7 +16,7 @@ showError(virConnectPtr conn)
|
||||
virErrorPtr err;
|
||||
|
||||
err = malloc(sizeof(*err));
|
||||
if (NULL == err) {
|
||||
if (!err) {
|
||||
printf("Could not allocate memory for error data\n");
|
||||
goto out;
|
||||
}
|
||||
@ -56,7 +57,7 @@ showHypervisorInfo(virConnectPtr conn)
|
||||
* to fail if, for example, there is no connection to a
|
||||
* hypervisor, so check what it returns. */
|
||||
hvType = virConnectGetType(conn);
|
||||
if (NULL == hvType) {
|
||||
if (!hvType) {
|
||||
ret = 1;
|
||||
printf("Failed to get hypervisor type\n");
|
||||
showError(conn);
|
||||
@ -90,10 +91,16 @@ static int
|
||||
showDomains(virConnectPtr conn)
|
||||
{
|
||||
int ret = 0, i, numNames, numInactiveDomains, numActiveDomains;
|
||||
char **nameList = NULL;
|
||||
int flags = VIR_CONNECT_LIST_DOMAINS_ACTIVE |
|
||||
VIR_CONNECT_LIST_DOMAINS_INACTIVE;
|
||||
virDomainPtr *nameList = NULL;
|
||||
|
||||
/* NB: The return from the virConnectNum*() APIs is only useful for
|
||||
* the current call. A domain could be started or stopped and any
|
||||
* assumptions made purely on these return values could result in
|
||||
* unexpected results */
|
||||
numActiveDomains = virConnectNumOfDomains(conn);
|
||||
if (-1 == numActiveDomains) {
|
||||
if (numActiveDomains == -1) {
|
||||
ret = 1;
|
||||
printf("Failed to get number of active domains\n");
|
||||
showError(conn);
|
||||
@ -101,7 +108,7 @@ showDomains(virConnectPtr conn)
|
||||
}
|
||||
|
||||
numInactiveDomains = virConnectNumOfDefinedDomains(conn);
|
||||
if (-1 == numInactiveDomains) {
|
||||
if (numInactiveDomains == -1) {
|
||||
ret = 1;
|
||||
printf("Failed to get number of inactive domains\n");
|
||||
showError(conn);
|
||||
@ -111,39 +118,24 @@ showDomains(virConnectPtr conn)
|
||||
printf("There are %d active and %d inactive domains\n",
|
||||
numActiveDomains, numInactiveDomains);
|
||||
|
||||
nameList = malloc(sizeof(*nameList) * numInactiveDomains);
|
||||
|
||||
if (NULL == nameList) {
|
||||
ret = 1;
|
||||
printf("Could not allocate memory for list of inactive domains\n");
|
||||
goto out;
|
||||
}
|
||||
|
||||
numNames = virConnectListDefinedDomains(conn,
|
||||
nameList,
|
||||
numInactiveDomains);
|
||||
|
||||
if (-1 == numNames) {
|
||||
ret = 1;
|
||||
printf("Could not get list of defined domains from hypervisor\n");
|
||||
showError(conn);
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (numNames > 0) {
|
||||
printf("Inactive domains:\n");
|
||||
}
|
||||
|
||||
for (i = 0 ; i < numNames ; i++) {
|
||||
printf(" %s\n", *(nameList + i));
|
||||
/* The API documentation doesn't say so, but the names
|
||||
* returned by virConnectListDefinedDomains are strdup'd and
|
||||
* must be freed here. */
|
||||
free(*(nameList + i));
|
||||
/* Return a list of all active and inactive domains. Using this API
|
||||
* instead of virConnectListDomains() and virConnectListDefinedDomains()
|
||||
* is preferred since it "solves" an inherit race between separated API
|
||||
* calls if domains are started or stopped between calls */
|
||||
numNames = virConnectListAllDomains(conn,
|
||||
&nameList,
|
||||
flags);
|
||||
for (i = 0; i < numNames; i++) {
|
||||
int active = virDomainIsActive(nameList[i]);
|
||||
printf(" %8s (%s)\n",
|
||||
virDomainGetName(nameList[i]),
|
||||
(active == 1 ? "active" : "non-active"));
|
||||
/* must free the returned named per the API documentation */
|
||||
virDomainFree(nameList[i]);
|
||||
}
|
||||
free(nameList);
|
||||
|
||||
out:
|
||||
free(nameList);
|
||||
return ret;
|
||||
}
|
||||
|
||||
@ -163,7 +155,7 @@ main(int argc, char *argv[])
|
||||
* except, possibly, the URI of the hypervisor. */
|
||||
conn = virConnectOpenAuth(uri, virConnectAuthPtrDefault, 0);
|
||||
|
||||
if (NULL == conn) {
|
||||
if (!conn) {
|
||||
ret = 1;
|
||||
printf("No connection to hypervisor\n");
|
||||
showError(conn);
|
||||
@ -171,7 +163,7 @@ main(int argc, char *argv[])
|
||||
}
|
||||
|
||||
uri = virConnectGetURI(conn);
|
||||
if (NULL == uri) {
|
||||
if (!uri) {
|
||||
ret = 1;
|
||||
printf("Failed to get URI for hypervisor connection\n");
|
||||
showError(conn);
|
||||
|
Loading…
Reference in New Issue
Block a user