epoc32/include/stdapis/glib-2.0/glib/gmain.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
/* gmain.h - the GLib Main loop
williamr@2
     2
 * Copyright (C) 1998-2000 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 Library 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
 * Library General Public License for more details.
williamr@2
    14
 *
williamr@2
    15
 * You should have received a copy of the GNU Library General Public
williamr@2
    16
 * 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
williamr@2
    21
#ifndef __G_MAIN_H__
williamr@2
    22
#define __G_MAIN_H__
williamr@2
    23
williamr@2
    24
#include <_ansi.h>
williamr@2
    25
#include <glib/gslist.h>
williamr@2
    26
#include <glib/gthread.h>
williamr@2
    27
williamr@2
    28
G_BEGIN_DECLS
williamr@2
    29
williamr@2
    30
typedef struct _GMainContext	        GMainContext;	/* Opaque */
williamr@2
    31
typedef struct _GMainLoop	        GMainLoop;	/* Opaque */
williamr@2
    32
typedef struct _GSource	                GSource;
williamr@2
    33
typedef struct _GSourceCallbackFuncs	GSourceCallbackFuncs;
williamr@2
    34
typedef struct _GSourceFuncs	        GSourceFuncs;
williamr@2
    35
williamr@2
    36
typedef gboolean (*GSourceFunc)       (gpointer data);
williamr@2
    37
typedef void     (*GChildWatchFunc)   (GPid     pid,
williamr@2
    38
				       gint     status,
williamr@2
    39
				       gpointer data);
williamr@2
    40
struct _GSource
williamr@2
    41
{
williamr@2
    42
  /*< private >*/
williamr@2
    43
  gpointer callback_data;
williamr@2
    44
  GSourceCallbackFuncs *callback_funcs;
williamr@2
    45
williamr@2
    46
  GSourceFuncs *source_funcs;
williamr@2
    47
  guint ref_count;
williamr@2
    48
williamr@2
    49
  GMainContext *context;
williamr@2
    50
williamr@2
    51
  gint priority;
williamr@2
    52
  guint flags;
williamr@2
    53
  guint source_id;
williamr@2
    54
williamr@2
    55
  GSList *poll_fds;
williamr@2
    56
  
williamr@2
    57
  GSource *prev;
williamr@2
    58
  GSource *next;
williamr@2
    59
williamr@2
    60
  gpointer reserved1;
williamr@2
    61
  gpointer reserved2;
williamr@2
    62
};
williamr@2
    63
williamr@2
    64
struct _GSourceCallbackFuncs
williamr@2
    65
{
williamr@2
    66
  void (*ref)   (gpointer     cb_data);
williamr@2
    67
  void (*unref) (gpointer     cb_data);
williamr@2
    68
  void (*get)   (gpointer     cb_data,
williamr@2
    69
		 GSource     *source, 
williamr@2
    70
		 GSourceFunc *func,
williamr@2
    71
		 gpointer    *data);
williamr@2
    72
};
williamr@2
    73
williamr@2
    74
typedef void (*GSourceDummyMarshal) (void);
williamr@2
    75
williamr@2
    76
struct _GSourceFuncs
williamr@2
    77
{
williamr@2
    78
  gboolean (*prepare)  (GSource    *source,
williamr@2
    79
			gint       *timeout_);
williamr@2
    80
  gboolean (*check)    (GSource    *source);
williamr@2
    81
  gboolean (*dispatch) (GSource    *source,
williamr@2
    82
			GSourceFunc callback,
williamr@2
    83
			gpointer    user_data);
williamr@2
    84
  void     (*finalize) (GSource    *source); /* Can be NULL */
williamr@2
    85
williamr@2
    86
  /* For use by g_source_set_closure */
williamr@2
    87
  GSourceFunc     closure_callback;	   
williamr@2
    88
  GSourceDummyMarshal closure_marshal; /* Really is of type GClosureMarshal */
williamr@2
    89
};
williamr@2
    90
williamr@2
    91
/* Any definitions using GPollFD or GPollFunc are primarily
williamr@2
    92
 * for Unix and not guaranteed to be the compatible on all
williamr@2
    93
 * operating systems on which GLib runs. Right now, the
williamr@2
    94
 * GLib does use these functions on Win32 as well, but interprets
williamr@2
    95
 * them in a fairly different way than on Unix. If you use
williamr@2
    96
 * these definitions, you are should be prepared to recode
williamr@2
    97
 * for different operating systems.
williamr@2
    98
 *
williamr@2
    99
 *
williamr@2
   100
 * On Win32, the fd in a GPollFD should be Win32 HANDLE (*not* a file
williamr@2
   101
 * descriptor as provided by the C runtime) that can be used by
williamr@2
   102
 * MsgWaitForMultipleObjects. This does *not* include file handles
williamr@2
   103
 * from CreateFile, SOCKETs, nor pipe handles. (But you can use
williamr@2
   104
 * WSAEventSelect to signal events when a SOCKET is readable).
williamr@2
   105
 *
williamr@2
   106
 * On Win32, fd can also be the special value G_WIN32_MSG_HANDLE to
williamr@2
   107
 * indicate polling for messages.
williamr@2
   108
 *
williamr@2
   109
 * But note that G_WIN32_MSG_HANDLE GPollFDs should not be used by GDK
williamr@2
   110
 * (GTK) programs, as GDK itself wants to read messages and convert them
williamr@2
   111
 * to GDK events.
williamr@2
   112
 *
williamr@2
   113
 * So, unless you really know what you are doing, it's best not to try
williamr@2
   114
 * to use the main loop polling stuff for your own needs on
williamr@2
   115
 * Win32. It's really only written for the GIMP's needs so
williamr@2
   116
 * far.
williamr@2
   117
 */
williamr@2
   118
typedef struct _GPollFD GPollFD;
williamr@2
   119
typedef gint	(*GPollFunc)	(GPollFD *ufds,
williamr@2
   120
				 guint	  nfsd,
williamr@2
   121
				 gint     timeout_);
williamr@2
   122
williamr@2
   123
struct _GPollFD
williamr@2
   124
{
williamr@2
   125
  gint		fd;
williamr@2
   126
  gushort 	events;
williamr@2
   127
  gushort 	revents;
williamr@2
   128
};
williamr@2
   129
williamr@2
   130
/* Standard priorities */
williamr@2
   131
williamr@2
   132
#define G_PRIORITY_HIGH            -100
williamr@2
   133
#define G_PRIORITY_DEFAULT          0
williamr@2
   134
#define G_PRIORITY_HIGH_IDLE        100
williamr@2
   135
#define G_PRIORITY_DEFAULT_IDLE     200
williamr@2
   136
#define G_PRIORITY_LOW	            300
williamr@2
   137
williamr@2
   138
/* GMainContext: */
williamr@2
   139
williamr@2
   140
IMPORT_C GMainContext *g_main_context_new       (void);
williamr@2
   141
IMPORT_C GMainContext *g_main_context_ref       (GMainContext *context);
williamr@2
   142
IMPORT_C void          g_main_context_unref     (GMainContext *context);
williamr@2
   143
IMPORT_C GMainContext *g_main_context_default   (void);
williamr@2
   144
williamr@2
   145
IMPORT_C gboolean      g_main_context_iteration (GMainContext *context,
williamr@2
   146
					gboolean      may_block);
williamr@2
   147
IMPORT_C gboolean      g_main_context_pending   (GMainContext *context);
williamr@2
   148
williamr@2
   149
/* For implementation of legacy interfaces
williamr@2
   150
 */
williamr@2
   151
IMPORT_C GSource      *g_main_context_find_source_by_id              (GMainContext *context,
williamr@2
   152
							     guint         source_id);
williamr@2
   153
IMPORT_C GSource      *g_main_context_find_source_by_user_data       (GMainContext *context,
williamr@2
   154
							     gpointer      user_data);
williamr@2
   155
IMPORT_C GSource      *g_main_context_find_source_by_funcs_user_data (GMainContext *context,
williamr@2
   156
 							     GSourceFuncs *funcs,
williamr@2
   157
							     gpointer      user_data);
williamr@2
   158
williamr@2
   159
/* Low level functions for implementing custom main loops.
williamr@2
   160
 */
williamr@2
   161
IMPORT_C void     g_main_context_wakeup  (GMainContext *context);
williamr@2
   162
IMPORT_C gboolean g_main_context_acquire (GMainContext *context);
williamr@2
   163
IMPORT_C void     g_main_context_release (GMainContext *context);
williamr@2
   164
IMPORT_C gboolean g_main_context_is_owner (GMainContext *context);
williamr@2
   165
IMPORT_C gboolean g_main_context_wait    (GMainContext *context,
williamr@2
   166
				 GCond        *cond,
williamr@2
   167
				 GMutex       *mutex);
williamr@2
   168
williamr@2
   169
IMPORT_C gboolean g_main_context_prepare  (GMainContext *context,
williamr@2
   170
				  gint         *priority);
williamr@2
   171
IMPORT_C gint     g_main_context_query    (GMainContext *context,
williamr@2
   172
				  gint          max_priority,
williamr@2
   173
				  gint         *timeout_,
williamr@2
   174
				  GPollFD      *fds,
williamr@2
   175
				  gint          n_fds);
williamr@2
   176
IMPORT_C gint     g_main_context_check    (GMainContext *context,
williamr@2
   177
				  gint          max_priority,
williamr@2
   178
				  GPollFD      *fds,
williamr@2
   179
				  gint          n_fds);
williamr@2
   180
IMPORT_C void     g_main_context_dispatch (GMainContext *context);
williamr@2
   181
williamr@2
   182
IMPORT_C void      g_main_context_set_poll_func (GMainContext *context,
williamr@2
   183
					GPollFunc     func);
williamr@2
   184
IMPORT_C GPollFunc g_main_context_get_poll_func (GMainContext *context);
williamr@2
   185
williamr@2
   186
/* Low level functions for use by source implementations
williamr@2
   187
 */
williamr@2
   188
IMPORT_C void g_main_context_add_poll      (GMainContext *context,
williamr@2
   189
				   GPollFD      *fd,
williamr@2
   190
				   gint          priority);
williamr@2
   191
IMPORT_C void g_main_context_remove_poll   (GMainContext *context,
williamr@2
   192
				   GPollFD      *fd);
williamr@2
   193
williamr@2
   194
IMPORT_C int g_main_depth (void);
williamr@2
   195
williamr@2
   196
/* GMainLoop: */
williamr@2
   197
williamr@2
   198
IMPORT_C GMainLoop *g_main_loop_new        (GMainContext *context,
williamr@2
   199
			    	   gboolean      is_running);
williamr@2
   200
IMPORT_C void       g_main_loop_run        (GMainLoop    *loop);
williamr@2
   201
IMPORT_C void       g_main_loop_quit       (GMainLoop    *loop);
williamr@2
   202
IMPORT_C GMainLoop *g_main_loop_ref        (GMainLoop    *loop);
williamr@2
   203
IMPORT_C void       g_main_loop_unref      (GMainLoop    *loop);
williamr@2
   204
IMPORT_C gboolean   g_main_loop_is_running (GMainLoop    *loop);
williamr@2
   205
IMPORT_C GMainContext *g_main_loop_get_context (GMainLoop    *loop);
williamr@2
   206
williamr@2
   207
/* GSource: */
williamr@2
   208
williamr@2
   209
IMPORT_C GSource *g_source_new             (GSourceFuncs   *source_funcs,
williamr@2
   210
				   guint           struct_size);
williamr@2
   211
IMPORT_C GSource *g_source_ref             (GSource        *source);
williamr@2
   212
IMPORT_C void     g_source_unref           (GSource        *source);
williamr@2
   213
williamr@2
   214
IMPORT_C guint    g_source_attach          (GSource        *source,
williamr@2
   215
				   GMainContext   *context);
williamr@2
   216
IMPORT_C void     g_source_destroy         (GSource        *source);
williamr@2
   217
williamr@2
   218
IMPORT_C void     g_source_set_priority    (GSource        *source,
williamr@2
   219
				   gint            priority);
williamr@2
   220
IMPORT_C gint     g_source_get_priority    (GSource        *source);
williamr@2
   221
IMPORT_C void     g_source_set_can_recurse (GSource        *source,
williamr@2
   222
				   gboolean        can_recurse);
williamr@2
   223
IMPORT_C gboolean g_source_get_can_recurse (GSource        *source);
williamr@2
   224
IMPORT_C guint    g_source_get_id          (GSource        *source);
williamr@2
   225
williamr@2
   226
IMPORT_C GMainContext *g_source_get_context (GSource       *source);
williamr@2
   227
williamr@2
   228
IMPORT_C void g_source_set_callback          (GSource              *source,
williamr@2
   229
				     GSourceFunc           func,
williamr@2
   230
				     gpointer              data,
williamr@2
   231
				     GDestroyNotify        notify);
williamr@2
   232
williamr@2
   233
williamr@2
   234
/* Used to implement g_source_connect_closure and internally*/
williamr@2
   235
IMPORT_C void g_source_set_callback_indirect (GSource              *source,
williamr@2
   236
				     gpointer              callback_data,
williamr@2
   237
				     GSourceCallbackFuncs *callback_funcs);
williamr@2
   238
williamr@2
   239
IMPORT_C void     g_source_add_poll         (GSource        *source,
williamr@2
   240
				    GPollFD        *fd);
williamr@2
   241
IMPORT_C void     g_source_remove_poll      (GSource        *source,
williamr@2
   242
				    GPollFD        *fd);
williamr@2
   243
williamr@2
   244
IMPORT_C void     g_source_get_current_time (GSource        *source,
williamr@2
   245
				    GTimeVal       *timeval);
williamr@2
   246
williamr@2
   247
 /* void g_source_connect_closure (GSource        *source,
williamr@2
   248
                                  GClosure       *closure);
williamr@2
   249
 */
williamr@2
   250
williamr@2
   251
/* Specific source types
williamr@2
   252
 */
williamr@2
   253
IMPORT_C GSource *g_idle_source_new        (void);
williamr@2
   254
IMPORT_C GSource *g_child_watch_source_new (GPid pid);
williamr@2
   255
IMPORT_C GSource *g_timeout_source_new     (guint interval);
williamr@2
   256
williamr@2
   257
/* Miscellaneous functions
williamr@2
   258
 */
williamr@2
   259
IMPORT_C void g_get_current_time		        (GTimeVal	*result);
williamr@2
   260
williamr@2
   261
/* ============== Compat main loop stuff ================== */
williamr@2
   262
williamr@2
   263
#ifndef G_DISABLE_DEPRECATED
williamr@2
   264
williamr@2
   265
/* Legacy names for GMainLoop functions
williamr@2
   266
 */
williamr@2
   267
#define 	g_main_new(is_running)	g_main_loop_new (NULL, is_running);
williamr@2
   268
#define         g_main_run(loop)        g_main_loop_run(loop)
williamr@2
   269
#define         g_main_quit(loop)       g_main_loop_quit(loop)
williamr@2
   270
#define         g_main_destroy(loop)    g_main_loop_unref(loop)
williamr@2
   271
#define         g_main_is_running(loop) g_main_loop_is_running(loop)
williamr@2
   272
williamr@2
   273
/* Functions to manipulate the default main loop
williamr@2
   274
 */
williamr@2
   275
williamr@2
   276
#define	g_main_iteration(may_block) g_main_context_iteration      (NULL, may_block)
williamr@2
   277
#define g_main_pending()            g_main_context_pending        (NULL)
williamr@2
   278
williamr@2
   279
#define g_main_set_poll_func(func)   g_main_context_set_poll_func (NULL, func)
williamr@2
   280
williamr@2
   281
#endif /* G_DISABLE_DEPRECATED */
williamr@2
   282
williamr@2
   283
/* Source manipulation by ID */
williamr@2
   284
IMPORT_C gboolean g_source_remove                     (guint          tag);
williamr@2
   285
IMPORT_C gboolean g_source_remove_by_user_data        (gpointer       user_data);
williamr@2
   286
IMPORT_C gboolean g_source_remove_by_funcs_user_data  (GSourceFuncs  *funcs,
williamr@2
   287
					      gpointer       user_data);
williamr@2
   288
williamr@2
   289
/* Idles, child watchers and timeouts */
williamr@2
   290
IMPORT_C guint    g_timeout_add_full     (gint            priority,
williamr@2
   291
				 guint           interval,
williamr@2
   292
				 GSourceFunc     function,
williamr@2
   293
				 gpointer        data,
williamr@2
   294
				 GDestroyNotify  notify);
williamr@2
   295
IMPORT_C guint    g_timeout_add          (guint           interval,
williamr@2
   296
				 GSourceFunc     function,
williamr@2
   297
				 gpointer        data);
williamr@2
   298
IMPORT_C guint    g_child_watch_add_full (gint            priority,
williamr@2
   299
				 GPid            pid,
williamr@2
   300
				 GChildWatchFunc function,
williamr@2
   301
				 gpointer        data,
williamr@2
   302
				 GDestroyNotify  notify);
williamr@2
   303
IMPORT_C guint    g_child_watch_add      (GPid            pid,
williamr@2
   304
				 GChildWatchFunc function,
williamr@2
   305
				 gpointer        data);
williamr@2
   306
IMPORT_C guint    g_idle_add             (GSourceFunc     function,
williamr@2
   307
				 gpointer        data);
williamr@2
   308
IMPORT_C guint    g_idle_add_full        (gint            priority,
williamr@2
   309
				 GSourceFunc     function,
williamr@2
   310
				 gpointer        data,
williamr@2
   311
				 GDestroyNotify  notify);
williamr@2
   312
IMPORT_C gboolean g_idle_remove_by_data  (gpointer        data);
williamr@2
   313
williamr@2
   314
/* Hook for GClosure / GSource integration. Don't touch */
williamr@2
   315
#ifdef __SYMBIAN32__
williamr@2
   316
IMPORT_C GSourceFuncs * _g_timeout_funcs();
williamr@2
   317
#endif /*__SYMBIAN32__ */
williamr@2
   318
GLIB_VAR GSourceFuncs g_timeout_funcs;
williamr@2
   319
#ifdef __SYMBIAN32__
williamr@2
   320
IMPORT_C GSourceFuncs * _g_child_watch_funcs();
williamr@2
   321
#endif /* __SYMBIAN32__ */
williamr@2
   322
GLIB_VAR GSourceFuncs g_child_watch_funcs;
williamr@2
   323
#ifdef __SYMBIAN32__
williamr@2
   324
IMPORT_C GSourceFuncs * _g_idle_funcs();
williamr@2
   325
#endif/* __SYMBIAN32__ */
williamr@2
   326
GLIB_VAR GSourceFuncs g_idle_funcs;
williamr@2
   327
williamr@2
   328
G_END_DECLS
williamr@2
   329
williamr@2
   330
#endif /* __G_MAIN_H__ */