[gnome-software/wip/rancell/apt: 25/25] Notify Unity launcher when installing



commit 389b5642b5ad992b86d579beeb4aa546cf87b465
Author: Andrea Azzarone <azzaronea gmail com>
Date:   Fri Feb 19 12:16:03 2016 -0800

    Notify Unity launcher when installing

 src/plugins/Makefile.am                      |   15 ++++++++++++-
 src/plugins/com.canonical.Unity.Launcher.xml |   15 +++++++++++++
 src/plugins/gs-plugin-apt.c                  |   29 ++++++++++++++++++++++++++
 3 files changed, 58 insertions(+), 1 deletions(-)
---
diff --git a/src/plugins/Makefile.am b/src/plugins/Makefile.am
index fbb3d95..d8d75c4 100644
--- a/src/plugins/Makefile.am
+++ b/src/plugins/Makefile.am
@@ -128,7 +128,20 @@ libgs_plugin_xdg_app_reviews_la_LDFLAGS = -module -avoid-version
 libgs_plugin_xdg_app_reviews_la_CFLAGS = $(GS_PLUGIN_CFLAGS) $(WARN_CFLAGS)
 endif
 
-libgs_plugin_apt_la_SOURCES = gs-plugin-apt.c
+ubuntu-unity-launcher-proxy.c ubuntu-unity-launcher-proxy.h: com.canonical.Unity.Launcher.xml Makefile
+       $(AM_V_GEN) gdbus-codegen --interface-prefix com.canonical.Unity.Launcher \
+                        --generate-c-code ubuntu-unity-launcher-proxy \
+                        --c-namespace UbuntuUnity \
+                        --annotate 'com.canonical.Unity.Launcher' \
+                                   org.gtk.GDBus.C.Name \
+                                   Launcher \
+                        $<
+
+
+libgs_plugin_apt_la_SOURCES = \
+       gs-plugin-apt.c \
+       ubuntu-unity-launcher-proxy.c \
+       ubuntu-unity-launcher-proxy.h
 libgs_plugin_apt_la_LIBADD = $(GS_PLUGIN_LIBS)
 libgs_plugin_apt_la_LDFLAGS = -module -avoid-version
 libgs_plugin_apt_la_CFLAGS = $(GS_PLUGIN_CFLAGS) $(WARN_CFLAGS)
diff --git a/src/plugins/com.canonical.Unity.Launcher.xml b/src/plugins/com.canonical.Unity.Launcher.xml
new file mode 100644
index 0000000..b631a2d
--- /dev/null
+++ b/src/plugins/com.canonical.Unity.Launcher.xml
@@ -0,0 +1,15 @@
+<!DOCTYPE node PUBLIC "-//freedesktop//DTD D-BUS Object Introspection 1.0//EN"
+"http://www.freedesktop.org/standards/dbus/1.0/introspect.dtd";>
+<node>
+  <interface name='com.canonical.Unity.Launcher'>
+    <method name='AddLauncherItem'>
+      <arg type='s' name='appstream_app_id' direction='in'/>
+      <arg type='s' name='aptdaemon_task' direction='in'/>
+    </method>
+    
+    <method name='UpdateLauncherIconFavoriteState'>
+      <arg type='s' name='icon_uri' direction='in'/>
+      <arg type='b' name='is_sticky' direction='in'/>
+    </method>
+  </interface>
+</node>
diff --git a/src/plugins/gs-plugin-apt.c b/src/plugins/gs-plugin-apt.c
index e14e6cf..81ff64d 100644
--- a/src/plugins/gs-plugin-apt.c
+++ b/src/plugins/gs-plugin-apt.c
@@ -36,6 +36,8 @@ typedef struct {
 } PackageInfo;
 
 
+#include "ubuntu-unity-launcher-proxy.h"
+
 struct GsPluginPrivate {
        gsize            loaded;
        GHashTable      *package_info;
@@ -467,6 +469,30 @@ transaction_finished_cb (GDBusConnection *connection,
        g_main_loop_quit (data->loop);
 }
 
+static void
+notify_unity_launcher (GsApp *app, const gchar *transaction_path)
+{
+       UbuntuUnityLauncher *launcher = NULL;
+
+       g_return_if_fail (GS_IS_APP (app));
+       g_return_if_fail (transaction_path);
+
+       launcher = ubuntu_unity_launcher_proxy_new_for_bus_sync (G_BUS_TYPE_SESSION,
+               G_DBUS_PROXY_FLAGS_NONE,
+               "com.canonical.Unity.Launcher",
+               "/com/canonical/Unity/Launcher",
+               NULL, NULL);
+
+       g_return_if_fail (launcher);
+
+       ubuntu_unity_launcher_call_add_launcher_item (launcher,
+               gs_app_get_id (app),
+               transaction_path,
+               NULL, NULL, NULL);
+
+       g_object_unref (launcher);
+}
+
 static gboolean
 aptd_transaction (GsPlugin *plugin, const gchar *method, GsApp *app, GError **error)
 {
@@ -506,6 +532,9 @@ aptd_transaction (GsPlugin *plugin, const gchar *method, GsApp *app, GError **er
        g_variant_get (result, "(s)", &transaction_path);
        g_variant_unref (result);
 
+       if (!g_strcmp0(method, "InstallPackages"))
+               notify_unity_launcher (app, transaction_path);
+
        loop = g_main_loop_new (NULL, FALSE);
 
        data.plugin = plugin;


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]