2002-09-29 Rachel Hestilow <hestilow@ximian.com>

* glue/canvas-proxy.c (update), glue/canvas-proxy-marshal.list:
	Marshal the array as a pointer for now.

	* gnome/voidObjectAffineSVPintSignal.cs: Added.
	* gnome/CanvasProxy.cs (Update): Use a custom signal handler.

svn path=/trunk/gtk-sharp/; revision=7892
This commit is contained in:
Rachel Hestilow 2002-09-30 02:21:06 +00:00
parent aa0ae0c644
commit 801634a502
7 changed files with 96 additions and 27 deletions

View file

@ -1,3 +1,11 @@
2002-09-29 Rachel Hestilow <hestilow@ximian.com>
* glue/canvas-proxy.c (update), glue/canvas-proxy-marshal.list:
Marshal the array as a pointer for now.
* gnome/voidObjectAffineSVPintSignal.cs: Added.
* gnome/CanvasProxy.cs (Update): Use a custom signal handler.
2002-09-23 Miguel de Icaza <miguel@ximian.com> 2002-09-23 Miguel de Icaza <miguel@ximian.com>
* gtk/Style.custom: bind it. * gtk/Style.custom: bind it.

View file

@ -47,22 +47,22 @@
#endif /* !G_ENABLE_DEBUG */ #endif /* !G_ENABLE_DEBUG */
/* VOID:OBJECT,DOUBLE,POINTER,INT (canvas-proxy-marshal.list:1) */ /* VOID:OBJECT,POINTER,POINTER,INT (canvas-proxy-marshal.list:1) */
void void
g_cclosure_user_marshal_VOID__OBJECT_DOUBLE_POINTER_INT (GClosure *closure, g_cclosure_user_marshal_VOID__OBJECT_POINTER_POINTER_INT (GClosure *closure,
GValue *return_value, GValue *return_value,
guint n_param_values, guint n_param_values,
const GValue *param_values, const GValue *param_values,
gpointer invocation_hint, gpointer invocation_hint,
gpointer marshal_data) gpointer marshal_data)
{ {
typedef void (*GMarshalFunc_VOID__OBJECT_DOUBLE_POINTER_INT) (gpointer data1, typedef void (*GMarshalFunc_VOID__OBJECT_POINTER_POINTER_INT) (gpointer data1,
gpointer arg_1, gpointer arg_1,
gdouble arg_2, gpointer arg_2,
gpointer arg_3, gpointer arg_3,
gint arg_4, gint arg_4,
gpointer data2); gpointer data2);
register GMarshalFunc_VOID__OBJECT_DOUBLE_POINTER_INT callback; register GMarshalFunc_VOID__OBJECT_POINTER_POINTER_INT callback;
register GCClosure *cc = (GCClosure*) closure; register GCClosure *cc = (GCClosure*) closure;
register gpointer data1, data2; register gpointer data1, data2;
@ -78,11 +78,11 @@ g_cclosure_user_marshal_VOID__OBJECT_DOUBLE_POINTER_INT (GClosure *closure,
data1 = g_value_peek_pointer (param_values + 0); data1 = g_value_peek_pointer (param_values + 0);
data2 = closure->data; data2 = closure->data;
} }
callback = (GMarshalFunc_VOID__OBJECT_DOUBLE_POINTER_INT) (marshal_data ? marshal_data : cc->callback); callback = (GMarshalFunc_VOID__OBJECT_POINTER_POINTER_INT) (marshal_data ? marshal_data : cc->callback);
callback (data1, callback (data1,
g_marshal_value_peek_object (param_values + 1), g_marshal_value_peek_object (param_values + 1),
g_marshal_value_peek_double (param_values + 2), g_marshal_value_peek_pointer (param_values + 2),
g_marshal_value_peek_pointer (param_values + 3), g_marshal_value_peek_pointer (param_values + 3),
g_marshal_value_peek_int (param_values + 4), g_marshal_value_peek_int (param_values + 4),
data2); data2);

View file

@ -6,8 +6,8 @@
G_BEGIN_DECLS G_BEGIN_DECLS
/* VOID:OBJECT,DOUBLE,POINTER,INT (canvas-proxy-marshal.list:1) */ /* VOID:OBJECT,POINTER,POINTER,INT (canvas-proxy-marshal.list:1) */
extern void g_cclosure_user_marshal_VOID__OBJECT_DOUBLE_POINTER_INT (GClosure *closure, extern void g_cclosure_user_marshal_VOID__OBJECT_POINTER_POINTER_INT (GClosure *closure,
GValue *return_value, GValue *return_value,
guint n_param_values, guint n_param_values,
const GValue *param_values, const GValue *param_values,

View file

@ -1,4 +1,4 @@
VOID:OBJECT,DOUBLE,POINTER,INT VOID:OBJECT,POINTER,POINTER,INT
DOUBLE:OBJECT,DOUBLE,DOUBLE,INT,INT,POINTER DOUBLE:OBJECT,DOUBLE,DOUBLE,INT,INT,POINTER
VOID:OBJECT,POINTER,POINTER,POINTER,POINTER VOID:OBJECT,POINTER,POINTER,POINTER,POINTER
VOID:OBJECT,INT,INT,INT,INT VOID:OBJECT,INT,INT,INT,INT

View file

@ -50,8 +50,8 @@ gtksharp_canvas_proxy_class_init (CanvasProxyClass *class)
G_SIGNAL_RUN_LAST, G_SIGNAL_RUN_LAST,
G_STRUCT_OFFSET (GnomeCanvasItemClass, update), G_STRUCT_OFFSET (GnomeCanvasItemClass, update),
NULL, NULL, NULL, NULL,
g_cclosure_user_marshal_VOID__OBJECT_DOUBLE_POINTER_INT, g_cclosure_user_marshal_VOID__OBJECT_POINTER_POINTER_INT,
G_TYPE_NONE, 3, G_TYPE_DOUBLE, G_TYPE_NONE, 3, G_TYPE_POINTER,
G_TYPE_POINTER, G_TYPE_INT); G_TYPE_POINTER, G_TYPE_INT);
/* void (* realize) (GnomeCanvasItem *item); */ /* void (* realize) (GnomeCanvasItem *item); */

View file

@ -26,7 +26,9 @@ namespace Gnome {
public event GtkSharp.UpdateHandler Update { public event GtkSharp.UpdateHandler Update {
add { add {
throw new NotImplementedException (); if (EventList["update"] == null)
Signals["update"] = new GtkSharp.Gnome.voidObjectAffineSVPintSignal(this, Handle, "update", value, System.Type.GetType("EventArgs"));
EventList.AddHandler("update", value);
} }
remove { remove {

View file

@ -0,0 +1,59 @@
// Generated File. Do not modify.
// <c> 2001-2002 Mike Kestner
namespace GtkSharp {
namespace Gnome {
using System;
using System.Runtime.InteropServices;
public delegate void voidObjectAffineSVPintDelegate(IntPtr arg0, IntPtr arg1, ref Art.SVP arg2, int arg3, int key);
public class voidObjectAffineSVPintSignal : SignalCallback {
private static voidObjectAffineSVPintDelegate _Delegate;
private static void voidObjectAffineSVPintCallback(IntPtr arg0, IntPtr arg1, ref Art.SVP arg2, int arg3, int key)
{
if (!_Instances.Contains(key))
throw new Exception("Unexpected signal key " + key);
voidObjectAffineSVPintSignal inst = (voidObjectAffineSVPintSignal) _Instances[key];
SignalArgs args = (SignalArgs) Activator.CreateInstance (inst._argstype);
args.Args = new object[3];
if (arg1 != IntPtr.Zero) {
double[] affine = new double[6];
Marshal.Copy (arg1, affine, 0, 6);
args.Args[0] = affine;
} else {
args.Args[0] = null;
}
arg2._Initialize ();
args.Args[1] = arg2;
args.Args[2] = arg3;
object[] argv = new object[2];
argv[0] = inst._obj;
argv[1] = args;
inst._handler.DynamicInvoke(argv);
}
[DllImport("gobject-2.0")] static extern void g_signal_connect_data(IntPtr obj, String name, voidObjectAffineSVPintDelegate cb, int key, IntPtr p, int flags);
public voidObjectAffineSVPintSignal(GLib.Object obj, IntPtr raw, String name, MulticastDelegate eh, Type argstype) : base(obj, eh, argstype)
{
if (_Delegate == null) {
_Delegate = new voidObjectAffineSVPintDelegate(voidObjectAffineSVPintCallback);
}
g_signal_connect_data(raw, name, _Delegate, _key, new IntPtr(0), 0);
}
~voidObjectAffineSVPintSignal()
{
_Instances.Remove(_key);
if(_Instances.Count == 0) {
_Delegate = null;
}
}
}
}
}