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