]> git.ipfire.org Git - thirdparty/libvirt.git/commitdiff
vbox: Rewrite vboxDomainLookupById
authorTaowei <uaedante@gmail.com>
Mon, 11 Aug 2014 10:06:16 +0000 (18:06 +0800)
committerMichal Privoznik <mprivozn@redhat.com>
Fri, 15 Aug 2014 07:25:10 +0000 (09:25 +0200)
src/vbox/vbox_common.c
src/vbox/vbox_tmpl.c
src/vbox/vbox_uniformed_api.h

index 3023fe600a81d4a172390b37c1aabb760fc3584a..d901b7f452d77f3d4506d0f2c896315bde3c1d17 100644 (file)
@@ -551,3 +551,76 @@ int vboxConnectNumOfDomains(virConnectPtr conn)
     gVBoxAPI.UArray.vboxArrayRelease(&machines);
     return ret;
 }
+
+virDomainPtr vboxDomainLookupByID(virConnectPtr conn, int id)
+{
+    VBOX_OBJECT_CHECK(conn, virDomainPtr, NULL);
+    vboxArray machines = VBOX_ARRAY_INITIALIZER;
+    IMachine *machine;
+    PRBool isAccessible = PR_FALSE;
+    PRUnichar *machineNameUtf16 = NULL;
+    char *machineNameUtf8  = NULL;
+    vboxIIDUnion iid;
+    unsigned char uuid[VIR_UUID_BUFLEN];
+    PRUint32 state;
+    nsresult rc;
+
+    VBOX_IID_INITIALIZE(&iid);
+    /* Internal vbox IDs start from 0, the public libvirt ID
+     * starts from 1, so refuse id == 0, and adjust the rest*/
+    if (id == 0) {
+        virReportError(VIR_ERR_NO_DOMAIN,
+                       _("no domain with matching id %d"), id);
+        return NULL;
+    }
+    id = id - 1;
+
+    rc = gVBoxAPI.UArray.vboxArrayGet(&machines, data->vboxObj, ARRAY_GET_MACHINES);
+    if (NS_FAILED(rc)) {
+        virReportError(VIR_ERR_INTERNAL_ERROR,
+                       _("Could not get list of machines, rc=%08x"), (unsigned)rc);
+        return NULL;
+    }
+
+    if (id >= machines.count)
+        goto cleanup;
+
+    machine = machines.items[id];
+
+    if (!machine)
+        goto cleanup;
+
+    isAccessible = PR_FALSE;
+    gVBoxAPI.UIMachine.GetAccessible(machine, &isAccessible);
+    if (!isAccessible)
+        goto cleanup;
+
+    gVBoxAPI.UIMachine.GetState(machine, &state);
+    if (!gVBoxAPI.machineStateChecker.Online(state))
+        goto cleanup;
+
+    gVBoxAPI.UIMachine.GetName(machine, &machineNameUtf16);
+    VBOX_UTF16_TO_UTF8(machineNameUtf16, &machineNameUtf8);
+
+    gVBoxAPI.UIMachine.GetId(machine, &iid);
+    vboxIIDToUUID(&iid, uuid);
+    vboxIIDUnalloc(&iid);
+
+    /* get a new domain pointer from virGetDomain, if it fails
+     * then no need to assign the id, else assign the id, cause
+     * it is -1 by default. rest is taken care by virGetDomain
+     * itself, so need not worry.
+     */
+
+    ret = virGetDomain(conn, machineNameUtf8, uuid);
+    if (ret)
+        ret->id = id + 1;
+
+    /* Cleanup all the XPCOM allocated stuff here */
+    VBOX_UTF8_FREE(machineNameUtf8);
+    VBOX_UTF16_FREE(machineNameUtf16);
+
+ cleanup:
+    gVBoxAPI.UArray.vboxArrayRelease(&machines);
+    return ret;
+}
index 8a00041212024eca428c4c6db50216ed42c215ec..96a0285c63af8e530c3c9cd9a6a4b11ce98d3f86 100644 (file)
@@ -949,74 +949,6 @@ static virDomainPtr vboxDomainCreateXML(virConnectPtr conn, const char *xml,
     return dom;
 }
 
-static virDomainPtr vboxDomainLookupByID(virConnectPtr conn, int id)
-{
-    VBOX_OBJECT_CHECK(conn, virDomainPtr, NULL);
-    vboxArray machines = VBOX_ARRAY_INITIALIZER;
-    vboxIID iid = VBOX_IID_INITIALIZER;
-    unsigned char uuid[VIR_UUID_BUFLEN];
-    PRUint32 state;
-    nsresult rc;
-
-    /* Internal vbox IDs start from 0, the public libvirt ID
-     * starts from 1, so refuse id == 0, and adjust the rest*/
-    if (id == 0) {
-        virReportError(VIR_ERR_NO_DOMAIN,
-                       _("no domain with matching id %d"), id);
-        return NULL;
-    }
-    id = id - 1;
-
-    rc = vboxArrayGet(&machines, data->vboxObj, data->vboxObj->vtbl->GetMachines);
-    if (NS_FAILED(rc)) {
-        virReportError(VIR_ERR_INTERNAL_ERROR,
-                       _("Could not get list of machines, rc=%08x"), (unsigned)rc);
-        return NULL;
-    }
-
-    if (id < machines.count) {
-        IMachine *machine = machines.items[id];
-
-        if (machine) {
-            PRBool isAccessible = PR_FALSE;
-            machine->vtbl->GetAccessible(machine, &isAccessible);
-            if (isAccessible) {
-                machine->vtbl->GetState(machine, &state);
-                if ((state >= MachineState_FirstOnline) &&
-                    (state <= MachineState_LastOnline)) {
-                    PRUnichar *machineNameUtf16 = NULL;
-                    char      *machineNameUtf8  = NULL;
-
-                    machine->vtbl->GetName(machine, &machineNameUtf16);
-                    VBOX_UTF16_TO_UTF8(machineNameUtf16, &machineNameUtf8);
-
-                    machine->vtbl->GetId(machine, &iid.value);
-                    vboxIIDToUUID(&iid, uuid);
-                    vboxIIDUnalloc(&iid);
-
-                    /* get a new domain pointer from virGetDomain, if it fails
-                     * then no need to assign the id, else assign the id, cause
-                     * it is -1 by default. rest is taken care by virGetDomain
-                     * itself, so need not worry.
-                     */
-
-                    ret = virGetDomain(conn, machineNameUtf8, uuid);
-                    if (ret)
-                        ret->id = id + 1;
-
-                    /* Cleanup all the XPCOM allocated stuff here */
-                    VBOX_UTF8_FREE(machineNameUtf8);
-                    VBOX_UTF16_FREE(machineNameUtf16);
-                }
-            }
-        }
-    }
-
-    vboxArrayRelease(&machines);
-
-    return ret;
-}
-
 static virDomainPtr
 vboxDomainLookupByUUID(virConnectPtr conn, const unsigned char *uuid)
 {
@@ -11267,6 +11199,18 @@ _machineGetState(IMachine *machine, PRUint32 *state)
     return machine->vtbl->GetState(machine, state);
 }
 
+static nsresult
+_machineGetName(IMachine *machine, PRUnichar **name)
+{
+    return machine->vtbl->GetName(machine, name);
+}
+
+static nsresult
+_machineGetId(IMachine *machine, vboxIIDUnion *iidu)
+{
+    return machine->vtbl->GetId(machine, &IID_MEMBER(value));
+}
+
 #if VBOX_API_VERSION < 4000000
 
 static nsresult
@@ -11376,6 +11320,8 @@ static vboxUniformedIVirtualBox _UIVirtualBox = {
 static vboxUniformedIMachine _UIMachine = {
     .GetAccessible = _machineGetAccessible,
     .GetState = _machineGetState,
+    .GetName = _machineGetName,
+    .GetId = _machineGetId,
 };
 
 static vboxUniformedISession _UISession = {
index 0b95459156d3317e8dddaa16b8eca80c441c91a3..26aec7637803785b2bd4b2d38382eabb301c8287 100644 (file)
@@ -186,6 +186,8 @@ typedef struct {
 typedef struct {
     nsresult (*GetAccessible)(IMachine *machine, PRBool *isAccessible);
     nsresult (*GetState)(IMachine *machine, PRUint32 *state);
+    nsresult (*GetName)(IMachine *machine, PRUnichar **name);
+    nsresult (*GetId)(IMachine *machine, vboxIIDUnion *iidu);
 } vboxUniformedIMachine;
 
 /* Functions for ISession */
@@ -257,6 +259,7 @@ int vboxConnectGetMaxVcpus(virConnectPtr conn, const char *type);
 char *vboxConnectGetCapabilities(virConnectPtr conn);
 int vboxConnectListDomains(virConnectPtr conn, int *ids, int nids);
 int vboxConnectNumOfDomains(virConnectPtr conn);
+virDomainPtr vboxDomainLookupByID(virConnectPtr conn, int id);
 
 /* Version specified functions for installing uniformed API */
 void vbox22InstallUniformedAPI(vboxUniformedAPI *pVBoxAPI);