2015-02-20 14:29:43 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<?xml version='1.0' encoding="UTF-8"?>  
						 
					
						
							
								
									
										
										
										
											2012-04-23 02:45:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< !DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								               "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
							 
						 
					
						
							
								
									
										
										
										
											2010-01-07 10:47:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								]>
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<chapter  id= "chapter-signal" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  <title > The GObject messaging system</title> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  <sect1  id= "closure" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    <title > Closures</title> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      Closures are central to the concept of asynchronous signal delivery
							 
						 
					
						
							
								
									
										
										
										
											2007-11-13 07:10:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      which is widely used throughout GTK+ and GNOME applications. A closure is an 
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      abstraction, a generic representation of a callback. It is a small structure
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      which contains three objects:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      <itemizedlist > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        <listitem > <para > a function pointer (the callback itself) whose prototype looks like:
							 
						 
					
						
							
								
									
										
										
										
											2014-09-18 16:41:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<informalexample > <programlisting >  
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								return_type function_callback (… , gpointer user_data);
							 
						 
					
						
							
								
									
										
										
										
											2014-09-18 16:41:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								</programlisting> </informalexample>  
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        </para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								           the <parameter > user_data</parameter>  pointer which is passed to the callback upon invocation of the closure
							 
						 
					
						
							
								
									
										
										
										
											2004-01-22 18:39:45 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								          </para> </listitem> 
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        <listitem > <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								           a function pointer which represents the destructor of the closure: whenever the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								           closure's refcount reaches zero, this function will be called before the closure
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								           structure is freed.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          </para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      </itemizedlist> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    <para > 
							 
						 
					
						
							
								
									
										
										
										
											2010-09-19 21:50:31 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      The <link  linkend= "GClosure" > <type > GClosure</type> </link>  structure represents the common functionality of all
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      closure implementations: there exists a different closure implementation for
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      each separate runtime which wants to use the GObject type system.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      <footnote > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2007-11-13 07:10:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        In practice, closures sit at the boundary of language runtimes: if you are
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        writing Python code and one of your Python callbacks receives a signal from
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        a GTK+ widget, the C code in GTK+ needs to execute your Python
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        code. The closure invoked by the GTK+ object invokes the Python callback:
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        it behaves as a normal C object for GTK+ and as a normal Python object for
							 
						 
					
						
							
								
									
										
										
										
											2007-11-13 07:10:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        Python code.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      </para> </footnote> 
							 
						 
					
						
							
								
									
										
										
										
											2010-09-19 21:50:31 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      The GObject library provides a simple <link  linkend= "GCClosure" > <type > GCClosure</type> </link>  type which
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      is a specific implementation of closures to be used with C/C++ callbacks.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    <para > 
							 
						 
					
						
							
								
									
										
										
										
											2010-09-19 21:50:31 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      A <link  linkend= "GClosure" > <type > GClosure</type> </link>  provides simple services:
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      <itemizedlist > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        <listitem > <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          Invocation (<function > <link  linkend= "g-closure-invoke" > g_closure_invoke</link> </function> ): this is what closures 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          were created for: they hide the details of callback invocation from the
							 
						 
					
						
							
								
									
										
										
										
											2007-11-13 07:10:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								          callback invoker.</para> 
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        <listitem > <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          Notification: the closure notifies listeners of certain events such as
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          closure invocation, closure invalidation and closure finalization. Listeners
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          can be registered with <function > <link  linkend= "g-closure-add-finalize-notifier" > g_closure_add_finalize_notifier</link> </function> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          (finalization notification), <function > <link  linkend= "g-closure-add-invalidate-notifier" > g_closure_add_invalidate_notifier</link> </function>  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          (invalidation notification) and 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          <function > <link  linkend= "g-closure-add-marshal-guards" > g_closure_add_marshal_guards</link> </function>  (invocation notification).
							 
						 
					
						
							
								
									
										
										
										
											2007-11-13 07:10:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								          There exist symmetric deregistration functions for finalization and invalidation
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								          events (<function > <link  linkend= "g-closure-remove-finalize-notifier" > g_closure_remove_finalize_notifier</link> </function>  and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          <function > <link  linkend= "g-closure-remove-invalidate-notifier" > g_closure_remove_invalidate_notifier</link> </function> ) but not for the invocation 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          process.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          <footnote > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2007-11-13 07:10:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            Closures are reference counted and notify listeners of their destruction in a two-stage
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            process: the invalidation notifiers are invoked before the finalization notifiers.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          </para> </footnote> </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      </itemizedlist> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    <sect2 > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      <title > C Closures</title> 
							 
						 
					
						
							
								
									
										
										
										
											2004-01-22 18:39:45 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      <para > 
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        If you are using C or C++
							 
						 
					
						
							
								
									
										
										
										
											2010-09-19 21:50:31 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        to connect a callback to a given event, you will either use simple <link  linkend= "GCClosure" > <type > GCClosure</type> </link> s
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        which have a pretty minimal API or the even simpler <function > <link  linkend= "g-signal-connect" > g_signal_connect</link> </function>  
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        functions (which will be presented a bit later).
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        <function > <link  linkend= "g-cclosure-new" > g_cclosure_new</link> </function>  will create a new closure which can invoke the
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        user-provided callback_func with the user-provided
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        <parameter > user_data</parameter>  as its last parameter. When the closure
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        is finalized (second stage of the destruction process), it will invoke
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        the <parameter > destroy_data</parameter>  function if the user has
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        supplied one.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        <function > <link  linkend= "g-cclosure-new-swap" > g_cclosure_new_swap</link> </function>  will create a new closure which can invoke the
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        user-provided <parameter > callback_func</parameter>  with the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        user-provided <parameter > user_data</parameter>  as its first parameter
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        (instead of being the 
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        last parameter as with <function > <link  linkend= "g-cclosure-new" > g_cclosure_new</link> </function> ). When the closure
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        is finalized (second stage of the destruction process), it will invoke
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        the <parameter > destroy_data</parameter>  function if the user has
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        supplied one.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    </sect2> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    <sect2 > 
							 
						 
					
						
							
								
									
										
										
										
											2007-11-13 07:10:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      <title > Non-C closures (for the fearless)</title> 
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      <para > 
							 
						 
					
						
							
								
									
										
										
										
											2007-11-13 07:10:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        As was explained above, closures hide the details of callback invocation. In C,
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        callback invocation is just like function invocation: it is a matter of creating
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        the correct stack frame for the called function and executing a <emphasis > call</emphasis> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        assembly instruction.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        C closure marshallers transform the array of GValues which represent 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        the parameters to the target function into a C-style function parameter list, invoke
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        the user-supplied C function with this new parameter list, get the return value of the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        function, transform it into a GValue and return this GValue to the marshaller caller.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      </para> 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        A generic C closure marshaller is available as
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        <link  linkend= "g-cclosure-marshal-generic" > <function > g_cclosure_marshal_generic</function> </link> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        which implements marshalling for all function types using libffi. Custom
							 
						 
					
						
							
								
									
										
										
										
											2015-02-24 08:50:53 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        marshallers for different types are not needed apart from performance
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        critical code where the libffi-based marshaller may be too slow.
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        An example of a custom marshaller is given below, illustrating how
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        <type > GValue</type> s can be converted to a C function call. The
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        marshaller is for a C function which takes an integer as its first
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        parameter and returns void.
							 
						 
					
						
							
								
									
										
										
										
											2014-09-18 16:41:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<informalexample > <programlisting >  
						 
					
						
							
								
									
										
										
										
											2004-01-22 18:39:45 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								g_cclosure_marshal_VOID__INT (GClosure     *closure,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                              GValue       *return_value,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                              guint         n_param_values,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                              const GValue *param_values,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                              gpointer      invocation_hint,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                              gpointer      marshal_data)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  typedef void (*GMarshalFunc_VOID__INT) (gpointer     data1,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                          gint         arg_1,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                          gpointer     data2);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  register GMarshalFunc_VOID__INT callback;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  register GCClosure *cc = (GCClosure*) closure;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  register gpointer data1, data2;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  g_return_if_fail (n_param_values == 2);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  data1 = g_value_peek_pointer (param_values + 0);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  data2 = closure->data;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  callback = (GMarshalFunc_VOID__INT) (marshal_data ? marshal_data : cc->callback);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  callback (data1,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            g_marshal_value_peek_int (param_values + 1),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            data2);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2014-09-18 16:41:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								</programlisting> </informalexample>  
						 
					
						
							
								
									
										
										
										
											2004-01-22 18:39:45 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								      </para> 
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  
							 
						 
					
						
							
								
									
										
										
										
											2004-01-22 18:39:45 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								      <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        There exist other kinds of marshallers, for example there is a generic
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        Python marshaller which is used by all Python closures (a Python closure
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        is used to invoke a callback written in Python). This Python marshaller
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        transforms the input GValue list representing the function parameters
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        into a Python tuple which is the equivalent structure in Python.
							 
						 
					
						
							
								
									
										
										
										
											2004-01-22 18:39:45 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								      </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    </sect2> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  </sect1> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  <sect1  id= "signal" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    <title > Signals</title> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      GObject's signals have nothing to do with standard UNIX signals: they connect 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      arbitrary application-specific events with any number of listeners.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      For example, in GTK+, every user event (keystroke or mouse move) is received
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      from the windowing system and generates a GTK+ event in the form of a signal emission
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      on the widget object instance.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      Each signal is registered in the type system together with the type on which
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      it can be emitted: users of the type are said to <emphasis > connect</emphasis> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      to the signal on a given type instance when they register a closure to be 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      invoked upon the signal emission. Users can also emit the signal by themselves 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      or stop the emission of the signal from within one of the closures connected 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      to the signal.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      When a signal is emitted on a given type instance, all the closures
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      connected to this signal on this type instance will be invoked. All the closures
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      connected to such a signal represent callbacks whose signature looks like:
							 
						 
					
						
							
								
									
										
										
										
											2014-09-18 16:41:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<informalexample > <programlisting >  
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								return_type function_callback (gpointer instance, …, gpointer user_data);
							 
						 
					
						
							
								
									
										
										
										
											2014-09-18 16:41:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								</programlisting> </informalexample>  
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    </para> 
							 
						 
					
						
							
								
									
										
										
										
											2004-01-22 18:39:45 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    <sect2  id= "signal-registration" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      <title > Signal registration</title> 
							 
						 
					
						
							
								
									
										
										
										
											2004-01-22 18:39:45 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										To register a new signal on an existing type, we can use any of <function > <link  linkend= "g-signal-newv" > g_signal_newv</link> </function> ,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										<function > <link  linkend= "g-signal-new-valist" > g_signal_new_valist</link> </function>  or <function > <link  linkend= "g-signal-new" > g_signal_new</link> </function>  functions:
							 
						 
					
						
							
								
									
										
										
										
											2014-09-18 16:41:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<informalexample > <programlisting >  
						 
					
						
							
								
									
										
										
										
											2008-07-18 17:55:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								guint g_signal_newv (const gchar        *signal_name,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     GType               itype,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     GSignalFlags        signal_flags,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     GClosure           *class_closure,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     GSignalAccumulator  accumulator,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     gpointer            accu_data,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     GSignalCMarshaller  c_marshaller,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     GType               return_type,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     guint               n_params,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     GType              *param_types);
							 
						 
					
						
							
								
									
										
										
										
											2014-09-18 16:41:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								</programlisting> </informalexample>  
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										The number of parameters to these functions is a bit intimidating but they are relatively
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										simple:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										<itemizedlist > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  <parameter > signal_name</parameter> : is a string which can be used to uniquely identify a given signal.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  <parameter > itype</parameter> : is the instance type on which this signal can be emitted.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  <parameter > signal_flags</parameter> : partly defines the order in which closures which were connected to the
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  signal are invoked.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  <parameter > class_closure</parameter> : this is the default closure for the signal: if it is not NULL upon
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  the signal emission, it will be invoked upon this emission of the signal. The 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											  moment where this closure is invoked compared to other closures connected to that 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											  signal depends partly on the signal_flags.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											<listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  <parameter > accumulator</parameter> : this is a function pointer which is invoked after each closure
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  has been invoked. If it returns FALSE, signal emission is stopped. If it returns
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											  TRUE, signal emission proceeds normally. It is also used to compute the return
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											  value of the signal based on the return value of all the invoked closures.
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  For example, an accumulator could ignore
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											  <literal > NULL</literal>  returns from closures; or it
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											  could build a list of the values returned by the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											  closures.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2017-07-11 12:49:40 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  <parameter > accu_data</parameter> : this pointer will be passed down to each invocation of the
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  accumulator during emission.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  <parameter > c_marshaller</parameter> : this is the default C marshaller for any closure which is connected to
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											this signal.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  <parameter > return_type</parameter> : this is the type of the return value of the signal.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  <parameter > n_params</parameter> : this is the number of parameters this signal takes.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  <parameter > param_types</parameter> : this is an array of GTypes which indicate the type of each parameter
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											  of the signal. The length of this array is indicated by n_params.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										</itemizedlist> 
							 
						 
					
						
							
								
									
										
										
										
											2004-01-22 18:39:45 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								      </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										As you can see from the above definition, a signal is basically a description
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										of the closures which can be connected to this signal and a description of the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										order in which the closures connected to this signal will be invoked.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									</sect2> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									<sect2  id= "signal-connection" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <title > Signal connection</title> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										If you want to connect to a signal with a closure, you have three possibilities:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										<itemizedlist > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  You can register a class closure at signal registration: this is a
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										  system-wide operation. i.e.: the class closure will be invoked during each emission
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  of a given signal on <emphasis > any</emphasis>  of the instances of the type which supports that signal.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  You can use <function > <link  linkend= "g-signal-override-class-closure" > g_signal_override_class_closure</link> </function>  which
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										  overrides the class closure of a given type. It is possible to call this function
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										  only on a derived type of the type on which the signal was registered.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  This function is of use only to language bindings.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  You can register a closure with the <function > <link  linkend= "g-signal-connect" > g_signal_connect</link> </function> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  family of functions. This is an instance-specific operation: the closure
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  will be invoked only during emission of a given signal on a given instance.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										</itemizedlist> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										It is also possible to connect a different kind of callback on a given signal: 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										emission hooks are invoked whenever a given signal is emitted whatever the instance on 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										which it is emitted. Emission hooks are used for example to get all mouse_clicked
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										emissions in an application to be able to emit the small mouse click sound.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										Emission hooks are connected with <function > <link  linkend= "g-signal-add-emission-hook" > g_signal_add_emission_hook</link> </function> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										and removed with <function > <link  linkend= "g-signal-remove-emission-hook" > g_signal_remove_emission_hook</link> </function> .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									</sect2> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									<sect2  id= "signal-emission" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <title > Signal emission</title> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										Signal emission is done through the use of the <function > <link  linkend= "g-signal-emit" > g_signal_emit</link> </function>  family 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										of functions.
							 
						 
					
						
							
								
									
										
										
										
											2014-09-18 16:41:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<informalexample > <programlisting >  
						 
					
						
							
								
									
										
										
										
											2008-07-18 17:55:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								void g_signal_emitv (const GValue *instance_and_params,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     guint         signal_id,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     GQuark        detail,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     GValue       *return_value);
							 
						 
					
						
							
								
									
										
										
										
											2014-09-18 16:41:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								</programlisting> </informalexample>  
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										<itemizedlist > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											The <parameter > instance_and_params</parameter>  array of GValues contains the list of input
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											parameters to the signal. The first element of the array is the 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											instance pointer on which to invoke the signal. The following elements of
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											the array contain the list of parameters to the signal.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											<parameter > signal_id</parameter>  identifies the signal to invoke.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											<parameter > detail</parameter>  identifies the specific detail of the signal to invoke. A detail is a kind of 
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											magic token/argument which is passed around during signal emission and which is used
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											by closures connected to the signal to filter out unwanted signal emissions. In most 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											cases, you can safely set this value to zero. See <xref  linkend= "signal-detail" />  for
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											more details about this parameter.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											<parameter > return_value</parameter>  holds the return value of the last closure invoked during emission if
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											no accumulator was specified. If an accumulator was specified during signal creation,
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											this accumulator is used to calculate the return value as a function of the return
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											values of all the closures invoked during emission. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											If no closure is invoked during
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											emission, the <parameter > return_value</parameter>  is nonetheless initialized to zero/null.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  </itemizedlist> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										</para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										Signal emission can be decomposed in 5 steps:
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										<orderedlist > 
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											<literal > RUN_FIRST</literal> : if the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											<link  linkend= "G-SIGNAL-RUN-FIRST:CAPS" > <literal > G_SIGNAL_RUN_FIRST</literal> </link>  flag was used
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											during signal registration and if there exists a class closure for this signal,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											the class closure is invoked.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											<literal > EMISSION_HOOK</literal> : if any emission hook was added to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											the signal, they are invoked from first to last added. Accumulate return values.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											<literal > HANDLER_RUN_FIRST</literal> : if any closure were connected
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											with the <function > <link  linkend= "g-signal-connect" > g_signal_connect</link> </function>  family of 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											functions, and if they are not blocked (with the <function > <link  linkend= "g-signal-handler-block" > g_signal_handler_block</link> </function> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											family of functions) they are run here, from first to last connected.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											<literal > RUN_LAST</literal> : if the <literal > G_SIGNAL_RUN_LAST</literal> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											flag was set during registration and if a class closure
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											was set, it is invoked here.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											<literal > HANDLER_RUN_LAST</literal> : if any closure were connected
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											with the <function > g_signal_connect_after</function>  family of 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											functions, if they were not invoked during <literal > HANDLER_RUN_FIRST</literal>  and if they 
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											are not blocked, they are run here, from first to last connected.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <listitem > <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											<literal > RUN_CLEANUP</literal> : if the <literal > G_SIGNAL_RUN_CLEANUP</literal>  flag
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											was set during registration and if a class closure was set,
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											it is invoked here. Signal emission is completed here.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											</para> </listitem> 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										</orderedlist> 
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									  </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
									
										
										
										
											2016-10-22 16:04:05 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										If, at any point during emission (except in <literal > RUN_CLEANUP</literal>  or
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										<literal > EMISSION_HOOK</literal>  state), one of the closures stops the signal emission with
							 
						 
					
						
							
								
									
										
										
										
											2011-09-05 18:46:59 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										<function > <link  linkend= "g-signal-stop-emission" > g_signal_stop_emission</link> </function> ,
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										emission jumps to <literal > RUN_CLEANUP</literal>  state.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									  </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										If, at any point during emission, one of the closures or emission hook 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										emits the same signal on the same instance, emission is restarted from
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										the <literal > RUN_FIRST</literal>  state.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									  </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										The accumulator function is invoked in all states, after invocation
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										of each closure (except in <literal > RUN_EMISSION_HOOK</literal>  and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										<literal > RUN_CLEANUP</literal> ). It accumulates
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										the closure return value into the signal return value and returns TRUE or
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										FALSE. If, at any point, it does not return TRUE, emission jumps
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										to <literal > RUN_CLEANUP</literal>  state.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									  </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										If no accumulator function was provided, the value returned by the last handler
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										run will be returned by <function > <link  linkend= "g-signal-emit" > g_signal_emit</link> </function> .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									</sect2> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									<sect2  id= "signal-detail" > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <title > The <emphasis > detail</emphasis>  argument</title> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <para > All the functions related to signal emission or signal connection have a parameter
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										named the <emphasis > detail</emphasis> . Sometimes, this parameter is hidden by the API
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										but it is always there, in one form or another. 
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									  </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    Of the three main connection functions,
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										only one has an explicit detail parameter as a <link  linkend= "GQuark" > <type > GQuark</type> </link> :
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										<link  linkend= "g-signal-connect-closure-by-id" > <function > g_signal_connect_closure_by_id</function> </link> .
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										<footnote > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  <para > A GQuark is an integer which uniquely represents a string. It is possible to transform
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   back and forth between the integer and string representations with the functions 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   <function > <link  linkend= "g-quark-from-string" > g_quark_from_string</link> </function>  and <function > <link  linkend= "g-quark-to-string" > g_quark_to_string</link> </function> .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  </para> 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										</footnote> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    The two other functions,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    <link  linkend= "g-signal-connect-closure" > <function > g_signal_connect_closure</function> </link>  and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    <link  linkend= "g-signal-connect-data" > <function > g_signal_connect_data</function> </link> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    hide the detail parameter in the signal name identification.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										Their <parameter > detailed_signal</parameter>  parameter is a
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										string which identifies the name of the signal to connect to.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										The format of this string should match
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										<emphasis > signal_name::detail_name</emphasis> . For example,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										connecting to the signal named
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										<emphasis > notify::cursor_position</emphasis>  will actually
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										connect to the signal named <emphasis > notify</emphasis>  with the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										<emphasis > cursor_position</emphasis>  detail.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										Internally, the detail string is transformed to a GQuark if it is present.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									    Of the four main signal emission functions, one hides it in its
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    signal name parameter:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    <link  linkend= "g-signal-connect" > <function > g_signal_connect</function> </link> .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    The other three have an explicit detail parameter as a
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    <link  linkend= "GQuark" > <type > GQuark</type> </link>  again:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    <link  linkend= "g-signal-emit" > <function > g_signal_emit</function> </link> ,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    <link  linkend= "g-signal-emitv" > <function > g_signal_emitv</function> </link>  and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    <link  linkend= "g-signal-emit-valist" > <function > g_signal_emit_valist</function> </link> .
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									  </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        If a detail is provided by the user to the emission function, it is used during emission to match
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        against the closures which also provide a detail.
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        If a closure's detail does not match the detail provided by the user, it
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        will not be invoked (even though it is connected to a signal which is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        being emitted).
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									  </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										This completely optional filtering mechanism is mainly used as an optimization for signals
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										which are often emitted for many different reasons: the clients can filter out which events they are
							 
						 
					
						
							
								
									
										
										
										
											2008-11-28 23:53:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										interested in before the closure's marshalling code runs. For example, this is used extensively
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										by the <link  linkend= "GObject-notify" > <structfield > notify</structfield> </link>  signal of GObject: whenever a property is modified on a GObject,
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										instead of just emitting the <emphasis > notify</emphasis>  signal, GObject associates as a detail to this
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										signal emission the name of the property modified. This allows clients who wish to be notified of changes
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										to only one property to filter most events before receiving them.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  <para > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										As a simple rule, users can and should set the detail parameter to zero: this will disable completely
							 
						 
					
						
							
								
									
										
										
										
											2015-02-23 15:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        this optional filtering for that signal.
							 
						 
					
						
							
								
									
										
										
										
											2007-02-10 22:08:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									  </para> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									</sect2> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  </sect1> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								</chapter>