Blame SOURCES/0054-remote-viewer-remove-spice-controller.patch

d4f8b6
From cfcf554c54965761772afe10fba950e5f2fed536 Mon Sep 17 00:00:00 2001
d4f8b6
From: =?UTF-8?q?Marc-Andr=C3=A9=20Lureau?= <marcandre.lureau@redhat.com>
d4f8b6
Date: Fri, 23 Jun 2017 17:25:07 +0200
d4f8b6
Subject: [PATCH] remote-viewer: remove --spice-controller
d4f8b6
MIME-Version: 1.0
d4f8b6
Content-Type: text/plain; charset=UTF-8
d4f8b6
Content-Transfer-Encoding: 8bit
d4f8b6
d4f8b6
spice controller interface is being removed from spice-gtk.
d4f8b6
d4f8b6
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
d4f8b6
Reviewed-by: Victor Toso <victortoso@redhat.com>
d4f8b6
Signed-off-by: Victor Toso <victortoso@redhat.com>
d4f8b6
---
d4f8b6
 configure.ac                        |   3 +-
d4f8b6
 data/Makefile.am                    |   1 -
d4f8b6
 data/spice-xpi-client-remote-viewer |   6 -
d4f8b6
 data/virt-viewer.wxs.in             |  11 -
d4f8b6
 man/remote-viewer.pod               |   6 -
d4f8b6
 src/Makefile.am                     |   2 -
d4f8b6
 src/remote-viewer.c                 | 448 +---------------------------
d4f8b6
 7 files changed, 5 insertions(+), 472 deletions(-)
d4f8b6
 delete mode 100644 data/spice-xpi-client-remote-viewer
d4f8b6
d4f8b6
diff --git a/configure.ac b/configure.ac
d4f8b6
index 6ed5f8a..abdbdaf 100644
d4f8b6
--- a/configure.ac
d4f8b6
+++ b/configure.ac
d4f8b6
@@ -159,13 +159,12 @@ AC_ARG_WITH([spice-gtk],
d4f8b6
 AS_IF([test "x$with_spice_gtk" != "xno" && test "x$with_spice_gtk" != "xyes"],
d4f8b6
       [PKG_CHECK_EXISTS([spice-client-gtk-3.0 >= $SPICE_GTK_REQUIRED
d4f8b6
                          spice-client-glib-2.0 >= $SPICE_GTK_REQUIRED
d4f8b6
-                         spice-controller spice-protocol >= $SPICE_PROTOCOL_REQUIRED],
d4f8b6
+                         spice-protocol >= $SPICE_PROTOCOL_REQUIRED],
d4f8b6
                         [with_spice_gtk=yes], [with_spice_gtk=no])])
d4f8b6
 
d4f8b6
 AS_IF([test "x$with_spice_gtk" = "xyes"],
d4f8b6
       [PKG_CHECK_MODULES(SPICE_GTK, [spice-client-gtk-3.0 >= $SPICE_GTK_REQUIRED
d4f8b6
                                      spice-client-glib-2.0 >= $SPICE_GTK_REQUIRED])]
d4f8b6
-      [PKG_CHECK_MODULES(SPICE_CONTROLLER, [spice-controller])]
d4f8b6
       [PKG_CHECK_MODULES(SPICE_PROTOCOL, [spice-protocol >= $SPICE_PROTOCOL_REQUIRED])]
d4f8b6
       [AC_DEFINE([HAVE_SPICE_GTK], 1, [Have spice-gtk?])]
d4f8b6
 )
d4f8b6
diff --git a/data/Makefile.am b/data/Makefile.am
d4f8b6
index 55718d9..54be2b1 100644
d4f8b6
--- a/data/Makefile.am
d4f8b6
+++ b/data/Makefile.am
d4f8b6
@@ -3,7 +3,6 @@ CLEANFILES =
d4f8b6
 MANUFACTURER = Virt Manager Project
d4f8b6
 
d4f8b6
 EXTRA_DIST =					\
d4f8b6
-	spice-xpi-client-remote-viewer		\
d4f8b6
 	virt-viewer.wxs.in			\
d4f8b6
 	$(NULL)
d4f8b6
 
d4f8b6
diff --git a/data/spice-xpi-client-remote-viewer b/data/spice-xpi-client-remote-viewer
d4f8b6
deleted file mode 100644
d4f8b6
index 3109c66..0000000
d4f8b6
--- a/data/spice-xpi-client-remote-viewer
d4f8b6
+++ /dev/null
d4f8b6
@@ -1,6 +0,0 @@
d4f8b6
-#!/bin/sh
d4f8b6
-
d4f8b6
-logger -t spice "starting remote-viewer --spice-controller $@..."
d4f8b6
-env | logger -t spice
d4f8b6
-exec remote-viewer --spice-controller "$@" 2>&1 | logger -t spice
d4f8b6
-logger -t spice "remote-viewer execution failed"
d4f8b6
diff --git a/data/virt-viewer.wxs.in b/data/virt-viewer.wxs.in
d4f8b6
index 9838265..2047720 100644
d4f8b6
--- a/data/virt-viewer.wxs.in
d4f8b6
+++ b/data/virt-viewer.wxs.in
d4f8b6
@@ -55,16 +55,6 @@
d4f8b6
     <Condition Message="VirtViewer is already installed.">NOT NEWERVERSIONDETECTED</Condition>
d4f8b6
 
d4f8b6
     <DirectoryRef Id="TARGETDIR">
d4f8b6
-      <Component Id="CRegistryEntries" Guid="*">
d4f8b6
-        <RegistryKey Root='HKLM' Key='Software\Microsoft\Internet Explorer\Low Rights\ElevationPolicy\{96190E9D-6FBB-64DB-9095-29F6FDE0B897}'>
d4f8b6
-          <RegistryValue Type='string' Name='AppPath' Value='[INSTALLDIR]\bin'/>
d4f8b6
-          <RegistryValue Type='string' Name='AppName' Value='remote-viewer.exe'/>
d4f8b6
-          <RegistryValue Type='integer' Name='Policy' Value='3'/>
d4f8b6
-        </RegistryKey>
d4f8b6
-        <RegistryKey Root='HKLM' Key='Software\spice-space.org\spicex'>
d4f8b6
-          <RegistryValue Type='string' Name='client' Value='[INSTALLDIR]\bin\remote-viewer.exe --spice-controller'/>
d4f8b6
-        </RegistryKey>
d4f8b6
-      </Component>
d4f8b6
       <Component Id="CProgIds" Guid="89D6F46D-9C5E-4D65-8456-58FC361E553E">
d4f8b6
         <ProgId Id='VirtViewer.vvfile' Description='VirtViewer connection file'>
d4f8b6
           <Extension Id='vv' ContentType='application/x-virt-viewer'>
d4f8b6
@@ -129,7 +119,6 @@
d4f8b6
       <ComponentGroupRef Id="CG.virt-viewer"/>
d4f8b6
       <ComponentRef Id="CDepsFile"/>
d4f8b6
       <ComponentRef Id="CShortcut"/>
d4f8b6
-      <ComponentRef Id="CRegistryEntries"/>
d4f8b6
       <ComponentRef Id="CProgIds"/>
d4f8b6
       <ComponentRef Id="CHwdataUSB"/>
d4f8b6
     </Feature>
d4f8b6
diff --git a/man/remote-viewer.pod b/man/remote-viewer.pod
d4f8b6
index 560f73f..e26aee7 100644
d4f8b6
--- a/man/remote-viewer.pod
d4f8b6
+++ b/man/remote-viewer.pod
d4f8b6
@@ -55,12 +55,6 @@ CONFIGURATION section below.
d4f8b6
 
d4f8b6
 Set the window title to B<TITLE>
d4f8b6
 
d4f8b6
-=item --spice-controller
d4f8b6
-
d4f8b6
-Use the SPICE controller to initialize the connection with the SPICE
d4f8b6
-server. This option is used by the SPICE browser addons to allow web
d4f8b6
-page to start a client.
d4f8b6
-
d4f8b6
 =item --debug
d4f8b6
 
d4f8b6
 Print debugging information
d4f8b6
diff --git a/src/Makefile.am b/src/Makefile.am
d4f8b6
index b3eea67..6f2b7a1 100644
d4f8b6
--- a/src/Makefile.am
d4f8b6
+++ b/src/Makefile.am
d4f8b6
@@ -180,11 +180,9 @@ remote_viewer_SOURCES =				\
d4f8b6
 	$(NULL)
d4f8b6
 remote_viewer_LDFLAGS =				\
d4f8b6
 	$(COMMON_LIBS)				\
d4f8b6
-	$(SPICE_CONTROLLER_LIBS)		\
d4f8b6
 	$(NULL)
d4f8b6
 remote_viewer_CFLAGS =				\
d4f8b6
 	$(COMMON_CFLAGS) 			\
d4f8b6
-	$(SPICE_CONTROLLER_CFLAGS)		\
d4f8b6
 	$(NULL)
d4f8b6
 remote_viewer_LDADD = \
d4f8b6
 	libvirt-viewer-util.la \
d4f8b6
diff --git a/src/remote-viewer.c b/src/remote-viewer.c
d4f8b6
index 429f38c..a920aa0 100644
d4f8b6
--- a/src/remote-viewer.c
d4f8b6
+++ b/src/remote-viewer.c
d4f8b6
@@ -36,7 +36,6 @@
d4f8b6
 #endif
d4f8b6
 
d4f8b6
 #ifdef HAVE_SPICE_GTK
d4f8b6
-#include <spice-controller.h>
d4f8b6
 #include "virt-viewer-session-spice.h"
d4f8b6
 #endif
d4f8b6
 
d4f8b6
@@ -53,10 +52,6 @@
d4f8b6
 #endif
d4f8b6
 
d4f8b6
 struct _RemoteViewerPrivate {
d4f8b6
-#ifdef HAVE_SPICE_GTK
d4f8b6
-    SpiceCtrlController *controller;
d4f8b6
-    SpiceCtrlForeignMenu *ctrl_foreign_menu;
d4f8b6
-#endif
d4f8b6
 #ifdef HAVE_OVIRT
d4f8b6
     OvirtForeignMenu *ovirt_foreign_menu;
d4f8b6
 #endif
d4f8b6
@@ -82,33 +77,15 @@ static OvirtVm * choose_vm(GtkWindow *main_window,
d4f8b6
 #endif
d4f8b6
 
d4f8b6
 static gboolean remote_viewer_start(VirtViewerApp *self, GError **error);
d4f8b6
-#ifdef HAVE_SPICE_GTK
d4f8b6
-static gboolean remote_viewer_activate(VirtViewerApp *self, GError **error);
d4f8b6
-static void remote_viewer_window_added(GtkApplication *app, GtkWindow *w);
d4f8b6
-static void spice_foreign_menu_updated(RemoteViewer *self);
d4f8b6
-static void foreign_menu_title_changed(SpiceCtrlForeignMenu *menu, GParamSpec *pspec, RemoteViewer *self);
d4f8b6
-#endif
d4f8b6
 
d4f8b6
 static void
d4f8b6
 remote_viewer_dispose (GObject *object)
d4f8b6
 {
d4f8b6
-#if defined(HAVE_SPICE_GTK) || defined(HAVE_OVIRT)
d4f8b6
+#if defined(HAVE_OVIRT)
d4f8b6
     RemoteViewer *self = REMOTE_VIEWER(object);
d4f8b6
     RemoteViewerPrivate *priv = self->priv;
d4f8b6
 #endif
d4f8b6
 
d4f8b6
-#ifdef HAVE_SPICE_GTK
d4f8b6
-    if (priv->controller) {
d4f8b6
-        g_object_unref(priv->controller);
d4f8b6
-        priv->controller = NULL;
d4f8b6
-    }
d4f8b6
-
d4f8b6
-    if (priv->ctrl_foreign_menu) {
d4f8b6
-        g_object_unref(priv->ctrl_foreign_menu);
d4f8b6
-        priv->ctrl_foreign_menu = NULL;
d4f8b6
-    }
d4f8b6
-#endif
d4f8b6
-
d4f8b6
 #ifdef HAVE_OVIRT
d4f8b6
     if (priv->ovirt_foreign_menu) {
d4f8b6
         g_object_unref(priv->ovirt_foreign_menu);
d4f8b6
@@ -136,7 +113,6 @@ remote_viewer_deactivated(VirtViewerApp *app, gboolean connect_error)
d4f8b6
 
d4f8b6
 static gchar **opt_args = NULL;
d4f8b6
 static char *opt_title = NULL;
d4f8b6
-static gboolean opt_controller = FALSE;
d4f8b6
 
d4f8b6
 static void
d4f8b6
 remote_viewer_add_option_entries(VirtViewerApp *self, GOptionContext *context, GOptionGroup *group)
d4f8b6
@@ -144,10 +120,6 @@ remote_viewer_add_option_entries(VirtViewerApp *self, GOptionContext *context, G
d4f8b6
     static const GOptionEntry options[] = {
d4f8b6
         { "title", 't', 0, G_OPTION_ARG_STRING, &opt_title,
d4f8b6
           N_("Set window title"), NULL },
d4f8b6
-#ifdef HAVE_SPICE_GTK
d4f8b6
-        { "spice-controller", '\0', 0, G_OPTION_ARG_NONE, &opt_controller,
d4f8b6
-          N_("Open connection using Spice controller communication"), NULL },
d4f8b6
-#endif
d4f8b6
         { G_OPTION_REMAINING, '\0', 0, G_OPTION_ARG_STRING_ARRAY, &opt_args,
d4f8b6
           NULL, "URI|VV-FILE" },
d4f8b6
         { NULL, 0, 0, G_OPTION_ARG_NONE, NULL, NULL, NULL }
d4f8b6
@@ -188,27 +160,7 @@ remote_viewer_local_command_line (GApplication   *gapp,
d4f8b6
         g_object_set(app, "guri", opt_args[0], NULL);
d4f8b6
     }
d4f8b6
 
d4f8b6
-#ifdef HAVE_SPICE_GTK
d4f8b6
-    if (opt_controller) {
d4f8b6
-        if (opt_args) {
d4f8b6
-            g_printerr(_("\nError: extra arguments given while using Spice controller\n\n"));
d4f8b6
-            ret = TRUE;
d4f8b6
-            *status = 1;
d4f8b6
-            goto end;
d4f8b6
-        }
d4f8b6
-
d4f8b6
-        self->priv->controller = spice_ctrl_controller_new();
d4f8b6
-        self->priv->ctrl_foreign_menu = spice_ctrl_foreign_menu_new();
d4f8b6
-
d4f8b6
-        g_object_set(self, "guest-name", "defined by Spice controller", NULL);
d4f8b6
-
d4f8b6
-        g_signal_connect(self->priv->ctrl_foreign_menu, "notify::title",
d4f8b6
-                         G_CALLBACK(foreign_menu_title_changed),
d4f8b6
-                         self);
d4f8b6
-    }
d4f8b6
-#endif
d4f8b6
-
d4f8b6
-    if (opt_title && !opt_controller)
d4f8b6
+    if (opt_title)
d4f8b6
         g_object_set(app, "title", opt_title, NULL);
d4f8b6
 
d4f8b6
 end:
d4f8b6
@@ -245,7 +197,6 @@ static void
d4f8b6
 remote_viewer_class_init (RemoteViewerClass *klass)
d4f8b6
 {
d4f8b6
     GObjectClass *object_class = G_OBJECT_CLASS (klass);
d4f8b6
-    GtkApplicationClass *gtk_app_class = GTK_APPLICATION_CLASS(klass);
d4f8b6
     VirtViewerAppClass *app_class = VIRT_VIEWER_APP_CLASS (klass);
d4f8b6
     GApplicationClass *g_app_class = G_APPLICATION_CLASS(klass);
d4f8b6
 
d4f8b6
@@ -259,12 +210,6 @@ remote_viewer_class_init (RemoteViewerClass *klass)
d4f8b6
     app_class->start = remote_viewer_start;
d4f8b6
     app_class->deactivated = remote_viewer_deactivated;
d4f8b6
     app_class->add_option_entries = remote_viewer_add_option_entries;
d4f8b6
-#ifdef HAVE_SPICE_GTK
d4f8b6
-    app_class->activate = remote_viewer_activate;
d4f8b6
-    gtk_app_class->window_added = remote_viewer_window_added;
d4f8b6
-#else
d4f8b6
-    (void) gtk_app_class;
d4f8b6
-#endif
d4f8b6
 
d4f8b6
 #ifdef HAVE_OVIRT
d4f8b6
     g_object_class_install_property(object_class,
d4f8b6
@@ -292,217 +237,7 @@ remote_viewer_new(void)
d4f8b6
                         NULL);
d4f8b6
 }
d4f8b6
 
d4f8b6
-#ifdef HAVE_SPICE_GTK
d4f8b6
-static void
d4f8b6
-foreign_menu_title_changed(SpiceCtrlForeignMenu *menu G_GNUC_UNUSED,
d4f8b6
-                           GParamSpec *pspec G_GNUC_UNUSED,
d4f8b6
-                           RemoteViewer *self)
d4f8b6
-{
d4f8b6
-    gboolean has_focus;
d4f8b6
-
d4f8b6
-    g_object_get(G_OBJECT(self), "has-focus", &has_focus, NULL);
d4f8b6
-    /* FIXME: use a proper "new client connected" event
d4f8b6
-    ** a foreign menu client set the title when connecting,
d4f8b6
-    ** inform of focus state at that time.
d4f8b6
-    */
d4f8b6
-    spice_ctrl_foreign_menu_app_activated_msg(self->priv->ctrl_foreign_menu, has_focus);
d4f8b6
-
d4f8b6
-    /* update menu title */
d4f8b6
-    spice_foreign_menu_updated(self);
d4f8b6
-}
d4f8b6
-
d4f8b6
-static void
d4f8b6
-spice_ctrl_do_connect(SpiceCtrlController *ctrl G_GNUC_UNUSED,
d4f8b6
-                      VirtViewerApp *self)
d4f8b6
-{
d4f8b6
-    GError *error = NULL;
d4f8b6
-
d4f8b6
-    if (!virt_viewer_app_initial_connect(self, &error)) {
d4f8b6
-        const gchar *msg = error ? error->message :
d4f8b6
-            _("Failed to initiate connection");
d4f8b6
-        virt_viewer_app_simple_message_dialog(self, msg);
d4f8b6
-        g_clear_error(&error);
d4f8b6
-    }
d4f8b6
-}
d4f8b6
-
d4f8b6
-static void
d4f8b6
-spice_ctrl_show(SpiceCtrlController *ctrl G_GNUC_UNUSED, RemoteViewer *self)
d4f8b6
-{
d4f8b6
-    virt_viewer_app_show_display(VIRT_VIEWER_APP(self));
d4f8b6
-}
d4f8b6
-
d4f8b6
-static void
d4f8b6
-spice_ctrl_hide(SpiceCtrlController *ctrl G_GNUC_UNUSED, RemoteViewer *self)
d4f8b6
-{
d4f8b6
-    virt_viewer_app_show_status(VIRT_VIEWER_APP(self), _("Display disabled by controller"));
d4f8b6
-}
d4f8b6
-
d4f8b6
-static void
d4f8b6
-spice_menuitem_activate_cb(GtkMenuItem *mi, GObject *ctrl)
d4f8b6
-{
d4f8b6
-    SpiceCtrlMenuItem *menuitem = g_object_get_data(G_OBJECT(mi), "spice-menuitem");
d4f8b6
-
d4f8b6
-    g_return_if_fail(menuitem != NULL);
d4f8b6
-    if (gtk_menu_item_get_submenu(mi))
d4f8b6
-        return;
d4f8b6
-
d4f8b6
-    if (SPICE_CTRL_IS_CONTROLLER(ctrl))
d4f8b6
-        spice_ctrl_controller_menu_item_click_msg(SPICE_CTRL_CONTROLLER(ctrl), menuitem->id);
d4f8b6
-    else if (SPICE_CTRL_IS_FOREIGN_MENU(ctrl))
d4f8b6
-        spice_ctrl_foreign_menu_menu_item_click_msg(SPICE_CTRL_FOREIGN_MENU(ctrl), menuitem->id);
d4f8b6
-}
d4f8b6
-
d4f8b6
-static GtkWidget *
d4f8b6
-ctrlmenu_to_gtkmenu (RemoteViewer *self, SpiceCtrlMenu *ctrlmenu, GObject *ctrl)
d4f8b6
-{
d4f8b6
-    GList *l;
d4f8b6
-    GtkWidget *menu = gtk_menu_new();
d4f8b6
-    guint n = 0;
d4f8b6
-
d4f8b6
-    for (l = ctrlmenu->items; l != NULL; l = l->next) {
d4f8b6
-        SpiceCtrlMenuItem *menuitem = l->data;
d4f8b6
-        GtkWidget *item;
d4f8b6
-        char *s;
d4f8b6
-        if (menuitem->text == NULL) {
d4f8b6
-            g_warn_if_reached();
d4f8b6
-            continue;
d4f8b6
-        }
d4f8b6
-
d4f8b6
-        for (s = menuitem->text; *s; s++)
d4f8b6
-            if (*s == '&')
d4f8b6
-                *s = '_';
d4f8b6
-
d4f8b6
-        if (g_str_equal(menuitem->text, "-")) {
d4f8b6
-            item = gtk_separator_menu_item_new();
d4f8b6
-        } else if (menuitem->flags & CONTROLLER_MENU_FLAGS_CHECKED) {
d4f8b6
-            item = gtk_check_menu_item_new_with_mnemonic(menuitem->text);
d4f8b6
-            g_object_set(item, "active", TRUE, NULL);
d4f8b6
-        } else {
d4f8b6
-            item = gtk_menu_item_new_with_mnemonic(menuitem->text);
d4f8b6
-        }
d4f8b6
-
d4f8b6
-        if (menuitem->flags & (CONTROLLER_MENU_FLAGS_GRAYED | CONTROLLER_MENU_FLAGS_DISABLED))
d4f8b6
-            gtk_widget_set_sensitive(item, FALSE);
d4f8b6
-
d4f8b6
-        g_object_set_data_full(G_OBJECT(item), "spice-menuitem",
d4f8b6
-                               g_object_ref(menuitem), g_object_unref);
d4f8b6
-        g_signal_connect(item, "activate", G_CALLBACK(spice_menuitem_activate_cb), ctrl);
d4f8b6
-        gtk_menu_attach(GTK_MENU (menu), item, 0, 1, n, n + 1);
d4f8b6
-        n += 1;
d4f8b6
-
d4f8b6
-        if (menuitem->submenu) {
d4f8b6
-            gtk_menu_item_set_submenu(GTK_MENU_ITEM(item),
d4f8b6
-                                      ctrlmenu_to_gtkmenu(self, menuitem->submenu, ctrl));
d4f8b6
-        }
d4f8b6
-    }
d4f8b6
-
d4f8b6
-    if (n == 0) {
d4f8b6
-        g_object_ref_sink(menu);
d4f8b6
-        g_object_unref(menu);
d4f8b6
-        menu = NULL;
d4f8b6
-    }
d4f8b6
-
d4f8b6
-    gtk_widget_show_all(menu);
d4f8b6
-    return menu;
d4f8b6
-}
d4f8b6
-
d4f8b6
-static void
d4f8b6
-spice_menu_update(RemoteViewer *self, VirtViewerWindow *win)
d4f8b6
-{
d4f8b6
-    GtkWidget *menuitem = g_object_get_data(G_OBJECT(win), "spice-menu");
d4f8b6
-    SpiceCtrlMenu *menu;
d4f8b6
-
d4f8b6
-    if (self->priv->controller == NULL)
d4f8b6
-        return;
d4f8b6
-
d4f8b6
-    if (menuitem != NULL)
d4f8b6
-        gtk_widget_destroy(menuitem);
d4f8b6
-
d4f8b6
-    {
d4f8b6
-        GtkMenuShell *shell = GTK_MENU_SHELL(gtk_builder_get_object(virt_viewer_window_get_builder(win), "top-menu"));
d4f8b6
-        menuitem = gtk_menu_item_new_with_label("Spice");
d4f8b6
-        gtk_menu_shell_append(shell, menuitem);
d4f8b6
-        g_object_set_data(G_OBJECT(win), "spice-menu", menuitem);
d4f8b6
-    }
d4f8b6
-
d4f8b6
-    g_object_get(self->priv->controller, "menu", &menu, NULL);
d4f8b6
-    if (menu == NULL || g_list_length(menu->items) == 0) {
d4f8b6
-        gtk_widget_set_visible(menuitem, FALSE);
d4f8b6
-    } else {
d4f8b6
-        gtk_menu_item_set_submenu(GTK_MENU_ITEM(menuitem),
d4f8b6
-            ctrlmenu_to_gtkmenu(self, menu, G_OBJECT(self->priv->controller)));
d4f8b6
-        gtk_widget_set_visible(menuitem, TRUE);
d4f8b6
-    }
d4f8b6
-
d4f8b6
-    if (menu != NULL)
d4f8b6
-        g_object_unref(menu);
d4f8b6
-}
d4f8b6
-
d4f8b6
-static void
d4f8b6
-spice_menu_update_each(gpointer value,
d4f8b6
-                       gpointer user_data)
d4f8b6
-{
d4f8b6
-    spice_menu_update(REMOTE_VIEWER(user_data), VIRT_VIEWER_WINDOW(value));
d4f8b6
-}
d4f8b6
-
d4f8b6
-static void
d4f8b6
-spice_ctrl_menu_updated(RemoteViewer *self)
d4f8b6
-{
d4f8b6
-    GList *windows = virt_viewer_app_get_windows(VIRT_VIEWER_APP(self));
d4f8b6
-
d4f8b6
-    g_debug("Spice controller menu updated");
d4f8b6
-
d4f8b6
-    g_list_foreach(windows, spice_menu_update_each, self);
d4f8b6
-}
d4f8b6
-
d4f8b6
-static void
d4f8b6
-spice_foreign_menu_update(RemoteViewer *self, VirtViewerWindow *win)
d4f8b6
-{
d4f8b6
-    GtkWidget *menuitem = g_object_get_data(G_OBJECT(win), "foreign-menu");
d4f8b6
-    SpiceCtrlMenu *menu;
d4f8b6
-
d4f8b6
-    if (self->priv->ctrl_foreign_menu == NULL)
d4f8b6
-        return;
d4f8b6
-
d4f8b6
-    if (menuitem != NULL)
d4f8b6
-        gtk_widget_destroy(menuitem);
d4f8b6
-
d4f8b6
-    {
d4f8b6
-        GtkMenuShell *shell = GTK_MENU_SHELL(gtk_builder_get_object(virt_viewer_window_get_builder(win), "top-menu"));
d4f8b6
-        const gchar *title = spice_ctrl_foreign_menu_get_title(self->priv->ctrl_foreign_menu);
d4f8b6
-        menuitem = gtk_menu_item_new_with_label(title);
d4f8b6
-        gtk_menu_shell_append(shell, menuitem);
d4f8b6
-        g_object_set_data(G_OBJECT(win), "foreign-menu", menuitem);
d4f8b6
-    }
d4f8b6
-
d4f8b6
-    g_object_get(self->priv->ctrl_foreign_menu, "menu", &menu, NULL);
d4f8b6
-    if (menu == NULL || g_list_length(menu->items) == 0) {
d4f8b6
-        gtk_widget_set_visible(menuitem, FALSE);
d4f8b6
-    } else {
d4f8b6
-        gtk_menu_item_set_submenu(GTK_MENU_ITEM(menuitem),
d4f8b6
-            ctrlmenu_to_gtkmenu(self, menu, G_OBJECT(self->priv->ctrl_foreign_menu)));
d4f8b6
-        gtk_widget_set_visible(menuitem, TRUE);
d4f8b6
-    }
d4f8b6
-    g_object_unref(menu);
d4f8b6
-}
d4f8b6
-
d4f8b6
-static void
d4f8b6
-spice_foreign_menu_update_each(gpointer value,
d4f8b6
-                               gpointer user_data)
d4f8b6
-{
d4f8b6
-    spice_foreign_menu_update(REMOTE_VIEWER(user_data), VIRT_VIEWER_WINDOW(value));
d4f8b6
-}
d4f8b6
-
d4f8b6
-static void
d4f8b6
-spice_foreign_menu_updated(RemoteViewer *self)
d4f8b6
-{
d4f8b6
-    GList *windows = virt_viewer_app_get_windows(VIRT_VIEWER_APP(self));
d4f8b6
-
d4f8b6
-    g_debug("Spice foreign menu updated");
d4f8b6
-
d4f8b6
-    g_list_foreach(windows, spice_foreign_menu_update_each, self);
d4f8b6
-}
d4f8b6
-
d4f8b6
+#if defined(HAVE_SPICE_GTK) && defined(HAVE_OVIRT)
d4f8b6
 static SpiceSession *
d4f8b6
 remote_viewer_get_spice_session(RemoteViewer *self)
d4f8b6
 {
d4f8b6
@@ -518,158 +253,6 @@ remote_viewer_get_spice_session(RemoteViewer *self)
d4f8b6
 
d4f8b6
     return session;
d4f8b6
 }
d4f8b6
-
d4f8b6
-static void
d4f8b6
-app_notified(VirtViewerApp *app,
d4f8b6
-             GParamSpec *pspec,
d4f8b6
-             RemoteViewer *self)
d4f8b6
-{
d4f8b6
-    GValue value = G_VALUE_INIT;
d4f8b6
-
d4f8b6
-    g_value_init(&value, pspec->value_type);
d4f8b6
-    g_object_get_property(G_OBJECT(app), pspec->name, &value);
d4f8b6
-
d4f8b6
-    if (g_str_equal(pspec->name, "has-focus")) {
d4f8b6
-        if (self->priv->ctrl_foreign_menu)
d4f8b6
-            spice_ctrl_foreign_menu_app_activated_msg(self->priv->ctrl_foreign_menu, g_value_get_boolean(&value));
d4f8b6
-    }
d4f8b6
-
d4f8b6
-    g_value_unset(&value);
d4f8b6
-}
d4f8b6
-
d4f8b6
-static void
d4f8b6
-spice_ctrl_notified(SpiceCtrlController *ctrl,
d4f8b6
-                    GParamSpec *pspec,
d4f8b6
-                    RemoteViewer *self)
d4f8b6
-{
d4f8b6
-    SpiceSession *session = remote_viewer_get_spice_session(self);
d4f8b6
-    GValue value = G_VALUE_INIT;
d4f8b6
-    VirtViewerApp *app = VIRT_VIEWER_APP(self);
d4f8b6
-
d4f8b6
-    g_return_if_fail(session != NULL);
d4f8b6
-
d4f8b6
-    g_value_init(&value, pspec->value_type);
d4f8b6
-    g_object_get_property(G_OBJECT(ctrl), pspec->name, &value);
d4f8b6
-
d4f8b6
-    if (g_str_equal(pspec->name, "host") ||
d4f8b6
-        g_str_equal(pspec->name, "port") ||
d4f8b6
-        g_str_equal(pspec->name, "password") ||
d4f8b6
-        g_str_equal(pspec->name, "ca-file") ||
d4f8b6
-        g_str_equal(pspec->name, "enable-smartcard") ||
d4f8b6
-        g_str_equal(pspec->name, "color-depth") ||
d4f8b6
-        g_str_equal(pspec->name, "disable-effects") ||
d4f8b6
-        g_str_equal(pspec->name, "enable-usbredir") ||
d4f8b6
-        g_str_equal(pspec->name, "secure-channels") ||
d4f8b6
-        g_str_equal(pspec->name, "proxy")) {
d4f8b6
-        g_object_set_property(G_OBJECT(session), pspec->name, &value);
d4f8b6
-    } else if (g_str_equal(pspec->name, "sport")) {
d4f8b6
-        g_object_set_property(G_OBJECT(session), "tls-port", &value);
d4f8b6
-    } else if (g_str_equal(pspec->name, "tls-ciphers")) {
d4f8b6
-        g_object_set_property(G_OBJECT(session), "ciphers", &value);
d4f8b6
-    } else if (g_str_equal(pspec->name, "host-subject")) {
d4f8b6
-        g_object_set_property(G_OBJECT(session), "cert-subject", &value);
d4f8b6
-    } else if (g_str_equal(pspec->name, "enable-usb-autoshare")) {
d4f8b6
-        VirtViewerSession *vsession = NULL;
d4f8b6
-
d4f8b6
-        g_object_get(self, "session", &vsession, NULL);
d4f8b6
-        g_object_set_property(G_OBJECT(vsession), "auto-usbredir", &value);
d4f8b6
-        g_object_unref(G_OBJECT(vsession));
d4f8b6
-    } else if (g_str_equal(pspec->name, "usb-filter")) {
d4f8b6
-        SpiceUsbDeviceManager *manager;
d4f8b6
-        manager = spice_usb_device_manager_get(session, NULL);
d4f8b6
-        if (manager != NULL) {
d4f8b6
-            g_object_set_property(G_OBJECT(manager),
d4f8b6
-                                  "auto-connect-filter",
d4f8b6
-                                  &value);
d4f8b6
-        }
d4f8b6
-    } else if (g_str_equal(pspec->name, "title")) {
d4f8b6
-        g_object_set(app, "title", g_value_get_string(&value), NULL);
d4f8b6
-    } else if (g_str_equal(pspec->name, "display-flags")) {
d4f8b6
-        guint flags = g_value_get_uint(&value);
d4f8b6
-        gboolean fullscreen = !!(flags & CONTROLLER_SET_FULL_SCREEN);
d4f8b6
-        g_object_set(G_OBJECT(self), "fullscreen", fullscreen, NULL);
d4f8b6
-    } else if (g_str_equal(pspec->name, "menu")) {
d4f8b6
-        spice_ctrl_menu_updated(self);
d4f8b6
-    } else if (g_str_equal(pspec->name, "hotkeys")) {
d4f8b6
-        virt_viewer_app_set_hotkeys(app, g_value_get_string(&value));
d4f8b6
-    } else {
d4f8b6
-        gchar *content = g_strdup_value_contents(&value);
d4f8b6
-
d4f8b6
-        g_debug("unimplemented property: %s=%s", pspec->name, content);
d4f8b6
-        g_free(content);
d4f8b6
-    }
d4f8b6
-
d4f8b6
-    g_object_unref(session);
d4f8b6
-    g_value_unset(&value);
d4f8b6
-}
d4f8b6
-
d4f8b6
-static void
d4f8b6
-spice_ctrl_foreign_menu_notified(SpiceCtrlForeignMenu *ctrl_foreign_menu G_GNUC_UNUSED,
d4f8b6
-                                 GParamSpec *pspec,
d4f8b6
-                                 RemoteViewer *self)
d4f8b6
-{
d4f8b6
-    if (g_str_equal(pspec->name, "menu")) {
d4f8b6
-        spice_foreign_menu_updated(self);
d4f8b6
-    }
d4f8b6
-}
d4f8b6
-
d4f8b6
-static void
d4f8b6
-spice_ctrl_listen_async_cb(GObject *object,
d4f8b6
-                           GAsyncResult *res,
d4f8b6
-                           gpointer user_data)
d4f8b6
-{
d4f8b6
-    GError *error = NULL;
d4f8b6
-    VirtViewerApp *app = VIRT_VIEWER_APP(user_data);
d4f8b6
-
d4f8b6
-    if (SPICE_CTRL_IS_CONTROLLER(object))
d4f8b6
-        spice_ctrl_controller_listen_finish(SPICE_CTRL_CONTROLLER(object), res, &error);
d4f8b6
-    else if (SPICE_CTRL_IS_FOREIGN_MENU(object)) {
d4f8b6
-        spice_ctrl_foreign_menu_listen_finish(SPICE_CTRL_FOREIGN_MENU(object), res, &error);
d4f8b6
-    } else
d4f8b6
-        g_warn_if_reached();
d4f8b6
-
d4f8b6
-    if (error != NULL) {
d4f8b6
-        virt_viewer_app_simple_message_dialog(app,
d4f8b6
-                                              _("Controller connection failed: %s"),
d4f8b6
-                                              error->message);
d4f8b6
-        g_clear_error(&error);
d4f8b6
-        exit(EXIT_FAILURE); /* TODO: make start async? */
d4f8b6
-    }
d4f8b6
-}
d4f8b6
-
d4f8b6
-
d4f8b6
-static gboolean
d4f8b6
-remote_viewer_activate(VirtViewerApp *app, GError **error)
d4f8b6
-{
d4f8b6
-    RemoteViewer *self;
d4f8b6
-    gboolean ret = FALSE;
d4f8b6
-
d4f8b6
-    g_return_val_if_fail(REMOTE_VIEWER_IS(app), FALSE);
d4f8b6
-
d4f8b6
-    self = REMOTE_VIEWER(app);
d4f8b6
-
d4f8b6
-    if (self->priv->controller) {
d4f8b6
-        SpiceSession *session = remote_viewer_get_spice_session(self);
d4f8b6
-        ret = spice_session_connect(session);
d4f8b6
-        g_object_unref(session);
d4f8b6
-    } else {
d4f8b6
-        ret = VIRT_VIEWER_APP_CLASS(remote_viewer_parent_class)->activate(app, error);
d4f8b6
-    }
d4f8b6
-
d4f8b6
-    return ret;
d4f8b6
-}
d4f8b6
-
d4f8b6
-static void
d4f8b6
-remote_viewer_window_added(GtkApplication *app,
d4f8b6
-                           GtkWindow *w)
d4f8b6
-{
d4f8b6
-    VirtViewerWindow *win = VIRT_VIEWER_WINDOW(
d4f8b6
-                                g_object_get_data(G_OBJECT(w), "virt-viewer-window"));
d4f8b6
-    spice_menu_update(REMOTE_VIEWER(app), win);
d4f8b6
-    spice_foreign_menu_update(REMOTE_VIEWER(app), win);
d4f8b6
-
d4f8b6
-    GTK_APPLICATION_CLASS(remote_viewer_parent_class)->window_added(app, w);
d4f8b6
-}
d4f8b6
 #endif
d4f8b6
 
d4f8b6
 #ifdef HAVE_OVIRT
d4f8b6
@@ -1101,29 +684,8 @@ remote_viewer_start(VirtViewerApp *app, GError **err)
d4f8b6
     gchar *type = NULL;
d4f8b6
     GError *error = NULL;
d4f8b6
 
d4f8b6
-#ifdef HAVE_SPICE_GTK
d4f8b6
-    g_signal_connect(app, "notify", G_CALLBACK(app_notified), self);
d4f8b6
-
d4f8b6
-    if (priv->controller) {
d4f8b6
-        if (!virt_viewer_app_create_session(app, "spice", &error)) {
d4f8b6
-            g_debug("Couldn't create a Spice session");
d4f8b6
-            goto cleanup;
d4f8b6
-        }
d4f8b6
-
d4f8b6
-        g_signal_connect(priv->controller, "notify", G_CALLBACK(spice_ctrl_notified), self);
d4f8b6
-        g_signal_connect(priv->controller, "do_connect", G_CALLBACK(spice_ctrl_do_connect), self);
d4f8b6
-        g_signal_connect(priv->controller, "show", G_CALLBACK(spice_ctrl_show), self);
d4f8b6
-        g_signal_connect(priv->controller, "hide", G_CALLBACK(spice_ctrl_hide), self);
d4f8b6
-
d4f8b6
-        spice_ctrl_controller_listen(priv->controller, NULL, spice_ctrl_listen_async_cb, self);
d4f8b6
-
d4f8b6
-        g_signal_connect(priv->ctrl_foreign_menu, "notify", G_CALLBACK(spice_ctrl_foreign_menu_notified), self);
d4f8b6
-        spice_ctrl_foreign_menu_listen(priv->ctrl_foreign_menu, NULL, spice_ctrl_listen_async_cb, self);
d4f8b6
-
d4f8b6
-        virt_viewer_app_show_status(VIRT_VIEWER_APP(self), _("Setting up Spice session..."));
d4f8b6
-    } else {
d4f8b6
-#endif
d4f8b6
 retry_dialog:
d4f8b6
+    {
d4f8b6
         if (priv->open_recent_dialog) {
d4f8b6
             VirtViewerWindow *main_window = virt_viewer_app_get_main_window(app);
d4f8b6
             if (!remote_viewer_connect_dialog(virt_viewer_window_get_window(main_window), &guri)) {
d4f8b6
@@ -1193,9 +755,7 @@ retry_dialog:
d4f8b6
             }
d4f8b6
             goto cleanup;
d4f8b6
         }
d4f8b6
-#ifdef HAVE_SPICE_GTK
d4f8b6
     }
d4f8b6
-#endif
d4f8b6
 
d4f8b6
     ret = VIRT_VIEWER_APP_CLASS(remote_viewer_parent_class)->start(app, &error);
d4f8b6
 
d4f8b6
-- 
d4f8b6
2.17.1
d4f8b6