[recipes/check-dbus-proxy-error] utils: Fix potential NULL pointer use
- From: Matthew Leeds <mwleeds src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [recipes/check-dbus-proxy-error] utils: Fix potential NULL pointer use
- Date: Sun, 16 Feb 2020 18:34:05 +0000 (UTC)
commit bab88752ae692873015285b6536b8ff461871def
Author: Matthew Leeds <matthew leeds endlessm com>
Date: Sun Feb 16 10:30:46 2020 -0800
utils: Fix potential NULL pointer use
Check if g_dbus_proxy_new_sync() returned NULL before using the value. I
don't know if this happens in practice.
src/gr-utils.c | 26 ++++++++++++++++----------
1 file changed, 16 insertions(+), 10 deletions(-)
---
diff --git a/src/gr-utils.c b/src/gr-utils.c
index 8f14552..4199ef2 100644
--- a/src/gr-utils.c
+++ b/src/gr-utils.c
@@ -376,14 +376,15 @@ portal_available (GtkWindow *window,
g_autoptr(GDBusProxy) proxy = NULL;
g_autofree char *owner = NULL;
g_autoptr(GVariant) version = NULL;
- const char *message1;
- const char *message2;
+ g_autoptr(GError) local_error = NULL;
+ g_autofree char *message1 = NULL;
+ g_autofree char *message2 = NULL;
GtkWidget *dialog;
bus = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, NULL);
if (!bus) {
- message1 = _("Could not connect to the session bus from inside the Flatpak sandbox.");
- message2 = _("Certain functionality will not be available.");
+ message1 = g_strdup (_("Could not connect to the session bus from inside the Flatpak
sandbox."));
+ message2 = g_strdup (_("Certain functionality will not be available."));
goto dialog;
}
@@ -394,7 +395,12 @@ portal_available (GtkWindow *window,
"/org/freedesktop/portal/desktop",
interface,
NULL,
- NULL);
+ &local_error);
+ if (proxy == NULL) {
+ message1 = g_strdup_printf (_("Could not create D-Bus proxy for
org.freedesktop.portal.Desktop interface %s"), interface);
+ message2 = g_strdup_printf (_("Error: %s"), local_error->message);
+ goto dialog;
+ }
owner = g_dbus_proxy_get_name_owner (proxy);
version = g_dbus_proxy_get_cached_property (proxy, "version");
@@ -403,15 +409,15 @@ portal_available (GtkWindow *window,
return TRUE;
if (strcmp (interface, "org.freedesktop.portal.FileChooser") == 0)
- message1 = _("Missing the desktop portal needed to open files from inside a Flatpak
sandbox.");
+ message1 = g_strdup (_("Missing the desktop portal needed to open files from inside a
Flatpak sandbox."));
else if (strcmp (interface, "org.freedesktop.portal.Print") == 0)
- message1 = _("Missing the desktop portal needed to print from inside a Flatpak sandbox.");
+ message1 = g_strdup (_("Missing the desktop portal needed to print from inside a Flatpak
sandbox."));
else if (strcmp (interface, "org.freedesktop.portal.OpenURI") == 0)
- message1 = _("Missing the desktop portal needed to open URLs from inside a Flatpak
sandbox.");
+ message1 = g_strdup (_("Missing the desktop portal needed to open URLs from inside a Flatpak
sandbox."));
else
- message1 = "";
+ message1 = g_strdup ("");
- message2 = _("Please install xdg-desktop-portal and xdg-desktop-portal-gtk on your system");
+ message2 = g_strdup (_("Please install xdg-desktop-portal and xdg-desktop-portal-gtk on your
system"));
dialog:
dialog = gtk_message_dialog_new (window,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]