summaryrefslogtreecommitdiffstats
path: root/patches/source/glib2/glib.bug.758823.diff
diff options
context:
space:
mode:
Diffstat (limited to 'patches/source/glib2/glib.bug.758823.diff')
-rw-r--r--patches/source/glib2/glib.bug.758823.diff40
1 files changed, 40 insertions, 0 deletions
diff --git a/patches/source/glib2/glib.bug.758823.diff b/patches/source/glib2/glib.bug.758823.diff
new file mode 100644
index 000000000..e92c03687
--- /dev/null
+++ b/patches/source/glib2/glib.bug.758823.diff
@@ -0,0 +1,40 @@
+From 30359e740953b596d6c3d980dba36dd131681a1f Mon Sep 17 00:00:00 2001
+From: Allison Ryan Lortie <desrt@desrt.ca>
+Date: Mon, 30 Nov 2015 10:13:46 -0500
+Subject: file monitors: reorder some code to avoid segfault
+
+We must initialise '->source' before we use fields inside of it.
+
+https://bugzilla.gnome.org/show_bug.cgi?id=758823
+---
+ gio/glocalfilemonitor.c | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+diff --git a/gio/glocalfilemonitor.c b/gio/glocalfilemonitor.c
+index dbd62ec..49a4dd2 100644
+--- a/gio/glocalfilemonitor.c
++++ b/gio/glocalfilemonitor.c
+@@ -748,6 +748,9 @@ g_local_file_monitor_start (GLocalFileMonitor *local_monitor,
+
+ g_assert (!local_monitor->source);
+
++ source = g_file_monitor_source_new (local_monitor, filename, is_directory, flags);
++ local_monitor->source = source; /* owns the ref */
++
+ if (is_directory && !class->mount_notify && (flags & G_FILE_MONITOR_WATCH_MOUNTS))
+ {
+ #ifdef G_OS_WIN32
+@@ -771,9 +774,6 @@ g_local_file_monitor_start (GLocalFileMonitor *local_monitor,
+ #endif
+ }
+
+- source = g_file_monitor_source_new (local_monitor, filename, is_directory, flags);
+- local_monitor->source = source; /* owns the ref */
+-
+ G_LOCAL_FILE_MONITOR_GET_CLASS (local_monitor)->start (local_monitor,
+ source->dirname, source->basename, source->filename,
+ source);
+--
+cgit v0.12
+
+