2005-08-26 John Luke <john.luke@gmail.com>

* glib/Signal.cs: deal with obj.Handle == IntPtr.Zero
        to avoid assertions


svn path=/trunk/gtk-sharp/; revision=48959
This commit is contained in:
John Luke 2005-08-27 00:27:42 +00:00
parent 32e6f7df76
commit a12a4b48f0
2 changed files with 14 additions and 3 deletions

View file

@ -1,3 +1,8 @@
2005-08-26 John Luke <john.luke@gmail.com>
* glib/Signal.cs: deal with obj.Handle == IntPtr.Zero
to avoid assertions
2005-08-25 Mike Kestner <mkestner@novell.com> 2005-08-25 Mike Kestner <mkestner@novell.com>
* configure.in.in : move GACUTIL check forward ahead of a use. * configure.in.in : move GACUTIL check forward ahead of a use.

View file

@ -70,6 +70,7 @@ namespace GLib {
this.marshaler = marshaler; this.marshaler = marshaler;
gc_handle = GCHandle.Alloc (this); gc_handle = GCHandle.Alloc (this);
IntPtr native_key = GLib.Marshaller.StringToPtrGStrdup (name + "_signal_marshaler"); IntPtr native_key = GLib.Marshaller.StringToPtrGStrdup (name + "_signal_marshaler");
if (handle != IntPtr.Zero)
g_object_set_data_full (handle, native_key, (IntPtr) gc_handle, notify); g_object_set_data_full (handle, native_key, (IntPtr) gc_handle, notify);
GLib.Marshaller.Free (native_key); GLib.Marshaller.Free (native_key);
} }
@ -82,7 +83,11 @@ namespace GLib {
public static Signal Lookup (GLib.Object obj, string name, Delegate marshaler) public static Signal Lookup (GLib.Object obj, string name, Delegate marshaler)
{ {
IntPtr native_key = GLib.Marshaller.StringToPtrGStrdup (name + "_signal_marshaler"); IntPtr native_key = GLib.Marshaller.StringToPtrGStrdup (name + "_signal_marshaler");
IntPtr data = g_object_get_data (obj.Handle, native_key); IntPtr data;
if (obj.Handle == IntPtr.Zero)
data = IntPtr.Zero;
else
data = g_object_get_data (obj.Handle, native_key);
GLib.Marshaller.Free (native_key); GLib.Marshaller.Free (native_key);
if (data == IntPtr.Zero) if (data == IntPtr.Zero)
return new Signal (obj, name, marshaler); return new Signal (obj, name, marshaler);
@ -152,6 +157,7 @@ namespace GLib {
void DisconnectObject () void DisconnectObject ()
{ {
IntPtr native_key = GLib.Marshaller.StringToPtrGStrdup (name + "_signal_marshaler"); IntPtr native_key = GLib.Marshaller.StringToPtrGStrdup (name + "_signal_marshaler");
if (handle != IntPtr.Zero)
g_object_set_data (handle, native_key, IntPtr.Zero); g_object_set_data (handle, native_key, IntPtr.Zero);
GLib.Marshaller.Free (native_key); GLib.Marshaller.Free (native_key);
} }