[gnome-software/1486-gs-repos-dialog-call-refresh-on-repository-setup-change: 15/16] gs-overview-page: Refresh the application after third-party repositories enable/disable
- From: Milan Crha <mcrha src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-software/1486-gs-repos-dialog-call-refresh-on-repository-setup-change: 15/16] gs-overview-page: Refresh the application after third-party repositories enable/disable
- Date: Thu, 14 Oct 2021 13:27:12 +0000 (UTC)
commit d34b30a1b993e16a89f7318d6fd56650fe3bf664
Author: Milan Crha <mcrha redhat com>
Date: Tue Oct 5 19:45:10 2021 +0200
gs-overview-page: Refresh the application after third-party repositories enable/disable
The enable/disable can cause other applications being found, thus call
the refresh, to update the repositories information.
src/gs-application.h | 2 +-
src/gs-overview-page.c | 28 ++++++++++++++++++++++++++++
2 files changed, 29 insertions(+), 1 deletion(-)
---
diff --git a/src/gs-application.h b/src/gs-application.h
index 40bad4d4c..04461bd3b 100644
--- a/src/gs-application.h
+++ b/src/gs-application.h
@@ -23,4 +23,4 @@ gboolean gs_application_has_active_window (GsApplication *application);
void gs_application_emit_install_resources_done
(GsApplication *application,
const gchar *ident,
- const GError *op_error);
\ No newline at end of file
+ const GError *op_error);
diff --git a/src/gs-overview-page.c b/src/gs-overview-page.c
index 7c08a8849..5a376ae4a 100644
--- a/src/gs-overview-page.c
+++ b/src/gs-overview-page.c
@@ -563,11 +563,30 @@ gs_overview_page_switch_to (GsPage *page)
gs_overview_page_load (self);
}
+static void
+gs_overview_page_refresh_cb (GsPluginLoader *plugin_loader,
+ GAsyncResult *result,
+ GsOverviewPage *self)
+{
+ gboolean success;
+ g_autoptr(GError) error = NULL;
+
+ success = gs_plugin_loader_job_action_finish (plugin_loader, result, &error);
+ if (!success &&
+ !g_error_matches (error, GS_PLUGIN_ERROR, GS_PLUGIN_ERROR_CANCELLED))
+ g_warning ("failed to refresh: %s", error->message);
+
+ if (success)
+ g_signal_emit_by_name (self->plugin_loader, "reload", 0, NULL);
+}
+
static void
third_party_response_cb (GtkInfoBar *info_bar,
gint response_id,
GsOverviewPage *self)
{
+ g_autoptr(GsPluginJob) plugin_job = NULL;
+
if (response_id == GTK_RESPONSE_YES)
fedora_third_party_enable (self);
else
@@ -575,6 +594,15 @@ third_party_response_cb (GtkInfoBar *info_bar,
self->third_party_needs_question = FALSE;
refresh_third_party_repo (self);
+
+ plugin_job = gs_plugin_job_newv (GS_PLUGIN_ACTION_REFRESH,
+ "interactive", FALSE,
+ "age", (guint64) 1,
+ NULL);
+ gs_plugin_loader_job_process_async (self->plugin_loader, plugin_job,
+ self->cancellable,
+ (GAsyncReadyCallback) gs_overview_page_refresh_cb,
+ self);
}
static gboolean
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]