info: Use gnome-software for showing the list of updates if installed
Resolves: https://bugzilla.gnome.org/show_bug.cgi?id=710595
This commit is contained in:
parent
93997f5ee8
commit
33cc59d726
2 changed files with 25 additions and 5 deletions
|
@ -5,6 +5,7 @@ INCLUDES = \
|
||||||
$(INFO_PANEL_CFLAGS) \
|
$(INFO_PANEL_CFLAGS) \
|
||||||
-DGNOMELOCALEDIR="\"$(datadir)/locale\"" \
|
-DGNOMELOCALEDIR="\"$(datadir)/locale\"" \
|
||||||
-DDATADIR="\"$(datadir)\"" \
|
-DDATADIR="\"$(datadir)\"" \
|
||||||
|
-DBINDIR="\"$(bindir)\"" \
|
||||||
$(NULL)
|
$(NULL)
|
||||||
|
|
||||||
noinst_LTLIBRARIES = libinfo.la
|
noinst_LTLIBRARIES = libinfo.la
|
||||||
|
|
|
@ -1730,18 +1730,37 @@ on_pk_signal (GDBusProxy *proxy,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
does_gnome_software_exist (void)
|
||||||
|
{
|
||||||
|
return g_file_test (BINDIR "/gnome-software", G_FILE_TEST_EXISTS);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
on_updates_button_clicked (GtkWidget *widget,
|
on_updates_button_clicked (GtkWidget *widget,
|
||||||
CcInfoPanel *self)
|
CcInfoPanel *self)
|
||||||
{
|
{
|
||||||
GError *error;
|
GError *error = NULL;
|
||||||
error = NULL;
|
gboolean ret;
|
||||||
g_spawn_command_line_async ("gpk-update-viewer", &error);
|
gchar **argv;
|
||||||
if (error != NULL)
|
|
||||||
|
argv = g_new0 (gchar *, 3);
|
||||||
|
if (does_gnome_software_exist ())
|
||||||
{
|
{
|
||||||
g_warning ("unable to launch Software Updates: %s", error->message);
|
argv[0] = g_build_filename (BINDIR, "gnome-software", NULL);
|
||||||
|
argv[1] = g_strdup_printf ("--mode=updates");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
argv[0] = g_build_filename (BINDIR, "gpk-update-viewer", NULL);
|
||||||
|
}
|
||||||
|
ret = g_spawn_async (NULL, argv, NULL, 0, NULL, NULL, NULL, &error);
|
||||||
|
if (!ret)
|
||||||
|
{
|
||||||
|
g_warning ("Failed to spawn %s: %s", argv[0], error->message);
|
||||||
g_error_free (error);
|
g_error_free (error);
|
||||||
}
|
}
|
||||||
|
g_strfreev (argv);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
|
|
Loading…
Add table
Reference in a new issue