Blame SOURCES/0006-ovirt-foreign-menu-Set-new-ISO-name-using-GTask-API.patch

48c875
From e7be486b866af394ca63edf339ec0f465b644137 Mon Sep 17 00:00:00 2001
48c875
From: "Eduardo Lima (Etrunko)" <etrunko@redhat.com>
48c875
Date: Fri, 13 Jan 2017 18:02:25 -0200
48c875
Subject: [PATCH 06/26] ovirt-foreign-menu: Set new ISO name using GTask API
48c875
48c875
This is done with the new ovirt_foreign_menu_set_current_iso_name_async
48c875
function.
48c875
48c875
Signed-off-by: Eduardo Lima (Etrunko) <etrunko@redhat.com>
48c875
---
48c875
 src/ovirt-foreign-menu.c | 117 ++++++++++++++++++++++++++++++++++-------------
48c875
 src/ovirt-foreign-menu.h |  10 ++++
48c875
 2 files changed, 96 insertions(+), 31 deletions(-)
48c875
48c875
diff --git a/src/ovirt-foreign-menu.c b/src/ovirt-foreign-menu.c
48c875
index a51f2c9..a422ebb 100644
48c875
--- a/src/ovirt-foreign-menu.c
48c875
+++ b/src/ovirt-foreign-menu.c
48c875
@@ -344,38 +344,102 @@ menu_item_set_active_no_signal(GtkMenuItem *menuitem,
48c875
 }
48c875
 
48c875
 
48c875
-static void updated_cdrom_cb(GObject *source_object,
48c875
-                             GAsyncResult *result,
48c875
-                             gpointer user_data)
48c875
+static void iso_name_set_cb(GObject *source_object,
48c875
+                            GAsyncResult *result,
48c875
+                            gpointer user_data)
48c875
 {
48c875
     GError *error = NULL;
48c875
-    OvirtForeignMenu *foreign_menu;
48c875
+    GTask *task = G_TASK(user_data);
48c875
+    OvirtForeignMenu *foreign_menu = OVIRT_FOREIGN_MENU(g_task_get_source_object(task));
48c875
     gboolean updated;
48c875
 
48c875
-    foreign_menu = OVIRT_FOREIGN_MENU(user_data);
48c875
     updated = ovirt_cdrom_update_finish(OVIRT_CDROM(source_object),
48c875
                                         result, &error);
48c875
-    g_debug("Finished updating cdrom content");
48c875
     if (updated) {
48c875
+        g_debug("Finished updating cdrom content: %s", foreign_menu->priv->next_iso_name);
48c875
         g_free(foreign_menu->priv->current_iso_name);
48c875
         foreign_menu->priv->current_iso_name = foreign_menu->priv->next_iso_name;
48c875
         foreign_menu->priv->next_iso_name = NULL;
48c875
-        g_object_notify(G_OBJECT(foreign_menu), "file");
48c875
+        g_task_return_boolean(task, TRUE);
48c875
+        goto end;
48c875
+    }
48c875
+
48c875
+    /* Reset old state back as we were not successful in switching to
48c875
+     * the new ISO */
48c875
+    g_debug("setting OvirtCdrom:file back to '%s'",
48c875
+            foreign_menu->priv->current_iso_name);
48c875
+    g_object_set(foreign_menu->priv->cdrom, "file",
48c875
+                 foreign_menu->priv->current_iso_name, NULL);
48c875
+    g_clear_pointer(&foreign_menu->priv->next_iso_name, g_free);
48c875
+
48c875
+    if (error != NULL) {
48c875
+        g_warning("failed to update cdrom resource: %s", error->message);
48c875
+        g_task_return_error(task, error);
48c875
     } else {
48c875
-        /* Reset old state back as we were not successful in switching to
48c875
-         * the new ISO */
48c875
-        const char *current_file = foreign_menu->priv->current_iso_name;
48c875
+        g_warn_if_reached();
48c875
+        g_task_return_new_error(task, OVIRT_ERROR, OVIRT_ERROR_FAILED,
48c875
+                                "failed to update cdrom resource");
48c875
+    }
48c875
 
48c875
-        if (error != NULL) {
48c875
-            g_warning("failed to update cdrom resource: %s", error->message);
48c875
-            g_clear_error(&error);
48c875
-        }
48c875
-        g_debug("setting OvirtCdrom:file back to '%s'",
48c875
-                current_file?current_file:NULL);
48c875
-        g_object_set(foreign_menu->priv->cdrom, "file", current_file, NULL);
48c875
+end:
48c875
+    g_object_unref(task);
48c875
+}
48c875
+
48c875
+
48c875
+void ovirt_foreign_menu_set_current_iso_name_async(OvirtForeignMenu *foreign_menu,
48c875
+                                                   const char *name,
48c875
+                                                   GCancellable *cancellable,
48c875
+                                                   GAsyncReadyCallback callback,
48c875
+                                                   gpointer user_data)
48c875
+{
48c875
+    GTask *task;
48c875
+
48c875
+    g_return_if_fail(foreign_menu->priv->cdrom != NULL);
48c875
+    g_return_if_fail(foreign_menu->priv->next_iso_name == NULL);
48c875
+
48c875
+    if (name) {
48c875
+        g_debug("Updating VM cdrom image to '%s'", name);
48c875
+        foreign_menu->priv->next_iso_name = g_strdup(name);
48c875
+    } else {
48c875
+        g_debug("Removing current cdrom image");
48c875
+        foreign_menu->priv->next_iso_name = NULL;
48c875
     }
48c875
 
48c875
-    g_clear_pointer(&foreign_menu->priv->next_iso_name, g_free);
48c875
+    g_object_set(foreign_menu->priv->cdrom,
48c875
+                 "file", name,
48c875
+                 NULL);
48c875
+
48c875
+    task = g_task_new(foreign_menu, cancellable, callback, user_data);
48c875
+    ovirt_cdrom_update_async(foreign_menu->priv->cdrom, TRUE,
48c875
+                             foreign_menu->priv->proxy, cancellable,
48c875
+                             iso_name_set_cb, task);
48c875
+}
48c875
+
48c875
+
48c875
+gboolean ovirt_foreign_menu_set_current_iso_name_finish(OvirtForeignMenu *foreign_menu,
48c875
+                                                        GAsyncResult *result,
48c875
+                                                        GError **error)
48c875
+{
48c875
+    g_return_val_if_fail(OVIRT_IS_FOREIGN_MENU(foreign_menu), FALSE);
48c875
+    return g_task_propagate_boolean(G_TASK(result), error);
48c875
+}
48c875
+
48c875
+
48c875
+static void
48c875
+ovirt_foreign_menu_iso_name_changed(GObject *source_object,
48c875
+                                    GAsyncResult *result,
48c875
+                                    gpointer user_data G_GNUC_UNUSED)
48c875
+{
48c875
+    OvirtForeignMenu *foreign_menu = OVIRT_FOREIGN_MENU(source_object);
48c875
+    GError *error = NULL;
48c875
+
48c875
+    if (!ovirt_foreign_menu_set_current_iso_name_finish(foreign_menu, result, &error)) {
48c875
+        g_warning(error ? error->message : "Failed to change CD");
48c875
+        g_clear_error(&error);
48c875
+        return;
48c875
+    }
48c875
+
48c875
+    g_object_notify(G_OBJECT(foreign_menu), "file");
48c875
 }
48c875
 
48c875
 
48c875
@@ -383,7 +447,7 @@ static void
48c875
 ovirt_foreign_menu_activate_item_cb(GtkMenuItem *menuitem, gpointer user_data)
48c875
 {
48c875
     OvirtForeignMenu *foreign_menu;
48c875
-    const char *iso_name;
48c875
+    const char *iso_name = NULL;
48c875
     gboolean checked;
48c875
 
48c875
     checked = gtk_check_menu_item_get_active(GTK_CHECK_MENU_ITEM(menuitem));
48c875
@@ -403,19 +467,10 @@ ovirt_foreign_menu_activate_item_cb(GtkMenuItem *menuitem, gpointer user_data)
48c875
 
48c875
     if (checked) {
48c875
         iso_name = gtk_menu_item_get_label(menuitem);
48c875
-        g_debug("Updating VM cdrom image to '%s'", iso_name);
48c875
-        foreign_menu->priv->next_iso_name = g_strdup(iso_name);
48c875
-    } else {
48c875
-        g_debug("Removing current cdrom image");
48c875
-        iso_name = NULL;
48c875
-        foreign_menu->priv->next_iso_name = NULL;
48c875
     }
48c875
-    g_object_set(foreign_menu->priv->cdrom,
48c875
-                 "file", iso_name,
48c875
-                 NULL);
48c875
-    ovirt_cdrom_update_async(foreign_menu->priv->cdrom, TRUE,
48c875
-                             foreign_menu->priv->proxy, NULL,
48c875
-                             updated_cdrom_cb, foreign_menu);
48c875
+    ovirt_foreign_menu_set_current_iso_name_async(foreign_menu, iso_name, NULL,
48c875
+                                                  ovirt_foreign_menu_iso_name_changed,
48c875
+                                                  menuitem);
48c875
 }
48c875
 
48c875
 
48c875
diff --git a/src/ovirt-foreign-menu.h b/src/ovirt-foreign-menu.h
48c875
index cf18b52..791d0f3 100644
48c875
--- a/src/ovirt-foreign-menu.h
48c875
+++ b/src/ovirt-foreign-menu.h
48c875
@@ -70,6 +70,16 @@ OvirtForeignMenu* ovirt_foreign_menu_new(OvirtProxy *proxy);
48c875
 OvirtForeignMenu *ovirt_foreign_menu_new_from_file(VirtViewerFile *self);
48c875
 void ovirt_foreign_menu_start(OvirtForeignMenu *menu);
48c875
 
48c875
+void ovirt_foreign_menu_set_current_iso_name_async(OvirtForeignMenu *foreign_menu,
48c875
+                                                   const char *name,
48c875
+                                                   GCancellable *cancellable,
48c875
+                                                   GAsyncReadyCallback callback,
48c875
+                                                   gpointer user_data);
48c875
+gboolean ovirt_foreign_menu_set_current_iso_name_finish(OvirtForeignMenu *foreign_menu,
48c875
+                                                        GAsyncResult *result,
48c875
+                                                        GError **error);
48c875
+
48c875
+
48c875
 GtkWidget *ovirt_foreign_menu_get_gtk_menu(OvirtForeignMenu *foreign_menu);
48c875
 
48c875
 G_END_DECLS
48c875
-- 
48c875
2.12.0
48c875