2009-05-06 Mike Kestner <mkestner@novell.com>

* glib/Idle.cs: add a Remove overload for consistency.
	* glib/Timeout.cs: add a Remove overload for consistency.
	[Fixes #356138]

svn path=/trunk/gtk-sharp/; revision=133702
This commit is contained in:
Mike Kestner 2009-05-07 01:22:41 +00:00
parent 60618ca6f0
commit e91a71949a
3 changed files with 42 additions and 0 deletions

View file

@ -1,3 +1,9 @@
2009-05-06 Mike Kestner <mkestner@novell.com>
* glib/Idle.cs: add a Remove overload for consistency.
* glib/Timeout.cs: add a Remove overload for consistency.
[Fixes #356138]
2009-05-06 Mike Kestner <mkestner@novell.com> 2009-05-06 Mike Kestner <mkestner@novell.com>
* generator/EnumGen.cs: support 1L long values or explicit types. * generator/EnumGen.cs: support 1L long values or explicit types.

View file

@ -94,6 +94,11 @@ namespace GLib {
[DllImport("libglib-2.0-0.dll")] [DllImport("libglib-2.0-0.dll")]
static extern bool g_source_remove_by_funcs_user_data (Delegate d, IntPtr data); static extern bool g_source_remove_by_funcs_user_data (Delegate d, IntPtr data);
public static void Remove (uint id)
{
Source.Remove (id);
}
public static bool Remove (IdleHandler hndlr) public static bool Remove (IdleHandler hndlr)
{ {
bool result = false; bool result = false;

View file

@ -25,6 +25,7 @@
namespace GLib { namespace GLib {
using System; using System;
using System.Collections;
using System.Runtime.InteropServices; using System.Runtime.InteropServices;
public delegate bool TimeoutHandler (); public delegate bool TimeoutHandler ();
@ -99,6 +100,36 @@ namespace GLib {
return p.ID; return p.ID;
} }
public static void Remove (uint id)
{
Source.Remove (id);
}
[DllImport("libglib-2.0-0.dll")]
static extern bool g_source_remove_by_funcs_user_data (Delegate d, IntPtr data);
public static bool Remove (TimeoutHandler hndlr)
{
bool result = false;
ArrayList keys = new ArrayList ();
lock (Source.source_handlers) {
foreach (uint code in Source.source_handlers.Keys) {
TimeoutProxy p = Source.source_handlers [code] as TimeoutProxy;
if (p != null && p.real_handler == hndlr) {
keys.Add (code);
result = g_source_remove_by_funcs_user_data (p.proxy_handler, IntPtr.Zero);
}
}
foreach (object key in keys)
Source.source_handlers.Remove (key);
}
return result;
}
} }
} }