[gnome-software/wip/rancell/apt: 25/25] Notify Unity launcher when installing
- From: Robert Ancell <rancell src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-software/wip/rancell/apt: 25/25] Notify Unity launcher when installing
- Date: Fri, 19 Feb 2016 20:21:19 +0000 (UTC)
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]