2004-08-25 Mike Kestner <mkestner@ximian.com>
* generator/Signal.cs : use typeof instead of Type.GetType to specify the event args type. * glib/ObjectManager.cs : beef up the type lookup code using Assembly.LoadWithPartialName to fix a very popular win32 bug. [Fixes #61139 and friends] Thanks to John Luke for expert patch testing on win32. svn path=/trunk/gtk-sharp/; revision=32831
This commit is contained in:
parent
0343bf93e6
commit
7a395905ac
3 changed files with 27 additions and 10 deletions
|
@ -1,3 +1,12 @@
|
||||||
|
2004-08-25 Mike Kestner <mkestner@ximian.com>
|
||||||
|
|
||||||
|
* generator/Signal.cs : use typeof instead of Type.GetType to
|
||||||
|
specify the event args type.
|
||||||
|
* glib/ObjectManager.cs : beef up the type lookup code using
|
||||||
|
Assembly.LoadWithPartialName to fix a very popular win32 bug.
|
||||||
|
[Fixes #61139 and friends] Thanks to John Luke for expert
|
||||||
|
patch testing on win32.
|
||||||
|
|
||||||
2004-08-25 John Luke <john.luke@gmail.com>
|
2004-08-25 John Luke <john.luke@gmail.com>
|
||||||
|
|
||||||
* glib/MainLoop.cs: MainLoop implementation by Jeroen
|
* glib/MainLoop.cs: MainLoop implementation by Jeroen
|
||||||
|
|
|
@ -268,20 +268,14 @@ namespace GtkSharp.Generation {
|
||||||
sw.WriteLine("\t\t\t\tif (value.Method.GetCustomAttributes(typeof(GLib.ConnectBeforeAttribute), false).Length > 0) {");
|
sw.WriteLine("\t\t\t\tif (value.Method.GetCustomAttributes(typeof(GLib.ConnectBeforeAttribute), false).Length > 0) {");
|
||||||
sw.WriteLine("\t\t\t\t\tif (BeforeHandlers[" + cname + "] == null)");
|
sw.WriteLine("\t\t\t\t\tif (BeforeHandlers[" + cname + "] == null)");
|
||||||
sw.Write("\t\t\t\t\t\tBeforeSignals[" + cname + "] = new " + qual_marsh);
|
sw.Write("\t\t\t\t\t\tBeforeSignals[" + cname + "] = new " + qual_marsh);
|
||||||
sw.Write("(this, " + cname + ", value, System.Type.GetType(\"" + EventArgsQualifiedName);
|
sw.Write("(this, " + cname + ", value, typeof (" + EventArgsQualifiedName + "), 0);");
|
||||||
if (EventArgsQualifiedName != "System.EventArgs")
|
|
||||||
sw.Write("," + gen_info.AssemblyName);
|
|
||||||
sw.WriteLine("\"), 0);");
|
|
||||||
sw.WriteLine("\t\t\t\t\telse");
|
sw.WriteLine("\t\t\t\t\telse");
|
||||||
sw.WriteLine("\t\t\t\t\t\t((GLib.SignalCallback) BeforeSignals [{0}]).AddDelegate (value);", cname);
|
sw.WriteLine("\t\t\t\t\t\t((GLib.SignalCallback) BeforeSignals [{0}]).AddDelegate (value);", cname);
|
||||||
sw.WriteLine("\t\t\t\t\tBeforeHandlers.AddHandler(" + cname + ", value);");
|
sw.WriteLine("\t\t\t\t\tBeforeHandlers.AddHandler(" + cname + ", value);");
|
||||||
sw.WriteLine("\t\t\t\t} else {");
|
sw.WriteLine("\t\t\t\t} else {");
|
||||||
sw.WriteLine("\t\t\t\t\tif (AfterHandlers[" + cname + "] == null)");
|
sw.WriteLine("\t\t\t\t\tif (AfterHandlers[" + cname + "] == null)");
|
||||||
sw.Write("\t\t\t\t\t\tAfterSignals[" + cname + "] = new " + qual_marsh);
|
sw.Write("\t\t\t\t\t\tAfterSignals[" + cname + "] = new " + qual_marsh);
|
||||||
sw.Write("(this, " + cname + ", value, System.Type.GetType(\"" + EventArgsQualifiedName);
|
sw.Write("(this, " + cname + ", value, typeof (" + EventArgsQualifiedName + "), 1);");
|
||||||
if (EventArgsQualifiedName != "System.EventArgs")
|
|
||||||
sw.Write("," + gen_info.AssemblyName);
|
|
||||||
sw.WriteLine("\"), 1);");
|
|
||||||
sw.WriteLine("\t\t\t\t\telse");
|
sw.WriteLine("\t\t\t\t\telse");
|
||||||
sw.WriteLine("\t\t\t\t\t\t((GLib.SignalCallback) AfterSignals [{0}]).AddDelegate (value);", cname);
|
sw.WriteLine("\t\t\t\t\t\t((GLib.SignalCallback) AfterSignals [{0}]).AddDelegate (value);", cname);
|
||||||
sw.WriteLine("\t\t\t\t\tAfterHandlers.AddHandler(" + cname + ", value);");
|
sw.WriteLine("\t\t\t\t\tAfterHandlers.AddHandler(" + cname + ", value);");
|
||||||
|
|
|
@ -46,7 +46,7 @@ namespace GLib {
|
||||||
mangled = (string)types[typename];
|
mangled = (string)types[typename];
|
||||||
else
|
else
|
||||||
mangled = GetExpected (typename);
|
mangled = GetExpected (typename);
|
||||||
Type t = Type.GetType (mangled);
|
Type t = LookupType (mangled);
|
||||||
|
|
||||||
// if null, try to get a parent type
|
// if null, try to get a parent type
|
||||||
if (t == null)
|
if (t == null)
|
||||||
|
@ -116,6 +116,20 @@ namespace GLib {
|
||||||
[DllImport("glibsharpglue")]
|
[DllImport("glibsharpglue")]
|
||||||
static extern IntPtr gtksharp_get_type_name_for_id (int typ);
|
static extern IntPtr gtksharp_get_type_name_for_id (int typ);
|
||||||
|
|
||||||
|
static Type LookupType (string mangled)
|
||||||
|
{
|
||||||
|
string[] toks = mangled.Split (',');
|
||||||
|
if (toks.Length < 2)
|
||||||
|
throw new ArgumentException ("mangled not properly formatted: " + mangled);
|
||||||
|
|
||||||
|
Assembly a = Assembly.LoadWithPartialName (toks [1]);
|
||||||
|
|
||||||
|
if (a == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
return a.GetType (toks [0]);
|
||||||
|
}
|
||||||
|
|
||||||
static Type GetValidParentType (IntPtr raw)
|
static Type GetValidParentType (IntPtr raw)
|
||||||
{
|
{
|
||||||
int type_id = gtksharp_get_type_id (raw);
|
int type_id = gtksharp_get_type_id (raw);
|
||||||
|
@ -130,7 +144,7 @@ namespace GLib {
|
||||||
mangled = (string)types[typename];
|
mangled = (string)types[typename];
|
||||||
else
|
else
|
||||||
mangled = GetExpected (typename);
|
mangled = GetExpected (typename);
|
||||||
t = Type.GetType (mangled);
|
t = LookupType (mangled);
|
||||||
if (t != null) {
|
if (t != null) {
|
||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue