epoc32/include/stdapis/glib-2.0/gobject/gsignal.h
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:33:34 +0100
branchSymbian3
changeset 4 837f303aceeb
parent 0 061f57f2323e
permissions -rw-r--r--
Current Symbian^3 public API header files (from PDK 3.0.h)
This is the epoc32/include tree with the "platform" subtrees removed, and
all but a selected few mbg and rsg files removed.
     1 /* GObject - GLib Type, Object, Parameter and Signal Library
     2  * Copyright (C) 2000-2001 Red Hat, Inc.
     3  * Portions copyright (c) 2006 Nokia Corporation.  All rights reserved.
     4  *
     5  * This library is free software; you can redistribute it and/or
     6  * modify it under the terms of the GNU Lesser General Public
     7  * License as published by the Free Software Foundation; either
     8  * version 2 of the License, or (at your option) any later version.
     9  *
    10  * This library is distributed in the hope that it will be useful,
    11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
    12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.	 See the GNU
    13  * Lesser General Public License for more details.
    14  *
    15  * You should have received a copy of the GNU Lesser General
    16  * Public License along with this library; if not, write to the
    17  * Free Software Foundation, Inc., 59 Temple Place, Suite 330,
    18  * Boston, MA 02111-1307, USA.
    19  */
    20 #if !defined (__GLIB_GOBJECT_H_INSIDE__) && !defined (GOBJECT_COMPILATION)
    21 #error "Only <glib-object.h> can be included directly."
    22 #endif
    23 
    24 #ifndef __G_SIGNAL_H__
    25 #define __G_SIGNAL_H__
    26 
    27 #include <_ansi.h>
    28 #include	<gobject/gclosure.h>
    29 #include	<gobject/gvalue.h>
    30 #include	<gobject/gparam.h>
    31 #include	<gobject/gmarshal.h>
    32 
    33 G_BEGIN_DECLS
    34 
    35 /* --- typedefs --- */
    36 typedef struct _GSignalQuery		 GSignalQuery;
    37 typedef struct _GSignalInvocationHint	 GSignalInvocationHint;
    38 typedef GClosureMarshal			 GSignalCMarshaller;
    39 typedef gboolean (*GSignalEmissionHook) (GSignalInvocationHint *ihint,
    40 					 guint			n_param_values,
    41 					 const GValue	       *param_values,
    42 					 gpointer		data);
    43 typedef gboolean (*GSignalAccumulator)	(GSignalInvocationHint *ihint,
    44 					 GValue		       *return_accu,
    45 					 const GValue	       *handler_return,
    46 					 gpointer               data);
    47 
    48 
    49 /* --- run, match and connect types --- */
    50 typedef enum
    51 {
    52   G_SIGNAL_RUN_FIRST	= 1 << 0,
    53   G_SIGNAL_RUN_LAST	= 1 << 1,
    54   G_SIGNAL_RUN_CLEANUP	= 1 << 2,
    55   G_SIGNAL_NO_RECURSE	= 1 << 3,
    56   G_SIGNAL_DETAILED	= 1 << 4,
    57   G_SIGNAL_ACTION	= 1 << 5,
    58   G_SIGNAL_NO_HOOKS	= 1 << 6
    59 } GSignalFlags;
    60 #define G_SIGNAL_FLAGS_MASK  0x7f
    61 typedef enum
    62 {
    63   G_CONNECT_AFTER	= 1 << 0,
    64   G_CONNECT_SWAPPED	= 1 << 1
    65 } GConnectFlags;
    66 typedef enum
    67 {
    68   G_SIGNAL_MATCH_ID	   = 1 << 0,
    69   G_SIGNAL_MATCH_DETAIL	   = 1 << 1,
    70   G_SIGNAL_MATCH_CLOSURE   = 1 << 2,
    71   G_SIGNAL_MATCH_FUNC	   = 1 << 3,
    72   G_SIGNAL_MATCH_DATA	   = 1 << 4,
    73   G_SIGNAL_MATCH_UNBLOCKED = 1 << 5
    74 } GSignalMatchType;
    75 #define G_SIGNAL_MATCH_MASK  0x3f
    76 #define	G_SIGNAL_TYPE_STATIC_SCOPE (G_TYPE_FLAG_RESERVED_ID_BIT)
    77 
    78 
    79 /* --- signal information --- */
    80 struct _GSignalInvocationHint
    81 {
    82   guint		signal_id;
    83   GQuark	detail;
    84   GSignalFlags	run_type;
    85 };
    86 struct _GSignalQuery
    87 {
    88   guint		signal_id;
    89   const gchar  *signal_name;
    90   GType		itype;
    91   GSignalFlags	signal_flags;
    92   GType		return_type; /* mangled with G_SIGNAL_TYPE_STATIC_SCOPE flag */
    93   guint		n_params;
    94   const GType  *param_types; /* mangled with G_SIGNAL_TYPE_STATIC_SCOPE flag */
    95 };
    96 
    97 
    98 /* --- signals --- */
    99 IMPORT_C guint                 g_signal_newv         (const gchar        *signal_name,
   100 					     GType               itype,
   101 					     GSignalFlags        signal_flags,
   102 					     GClosure           *class_closure,
   103 					     GSignalAccumulator	 accumulator,
   104 					     gpointer		 accu_data,
   105 					     GSignalCMarshaller  c_marshaller,
   106 					     GType               return_type,
   107 					     guint               n_params,
   108 					     GType              *param_types);
   109 IMPORT_C guint                 g_signal_new_valist   (const gchar        *signal_name,
   110 					     GType               itype,
   111 					     GSignalFlags        signal_flags,
   112 					     GClosure           *class_closure,
   113 					     GSignalAccumulator	 accumulator,
   114 					     gpointer		 accu_data,
   115 					     GSignalCMarshaller  c_marshaller,
   116 					     GType               return_type,
   117 					     guint               n_params,
   118 					     va_list             args);
   119 IMPORT_C guint                 g_signal_new          (const gchar        *signal_name,
   120 					     GType               itype,
   121 					     GSignalFlags        signal_flags,
   122 					     guint               class_offset,
   123 					     GSignalAccumulator	 accumulator,
   124 					     gpointer		 accu_data,
   125 					     GSignalCMarshaller  c_marshaller,
   126 					     GType               return_type,
   127 					     guint               n_params,
   128 					     ...);
   129 IMPORT_C void                  g_signal_emitv        (const GValue       *instance_and_params,
   130 					     guint               signal_id,
   131 					     GQuark              detail,
   132 					     GValue             *return_value);
   133 IMPORT_C void                  g_signal_emit_valist  (gpointer            instance,
   134 					     guint               signal_id,
   135 					     GQuark              detail,
   136 					     va_list             var_args);
   137 IMPORT_C void                  g_signal_emit         (gpointer            instance,
   138 					     guint               signal_id,
   139 					     GQuark              detail,
   140 					     ...);
   141 IMPORT_C void                  g_signal_emit_by_name (gpointer            instance,
   142 					     const gchar        *detailed_signal,
   143 					     ...);
   144 IMPORT_C guint                 g_signal_lookup       (const gchar        *name,
   145 					     GType               itype);
   146 IMPORT_C G_CONST_RETURN gchar* g_signal_name         (guint               signal_id);
   147 IMPORT_C void                  g_signal_query        (guint               signal_id,
   148 					     GSignalQuery       *query);
   149 IMPORT_C guint*                g_signal_list_ids     (GType               itype,
   150 					     guint              *n_ids);
   151 IMPORT_C gboolean	      g_signal_parse_name   (const gchar	*detailed_signal,
   152 					     GType		 itype,
   153 					     guint		*signal_id_p,
   154 					     GQuark		*detail_p,
   155 					     gboolean		 force_detail_quark);
   156 IMPORT_C GSignalInvocationHint* g_signal_get_invocation_hint (gpointer    instance);
   157 
   158 
   159 /* --- signal emissions --- */
   160 IMPORT_C void	g_signal_stop_emission		    (gpointer		  instance,
   161 					     guint		  signal_id,
   162 					     GQuark		  detail);
   163 IMPORT_C void	g_signal_stop_emission_by_name	    (gpointer		  instance,
   164 					     const gchar	 *detailed_signal);
   165 IMPORT_C gulong	g_signal_add_emission_hook	    (guint		  signal_id,
   166 					     GQuark		  detail,
   167 					     GSignalEmissionHook  hook_func,
   168 					     gpointer	       	  hook_data,
   169 					     GDestroyNotify	  data_destroy);
   170 IMPORT_C void	g_signal_remove_emission_hook	    (guint		  signal_id,
   171 					     gulong		  hook_id);
   172 
   173 
   174 /* --- signal handlers --- */
   175 IMPORT_C gboolean g_signal_has_handler_pending	      (gpointer		  instance,
   176 					       guint		  signal_id,
   177 					       GQuark		  detail,
   178 					       gboolean		  may_be_blocked);
   179 IMPORT_C gulong	 g_signal_connect_closure_by_id	      (gpointer		  instance,
   180 					       guint		  signal_id,
   181 					       GQuark		  detail,
   182 					       GClosure		 *closure,
   183 					       gboolean		  after);
   184 IMPORT_C gulong	 g_signal_connect_closure	      (gpointer		  instance,
   185 					       const gchar       *detailed_signal,
   186 					       GClosure		 *closure,
   187 					       gboolean		  after);
   188 IMPORT_C gulong	 g_signal_connect_data		      (gpointer		  instance,
   189 					       const gchar	 *detailed_signal,
   190 					       GCallback	  c_handler,
   191 					       gpointer		  data,
   192 					       GClosureNotify	  destroy_data,
   193 					       GConnectFlags	  connect_flags);
   194 IMPORT_C void	 g_signal_handler_block		      (gpointer		  instance,
   195 					       gulong		  handler_id);
   196 IMPORT_C void	 g_signal_handler_unblock	      (gpointer		  instance,
   197 					       gulong		  handler_id);
   198 IMPORT_C void	 g_signal_handler_disconnect	      (gpointer		  instance,
   199 					       gulong		  handler_id);
   200 IMPORT_C gboolean g_signal_handler_is_connected	      (gpointer		  instance,
   201 					       gulong		  handler_id);
   202 IMPORT_C gulong	 g_signal_handler_find		      (gpointer		  instance,
   203 					       GSignalMatchType	  mask,
   204 					       guint		  signal_id,
   205 					       GQuark		  detail,
   206 					       GClosure		 *closure,
   207 					       gpointer		  func,
   208 					       gpointer		  data);
   209 IMPORT_C guint	 g_signal_handlers_block_matched      (gpointer		  instance,
   210 					       GSignalMatchType	  mask,
   211 					       guint		  signal_id,
   212 					       GQuark		  detail,
   213 					       GClosure		 *closure,
   214 					       gpointer		  func,
   215 					       gpointer		  data);
   216 IMPORT_C guint	 g_signal_handlers_unblock_matched    (gpointer		  instance,
   217 					       GSignalMatchType	  mask,
   218 					       guint		  signal_id,
   219 					       GQuark		  detail,
   220 					       GClosure		 *closure,
   221 					       gpointer		  func,
   222 					       gpointer		  data);
   223 IMPORT_C guint	 g_signal_handlers_disconnect_matched (gpointer		  instance,
   224 					       GSignalMatchType	  mask,
   225 					       guint		  signal_id,
   226 					       GQuark		  detail,
   227 					       GClosure		 *closure,
   228 					       gpointer		  func,
   229 					       gpointer		  data);
   230 
   231 
   232 /* --- chaining for language bindings --- */
   233 IMPORT_C void	g_signal_override_class_closure	      (guint		  signal_id,
   234 					       GType		  instance_type,
   235 					       GClosure		 *class_closure);
   236 IMPORT_C void	g_signal_chain_from_overridden	      (const GValue      *instance_and_params,
   237 					       GValue            *return_value);
   238 
   239 
   240 /* --- convenience --- */
   241 #define g_signal_connect(instance, detailed_signal, c_handler, data) \
   242     g_signal_connect_data ((instance), (detailed_signal), (c_handler), (data), NULL, (GConnectFlags) 0)
   243 #define g_signal_connect_after(instance, detailed_signal, c_handler, data) \
   244     g_signal_connect_data ((instance), (detailed_signal), (c_handler), (data), NULL, G_CONNECT_AFTER)
   245 #define g_signal_connect_swapped(instance, detailed_signal, c_handler, data) \
   246     g_signal_connect_data ((instance), (detailed_signal), (c_handler), (data), NULL, G_CONNECT_SWAPPED)
   247 #define	g_signal_handlers_disconnect_by_func(instance, func, data)						\
   248     g_signal_handlers_disconnect_matched ((instance),								\
   249 					  (GSignalMatchType) (G_SIGNAL_MATCH_FUNC | G_SIGNAL_MATCH_DATA),	\
   250 					  0, 0, NULL, (func), (data))
   251 #define	g_signal_handlers_block_by_func(instance, func, data)							\
   252     g_signal_handlers_block_matched      ((instance),								\
   253 				          (GSignalMatchType) (G_SIGNAL_MATCH_FUNC | G_SIGNAL_MATCH_DATA),	\
   254 				          0, 0, NULL, (func), (data))
   255 #define	g_signal_handlers_unblock_by_func(instance, func, data)							\
   256     g_signal_handlers_unblock_matched    ((instance),								\
   257 				          (GSignalMatchType) (G_SIGNAL_MATCH_FUNC | G_SIGNAL_MATCH_DATA),	\
   258 				          0, 0, NULL, (func), (data))
   259 
   260 
   261 IMPORT_C gboolean g_signal_accumulator_true_handled (GSignalInvocationHint *ihint,
   262 					    GValue                *return_accu,
   263 					    const GValue          *handler_return,
   264 					    gpointer               dummy);
   265 
   266 /*< private >*/
   267 IMPORT_C void	 g_signal_handlers_destroy	      (gpointer		  instance);
   268 void	 _g_signals_destroy		      (GType		  itype);
   269 
   270 G_END_DECLS
   271 
   272 #endif /* __G_SIGNAL_H__ */