From 114899f46e9c8077852580c247b78aeae46578ec Mon Sep 17 00:00:00 2001 From: nyx Date: Tue, 16 Feb 2016 22:55:05 +0300 Subject: [PATCH] Fixed memory leak when scheduling timeout and idle callbacks --- glib/Idle.cs | 21 ++++++++++++++++----- glib/Timeout.cs | 31 +++++++++++++++++++++---------- 2 files changed, 37 insertions(+), 15 deletions(-) diff --git a/glib/Idle.cs b/glib/Idle.cs index 189b3a8b0..36f50909f 100644 --- a/glib/Idle.cs +++ b/glib/Idle.cs @@ -51,7 +51,12 @@ namespace GLib { bool cont = idle_handler (); if (!cont) - Remove (); + { + lock (this) + { + Remove (); + } + } return cont; } catch (Exception e) { ExceptionManager.RaiseUnhandledException (e, false); @@ -70,8 +75,11 @@ namespace GLib { public static uint Add (IdleHandler hndlr) { IdleProxy p = new IdleProxy (hndlr); - p.ID = g_idle_add ((IdleHandlerInternal) p.proxy_handler, IntPtr.Zero); - Source.AddSourceHandler (p.ID, p); + lock (p) + { + p.ID = g_idle_add ((IdleHandlerInternal) p.proxy_handler, IntPtr.Zero); + Source.AddSourceHandler (p.ID, p); + } return p.ID; } @@ -82,8 +90,11 @@ namespace GLib { public static uint Add (IdleHandler hndlr, Priority priority) { IdleProxy p = new IdleProxy (hndlr); - p.ID = g_idle_add_full ((int)priority, (IdleHandlerInternal)p.proxy_handler, IntPtr.Zero, null); - Source.AddSourceHandler (p.ID, p); + lock (p) + { + p.ID = g_idle_add_full ((int)priority, (IdleHandlerInternal)p.proxy_handler, IntPtr.Zero, null); + Source.AddSourceHandler (p.ID, p); + } return p.ID; } diff --git a/glib/Timeout.cs b/glib/Timeout.cs index 2e68e068f..d0dc03c03 100644 --- a/glib/Timeout.cs +++ b/glib/Timeout.cs @@ -49,7 +49,12 @@ namespace GLib { bool cont = timeout_handler (); if (!cont) - Remove (); + { + lock (this) + { + Remove (); + } + } return cont; } catch (Exception e) { ExceptionManager.RaiseUnhandledException (e, false); @@ -65,9 +70,11 @@ namespace GLib { public static uint Add (uint interval, TimeoutHandler hndlr) { TimeoutProxy p = new TimeoutProxy (hndlr); - - p.ID = g_timeout_add (interval, (TimeoutHandlerInternal) p.proxy_handler, IntPtr.Zero); - Source.AddSourceHandler (p.ID, p); + lock (p) + { + p.ID = g_timeout_add (interval, (TimeoutHandlerInternal) p.proxy_handler, IntPtr.Zero); + Source.AddSourceHandler (p.ID, p); + } return p.ID; } @@ -78,9 +85,11 @@ namespace GLib { public static uint Add (uint interval, TimeoutHandler hndlr, Priority priority) { TimeoutProxy p = new TimeoutProxy (hndlr); - - p.ID = g_timeout_add_full ((int)priority, interval, (TimeoutHandlerInternal) p.proxy_handler, IntPtr.Zero, null); - Source.AddSourceHandler (p.ID, p); + lock (p) + { + p.ID = g_timeout_add_full ((int)priority, interval, (TimeoutHandlerInternal) p.proxy_handler, IntPtr.Zero, null); + Source.AddSourceHandler (p.ID, p); + } return p.ID; } @@ -91,9 +100,11 @@ namespace GLib { public static uint AddSeconds (uint interval, TimeoutHandler hndlr) { TimeoutProxy p = new TimeoutProxy (hndlr); - - p.ID = g_timeout_add_seconds (interval, (TimeoutHandlerInternal) p.proxy_handler, IntPtr.Zero); - Source.AddSourceHandler (p.ID, p); + lock (p) + { + p.ID = g_timeout_add_seconds (interval, (TimeoutHandlerInternal) p.proxy_handler, IntPtr.Zero); + Source.AddSourceHandler (p.ID, p); + } return p.ID; }