unit class Gnome::GObject::Signal;
# define method
method mouse-event ( :widget($w), :event($e)) { ... }
# get the window object
my Gnome::Gtk3::Window $w .= new( ... );
# define proper handler. you must study the GTK develper guides. you will
# then notice that C<connect-object> is a bit different than the real mcCoy.
my Callable $handler;
$handler = -> N-GObject $ignore-w, GdkEvent $e, OpaquePointer $ignore-d {
  self.mouse-event( :widget($w), :event($e) );
}
# connect signal to the handler
$w.connect-object( 'button-press-event', $handler);
It will be easier to use the register-signal() method defined in Gnome::GObject::Object.
# define method
method mouse-event ( :widget($w), :event($e), :$time) { ... }
# get the window object
my Gnome::Gtk3::Window $w .= new( ... );
# then register
$w.register-signal( self, 'mouse-event', 'button-press-event', :time(now));
Connects a callback function to a signal for a particular object.
method g_signal_connect_object( Str $signal, Callable $handler --> uint64 )
$signal; a string of the form signal-name::detail.
$handler; the callback to connect.
Emits a signal.
Note that g_signal_emit_by_name() resets the return value to the default if no handlers are connected.
g_signal_emit_by_name ( Str $signal, N-GObject $widget )
$signal; a string of the form "signal-name::detail".
$widget; widget to pass to the handler.
Disconnects a handler from an instance so it will not be called during any future or currently ongoing emissions of the signal it has been connected to. The handler_id becomes invalid and may be reused.
The handler_id has to be a valid signal handler id, connected to a signal of instance .
g_signal_handler_disconnect( int32 $handler_id )
$handler_id; Handler id of the handler to be disconnected.