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

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