1 /* GIO - GLib Input, Output and Streaming Library
2 *
3 * Copyright 2011 Red Hat, Inc.
4 *
5 * SPDX-License-Identifier: LGPL-2.1-or-later
6 *
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
11 *
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
16 *
17 * You should have received a copy of the GNU Lesser General
18 * Public License along with this library; if not, see <http://www.gnu.org/licenses/>.
19 */
20
21 #ifndef __G_TASK_H__
22 #define __G_TASK_H__
23
24 #if !defined (__GIO_GIO_H_INSIDE__) && !defined (GIO_COMPILATION)
25 #error "Only <gio/gio.h> can be included directly."
26 #endif
27
28 #include <gio/giotypes.h>
29
30 G_BEGIN_DECLS
31
32 #define G_TYPE_TASK (g_task_get_type ())
33 #define G_TASK(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), G_TYPE_TASK, GTask))
34 #define G_TASK_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), G_TYPE_TASK, GTaskClass))
35 #define G_IS_TASK(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), G_TYPE_TASK))
36 #define G_IS_TASK_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), G_TYPE_TASK))
37 #define G_TASK_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), G_TYPE_TASK, GTaskClass))
38
39 typedef struct _GTaskClass GTaskClass;
40
41 GIO_AVAILABLE_IN_2_36
42 GType g_task_get_type (void) G_GNUC_CONST;
43
44 GIO_AVAILABLE_IN_2_36
45 GTask *g_task_new (gpointer source_object,
46 GCancellable *cancellable,
47 GAsyncReadyCallback callback,
48 gpointer callback_data);
49
50 GIO_AVAILABLE_IN_2_36
51 void g_task_report_error (gpointer source_object,
52 GAsyncReadyCallback callback,
53 gpointer callback_data,
54 gpointer source_tag,
55 GError *error);
56 GIO_AVAILABLE_IN_2_36
57 void g_task_report_new_error (gpointer source_object,
58 GAsyncReadyCallback callback,
59 gpointer callback_data,
60 gpointer source_tag,
61 GQuark domain,
62 gint code,
63 const char *format,
64 ...) G_GNUC_PRINTF(7, 8);
65
66 GIO_AVAILABLE_IN_2_36
67 void g_task_set_task_data (GTask *task,
68 gpointer task_data,
69 GDestroyNotify task_data_destroy);
70 GIO_AVAILABLE_IN_2_36
71 void g_task_set_priority (GTask *task,
72 gint priority);
73 GIO_AVAILABLE_IN_2_36
74 void g_task_set_check_cancellable (GTask *task,
75 gboolean check_cancellable);
76 GIO_AVAILABLE_IN_2_36
77 void g_task_set_source_tag (GTask *task,
78 gpointer source_tag);
79 GIO_AVAILABLE_IN_2_60
80 void g_task_set_name (GTask *task,
81 const gchar *name);
82 GIO_AVAILABLE_IN_2_76
83 void g_task_set_static_name (GTask *task,
84 const gchar *name);
85
86 /* Macro wrapper to set the task name when setting the source tag. */
87 #if GLIB_VERSION_MIN_REQUIRED >= GLIB_VERSION_2_76
88 #define g_task_set_source_tag(task, tag) G_STMT_START { \
89 GTask *_task = (task); \
90 (g_task_set_source_tag) (_task, tag); \
91 if (g_task_get_name (_task) == NULL) \
92 g_task_set_static_name (_task, G_STRINGIFY (tag)); \
93 } G_STMT_END
94 #endif
95
96 #if GLIB_VERSION_MIN_REQUIRED >= GLIB_VERSION_2_76
97 #if defined (__GNUC__) && (__GNUC__ >= 2)
98 #define g_task_set_name(task, name) G_STMT_START { \
99 GTask *_task = (task); \
100 if (__builtin_constant_p (name)) \
101 g_task_set_static_name (_task, name); \
102 else \
103 g_task_set_name (_task, name); \
104 } G_STMT_END
105 #endif
106 #endif
107
108 GIO_AVAILABLE_IN_2_36
109 gpointer g_task_get_source_object (GTask *task);
110 GIO_AVAILABLE_IN_2_36
111 gpointer g_task_get_task_data (GTask *task);
112 GIO_AVAILABLE_IN_2_36
113 gint g_task_get_priority (GTask *task);
114 GIO_AVAILABLE_IN_2_36
115 GMainContext *g_task_get_context (GTask *task);
116 GIO_AVAILABLE_IN_2_36
117 GCancellable *g_task_get_cancellable (GTask *task);
118 GIO_AVAILABLE_IN_2_36
119 gboolean g_task_get_check_cancellable (GTask *task);
120 GIO_AVAILABLE_IN_2_36
121 gpointer g_task_get_source_tag (GTask *task);
122 GIO_AVAILABLE_IN_2_60
123 const gchar *g_task_get_name (GTask *task);
124
125 GIO_AVAILABLE_IN_2_36
126 gboolean g_task_is_valid (gpointer result,
127 gpointer source_object);
128
129
130 typedef void (*GTaskThreadFunc) (GTask *task,
131 gpointer source_object,
132 gpointer task_data,
133 GCancellable *cancellable);
134 GIO_AVAILABLE_IN_2_36
135 void g_task_run_in_thread (GTask *task,
136 GTaskThreadFunc task_func);
137 GIO_AVAILABLE_IN_2_36
138 void g_task_run_in_thread_sync (GTask *task,
139 GTaskThreadFunc task_func);
140 GIO_AVAILABLE_IN_2_36
141 gboolean g_task_set_return_on_cancel (GTask *task,
142 gboolean return_on_cancel);
143 GIO_AVAILABLE_IN_2_36
144 gboolean g_task_get_return_on_cancel (GTask *task);
145
146 GIO_AVAILABLE_IN_2_36
147 void g_task_attach_source (GTask *task,
148 GSource *source,
149 GSourceFunc callback);
150
151
152 GIO_AVAILABLE_IN_2_36
153 void g_task_return_pointer (GTask *task,
154 gpointer result,
155 GDestroyNotify result_destroy);
156 GIO_AVAILABLE_IN_2_36
157 void g_task_return_boolean (GTask *task,
158 gboolean result);
159 GIO_AVAILABLE_IN_2_36
160 void g_task_return_int (GTask *task,
161 gssize result);
162
163 GIO_AVAILABLE_IN_2_36
164 void g_task_return_error (GTask *task,
165 GError *error);
166 GIO_AVAILABLE_IN_2_80
167 void g_task_return_prefixed_error (GTask *task,
168 GError *error,
169 const char *format,
170 ...) G_GNUC_PRINTF (3, 4);
171
172 GIO_AVAILABLE_IN_2_36
173 void g_task_return_new_error (GTask *task,
174 GQuark domain,
175 gint code,
176 const char *format,
177 ...) G_GNUC_PRINTF (4, 5);
178
179 GIO_AVAILABLE_IN_2_80
180 void g_task_return_new_error_literal (GTask *task,
181 GQuark domain,
182 gint code,
183 const char *message);
184 GIO_AVAILABLE_IN_2_64
185 void g_task_return_value (GTask *task,
186 GValue *result);
187
188 GIO_AVAILABLE_IN_2_36
189 gboolean g_task_return_error_if_cancelled (GTask *task);
190
191 GIO_AVAILABLE_IN_2_36
192 gpointer g_task_propagate_pointer (GTask *task,
193 GError **error);
194 GIO_AVAILABLE_IN_2_36
195 gboolean g_task_propagate_boolean (GTask *task,
196 GError **error);
197 GIO_AVAILABLE_IN_2_36
198 gssize g_task_propagate_int (GTask *task,
199 GError **error);
200 GIO_AVAILABLE_IN_2_64
201 gboolean g_task_propagate_value (GTask *task,
202 GValue *value,
203 GError **error);
204 GIO_AVAILABLE_IN_2_36
205 gboolean g_task_had_error (GTask *task);
206 GIO_AVAILABLE_IN_2_44
207 gboolean g_task_get_completed (GTask *task);
208
209 /*< private >*/
210 #ifndef __GTK_DOC_IGNORE__
211 #ifndef __GI_SCANNER__
212 /* Debugging API, not part of the public API */
213 void g_task_print_alive_tasks (void);
214 #endif /* !__GI_SCANNER__ */
215 #endif /* !__GTK_DOC_IGNORE__ */
216
217 G_END_DECLS
218
219 #endif /* __G_TASK_H__ */