[gnome-software/wip/temp/ubuntu-xenial-rebased: 79/329] Only process packages that are intended for the apt plugin
- From: Iain Lane <iainl src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-software/wip/temp/ubuntu-xenial-rebased: 79/329] Only process packages that are intended for the apt plugin
- Date: Fri, 29 Apr 2016 13:51:58 +0000 (UTC)
commit 69d3d44a0c58fcafb203f8bb8a2f81f5fbd35077
Author: Robert Ancell <robert ancell canonical com>
Date: Wed Feb 10 15:59:37 2016 +1300
Only process packages that are intended for the apt plugin
src/plugins/gs-plugin-apt.c | 21 +++++++++++++++++++++
1 files changed, 21 insertions(+), 0 deletions(-)
---
diff --git a/src/plugins/gs-plugin-apt.c b/src/plugins/gs-plugin-apt.c
index ad5108f..e79a24a 100644
--- a/src/plugins/gs-plugin-apt.c
+++ b/src/plugins/gs-plugin-apt.c
@@ -362,6 +362,8 @@ gs_plugin_add_installed (GsPlugin *plugin,
g_autoptr(GsApp) app = NULL;
app = gs_app_new (installed[i]);
+ // FIXME: Since appstream marks all packages as owned by PackageKit and we are replacing
PackageKit we need to accept those packages
+ gs_app_set_management_plugin (app, "PackageKit");
gs_app_add_source (app, installed[i]);
gs_app_set_state (app, AS_APP_STATE_INSTALLED);
gs_plugin_add_app (list, app);
@@ -507,6 +509,13 @@ aptd_transaction (GsPlugin *plugin, const gchar *method, GsApp *app, GError **er
return TRUE;
}
+static gboolean
+app_is_ours (GsApp *app)
+{
+ // FIXME: Since appstream marks all packages as owned by PackageKit and we are replacing PackageKit
we need to accept those packages
+ return g_strcmp0 (gs_app_get_management_plugin (app), "PackageKit") == 0;
+}
+
gboolean
gs_plugin_app_install (GsPlugin *plugin,
GsApp *app,
@@ -515,6 +524,9 @@ gs_plugin_app_install (GsPlugin *plugin,
{
//g_printerr ("APT: gs_plugin_app_install\n");
+ if (!app_is_ours (app))
+ return TRUE;
+
if (gs_app_get_source_default (app) == NULL)
return TRUE;
@@ -537,6 +549,9 @@ gs_plugin_app_remove (GsPlugin *plugin,
{
//g_printerr ("APT: gs_plugin_app_remove\n");
+ if (!app_is_ours (app))
+ return TRUE;
+
if (gs_app_get_source_default (app) == NULL)
return TRUE;
@@ -606,6 +621,9 @@ gs_plugin_app_update (GsPlugin *plugin,
{
g_printerr ("APT: gs_plugin_app_update\n");
+ if (!app_is_ours (app))
+ return TRUE;
+
gs_app_set_state (app, AS_APP_STATE_INSTALLING);
if (aptd_transaction (plugin, "UpgradePackages", app, error))
gs_app_set_state (app, AS_APP_STATE_INSTALLED);
@@ -623,5 +641,8 @@ gs_plugin_launch (GsPlugin *plugin,
GCancellable *cancellable,
GError **error)
{
+ if (!app_is_ours (app))
+ return TRUE;
+
return gs_plugin_app_launch (plugin, app, error);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]