1/* GIO - GLib Input, Output and Streaming Library
2 *
3 * Copyright 2011 Red Hat, Inc.
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.1 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, see <http://www.gnu.org/licenses/>.
17 */
18
19#ifndef __G_TASK_H__
20#define __G_TASK_H__
21
22#if !defined (__GIO_GIO_H_INSIDE__) && !defined (GIO_COMPILATION)
23#error "Only <gio/gio.h> can be included directly."
24#endif
25
26#include <gio/giotypes.h>
27
28G_BEGIN_DECLS
29
30#define G_TYPE_TASK (g_task_get_type ())
31#define G_TASK(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), G_TYPE_TASK, GTask))
32#define G_TASK_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), G_TYPE_TASK, GTaskClass))
33#define G_IS_TASK(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), G_TYPE_TASK))
34#define G_IS_TASK_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), G_TYPE_TASK))
35#define G_TASK_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), G_TYPE_TASK, GTaskClass))
36
37typedef struct _GTaskClass GTaskClass;
38
39GLIB_AVAILABLE_IN_2_36
40GType g_task_get_type (void) G_GNUC_CONST;
41
42GLIB_AVAILABLE_IN_2_36
43GTask *g_task_new (gpointer source_object,
44 GCancellable *cancellable,
45 GAsyncReadyCallback callback,
46 gpointer callback_data);
47
48GLIB_AVAILABLE_IN_2_36
49void g_task_report_error (gpointer source_object,
50 GAsyncReadyCallback callback,
51 gpointer callback_data,
52 gpointer source_tag,
53 GError *error);
54GLIB_AVAILABLE_IN_2_36
55void g_task_report_new_error (gpointer source_object,
56 GAsyncReadyCallback callback,
57 gpointer callback_data,
58 gpointer source_tag,
59 GQuark domain,
60 gint code,
61 const char *format,
62 ...) G_GNUC_PRINTF(7, 8);
63
64GLIB_AVAILABLE_IN_2_36
65void g_task_set_task_data (GTask *task,
66 gpointer task_data,
67 GDestroyNotify task_data_destroy);
68GLIB_AVAILABLE_IN_2_36
69void g_task_set_priority (GTask *task,
70 gint priority);
71GLIB_AVAILABLE_IN_2_36
72void g_task_set_check_cancellable (GTask *task,
73 gboolean check_cancellable);
74GLIB_AVAILABLE_IN_2_36
75void g_task_set_source_tag (GTask *task,
76 gpointer source_tag);
77GLIB_AVAILABLE_IN_2_60
78void g_task_set_name (GTask *task,
79 const gchar *name);
80
81GLIB_AVAILABLE_IN_2_36
82gpointer g_task_get_source_object (GTask *task);
83GLIB_AVAILABLE_IN_2_36
84gpointer g_task_get_task_data (GTask *task);
85GLIB_AVAILABLE_IN_2_36
86gint g_task_get_priority (GTask *task);
87GLIB_AVAILABLE_IN_2_36
88GMainContext *g_task_get_context (GTask *task);
89GLIB_AVAILABLE_IN_2_36
90GCancellable *g_task_get_cancellable (GTask *task);
91GLIB_AVAILABLE_IN_2_36
92gboolean g_task_get_check_cancellable (GTask *task);
93GLIB_AVAILABLE_IN_2_36
94gpointer g_task_get_source_tag (GTask *task);
95GLIB_AVAILABLE_IN_2_60
96const gchar *g_task_get_name (GTask *task);
97
98GLIB_AVAILABLE_IN_2_36
99gboolean g_task_is_valid (gpointer result,
100 gpointer source_object);
101
102
103typedef void (*GTaskThreadFunc) (GTask *task,
104 gpointer source_object,
105 gpointer task_data,
106 GCancellable *cancellable);
107GLIB_AVAILABLE_IN_2_36
108void g_task_run_in_thread (GTask *task,
109 GTaskThreadFunc task_func);
110GLIB_AVAILABLE_IN_2_36
111void g_task_run_in_thread_sync (GTask *task,
112 GTaskThreadFunc task_func);
113GLIB_AVAILABLE_IN_2_36
114gboolean g_task_set_return_on_cancel (GTask *task,
115 gboolean return_on_cancel);
116GLIB_AVAILABLE_IN_2_36
117gboolean g_task_get_return_on_cancel (GTask *task);
118
119GLIB_AVAILABLE_IN_2_36
120void g_task_attach_source (GTask *task,
121 GSource *source,
122 GSourceFunc callback);
123
124
125GLIB_AVAILABLE_IN_2_36
126void g_task_return_pointer (GTask *task,
127 gpointer result,
128 GDestroyNotify result_destroy);
129GLIB_AVAILABLE_IN_2_36
130void g_task_return_boolean (GTask *task,
131 gboolean result);
132GLIB_AVAILABLE_IN_2_36
133void g_task_return_int (GTask *task,
134 gssize result);
135
136GLIB_AVAILABLE_IN_2_36
137void g_task_return_error (GTask *task,
138 GError *error);
139GLIB_AVAILABLE_IN_2_36
140void g_task_return_new_error (GTask *task,
141 GQuark domain,
142 gint code,
143 const char *format,
144 ...) G_GNUC_PRINTF (4, 5);
145
146GLIB_AVAILABLE_IN_2_36
147gboolean g_task_return_error_if_cancelled (GTask *task);
148
149GLIB_AVAILABLE_IN_2_36
150gpointer g_task_propagate_pointer (GTask *task,
151 GError **error);
152GLIB_AVAILABLE_IN_2_36
153gboolean g_task_propagate_boolean (GTask *task,
154 GError **error);
155GLIB_AVAILABLE_IN_2_36
156gssize g_task_propagate_int (GTask *task,
157 GError **error);
158GLIB_AVAILABLE_IN_2_36
159gboolean g_task_had_error (GTask *task);
160GLIB_AVAILABLE_IN_2_44
161gboolean g_task_get_completed (GTask *task);
162
163G_END_DECLS
164
165#endif /* __G_TASK_H__ */
166