2008-04-28 Mike Kestner <mkestner@novell.com>
* glib/Value.cs : Add GParam support and beef up the Boxed type marshaling to support types with New methods via reflection. svn path=/trunk/gtk-sharp/; revision=102064
This commit is contained in:
parent
d5e5c13a1f
commit
4afdaf6602
2 changed files with 24 additions and 1 deletions
|
@ -1,3 +1,8 @@
|
||||||
|
2008-04-28 Mike Kestner <mkestner@novell.com>
|
||||||
|
|
||||||
|
* glib/Value.cs : Add GParam support and beef up the Boxed
|
||||||
|
type marshaling to support types with New methods via reflection.
|
||||||
|
|
||||||
2008-04-28 Mike Kestner <mkestner@novell.com>
|
2008-04-28 Mike Kestner <mkestner@novell.com>
|
||||||
|
|
||||||
* glib/GType.cs : Add a few missing static fields.
|
* glib/GType.cs : Add a few missing static fields.
|
||||||
|
|
|
@ -24,6 +24,7 @@ namespace GLib {
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections;
|
using System.Collections;
|
||||||
|
using System.Reflection;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
|
|
||||||
[StructLayout (LayoutKind.Sequential)]
|
[StructLayout (LayoutKind.Sequential)]
|
||||||
|
@ -313,7 +314,14 @@ namespace GLib {
|
||||||
Type t = GType.LookupType (type);
|
Type t = GType.LookupType (type);
|
||||||
if (t == null)
|
if (t == null)
|
||||||
throw new Exception ("Unknown type " + new GType (type).ToString ());
|
throw new Exception ("Unknown type " + new GType (type).ToString ());
|
||||||
|
else if (t.IsSubclassOf (typeof (GLib.Opaque)))
|
||||||
|
return (GLib.Opaque) this;
|
||||||
|
|
||||||
|
MethodInfo mi = t.GetMethod ("New", BindingFlags.Static | BindingFlags.Public | BindingFlags.FlattenHierarchy);
|
||||||
|
if (mi == null)
|
||||||
return Marshal.PtrToStructure (boxed_ptr, t);
|
return Marshal.PtrToStructure (boxed_ptr, t);
|
||||||
|
else
|
||||||
|
return mi.Invoke (null, new object[] {boxed_ptr});
|
||||||
}
|
}
|
||||||
|
|
||||||
public object Val
|
public object Val
|
||||||
|
@ -340,6 +348,8 @@ namespace GLib {
|
||||||
return (string) this;
|
return (string) this;
|
||||||
else if (type == GType.Pointer.Val)
|
else if (type == GType.Pointer.Val)
|
||||||
return (IntPtr) this;
|
return (IntPtr) this;
|
||||||
|
else if (type == GType.Param.Val)
|
||||||
|
return g_value_get_param (ref this);
|
||||||
else if (type == ManagedValue.GType.Val)
|
else if (type == ManagedValue.GType.Val)
|
||||||
return ManagedValue.ObjectForWrapper (g_value_get_boxed (ref this));
|
return ManagedValue.ObjectForWrapper (g_value_get_boxed (ref this));
|
||||||
else if (g_type_is_a (type, GType.Object.Val))
|
else if (g_type_is_a (type, GType.Object.Val))
|
||||||
|
@ -380,6 +390,8 @@ namespace GLib {
|
||||||
IntPtr buf = Marshal.AllocHGlobal (Marshal.SizeOf (value.GetType()));
|
IntPtr buf = Marshal.AllocHGlobal (Marshal.SizeOf (value.GetType()));
|
||||||
Marshal.StructureToPtr (value, buf, false);
|
Marshal.StructureToPtr (value, buf, false);
|
||||||
g_value_set_pointer (ref this, buf);
|
g_value_set_pointer (ref this, buf);
|
||||||
|
} else if (type == GType.Param.Val) {
|
||||||
|
g_value_set_param (ref this, (IntPtr) value);
|
||||||
} else if (type == ManagedValue.GType.Val) {
|
} else if (type == ManagedValue.GType.Val) {
|
||||||
IntPtr wrapper = ManagedValue.WrapObject (value);
|
IntPtr wrapper = ManagedValue.WrapObject (value);
|
||||||
g_value_set_boxed (ref this, wrapper);
|
g_value_set_boxed (ref this, wrapper);
|
||||||
|
@ -438,6 +450,9 @@ namespace GLib {
|
||||||
[DllImport("libgobject-2.0-0.dll")]
|
[DllImport("libgobject-2.0-0.dll")]
|
||||||
static extern void g_value_set_object (ref Value val, IntPtr data);
|
static extern void g_value_set_object (ref Value val, IntPtr data);
|
||||||
|
|
||||||
|
[DllImport("libgobject-2.0-0.dll")]
|
||||||
|
static extern void g_value_set_param (ref Value val, IntPtr data);
|
||||||
|
|
||||||
[DllImport("libgobject-2.0-0.dll")]
|
[DllImport("libgobject-2.0-0.dll")]
|
||||||
static extern void g_value_set_pointer (ref Value val, IntPtr data);
|
static extern void g_value_set_pointer (ref Value val, IntPtr data);
|
||||||
|
|
||||||
|
@ -476,6 +491,9 @@ namespace GLib {
|
||||||
[DllImport("libgobject-2.0-0.dll")]
|
[DllImport("libgobject-2.0-0.dll")]
|
||||||
static extern IntPtr g_value_get_object (ref Value val);
|
static extern IntPtr g_value_get_object (ref Value val);
|
||||||
|
|
||||||
|
[DllImport("libgobject-2.0-0.dll")]
|
||||||
|
static extern IntPtr g_value_get_param (ref Value val);
|
||||||
|
|
||||||
[DllImport("libgobject-2.0-0.dll")]
|
[DllImport("libgobject-2.0-0.dll")]
|
||||||
static extern IntPtr g_value_get_pointer (ref Value val);
|
static extern IntPtr g_value_get_pointer (ref Value val);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue