diff --git a/src/sugar/sugar-key-grabber.c b/src/sugar/sugar-key-grabber.c index 65476ef5..8139ce13 100644 --- a/src/sugar/sugar-key-grabber.c +++ b/src/sugar/sugar-key-grabber.c @@ -83,8 +83,9 @@ sugar_key_grabber_class_init(SugarKeyGrabberClass *grabber_class) G_SIGNAL_RUN_LAST | G_SIGNAL_ACTION, G_STRUCT_OFFSET (SugarKeyGrabberClass, key_pressed), NULL, NULL, - sugar_marshal_BOOLEAN__UINT_UINT, - G_TYPE_BOOLEAN, 2, + sugar_marshal_BOOLEAN__UINT_UINT_UINT, + G_TYPE_BOOLEAN, 3, + G_TYPE_UINT, G_TYPE_UINT, G_TYPE_UINT); signals[KEY_RELEASED] = g_signal_new ("key-released", @@ -92,8 +93,9 @@ sugar_key_grabber_class_init(SugarKeyGrabberClass *grabber_class) G_SIGNAL_RUN_LAST | G_SIGNAL_ACTION, G_STRUCT_OFFSET (SugarKeyGrabberClass, key_released), NULL, NULL, - sugar_marshal_BOOLEAN__UINT_UINT, - G_TYPE_BOOLEAN, 2, + sugar_marshal_BOOLEAN__UINT_UINT_UINT, + G_TYPE_BOOLEAN, 3, + G_TYPE_UINT, G_TYPE_UINT, G_TYPE_UINT); } @@ -123,7 +125,7 @@ filter_events(GdkXEvent *xevent, GdkEvent *event, gpointer data) if (xev->type == KeyRelease) { int return_value; g_signal_emit (grabber, signals[KEY_RELEASED], 0, xev->xkey.keycode, - xev->xkey.state, &return_value); + xev->xkey.state, xev->xkey.time, &return_value); if(return_value) return GDK_FILTER_REMOVE; } @@ -131,7 +133,7 @@ filter_events(GdkXEvent *xevent, GdkEvent *event, gpointer data) if (xev->type == KeyPress) { int return_value; g_signal_emit (grabber, signals[KEY_PRESSED], 0, xev->xkey.keycode, - xev->xkey.state, &return_value); + xev->xkey.state, xev->xkey.time, &return_value); if(return_value) return GDK_FILTER_REMOVE; } diff --git a/src/sugar/sugar-marshal.list b/src/sugar/sugar-marshal.list index 41ce6202..cb5ec080 100644 --- a/src/sugar/sugar-marshal.list +++ b/src/sugar/sugar-marshal.list @@ -1 +1 @@ -BOOLEAN:UINT,UINT +BOOLEAN:UINT,UINT,UINT