Tue, 02 Oct 2018 16:23:35 -0500
libpurple: Drop Purple DBus client code in preparation for DBus drop
|
37665
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
1 | /* |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
2 | * |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
3 | * purple |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
4 | * |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
5 | * Purple is the legal property of its developers, whose names are too numerous |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
6 | * to list here. Please refer to the COPYRIGHT file distributed with this |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
7 | * source distribution. |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
8 | * |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
9 | * This program is free software; you can redistribute it and/or modify |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
10 | * it under the terms of the GNU General Public License as published by |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
11 | * the Free Software Foundation; either version 2 of the License, or |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
12 | * (at your option) any later version. |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
13 | * |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
14 | * This program is distributed in the hope that it will be useful, |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
17 | * GNU General Public License for more details. |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
18 | * |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
19 | * You should have received a copy of the GNU General Public License |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
20 | * along with this program; if not, write to the Free Software |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
21 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
22 | */ |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
23 | |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
24 | #ifndef _PURPLE_QUEUED_OUTPUT_STREAM_H |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
25 | #define _PURPLE_QUEUED_OUTPUT_STREAM_H |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
26 | /** |
|
38552
85c4c3296419
libpurple: Fix section documentation headings
Mike Ruprecht <cmaiku@gmail.com>
parents:
37665
diff
changeset
|
27 | * SECTION:queuedoutputstream |
|
85c4c3296419
libpurple: Fix section documentation headings
Mike Ruprecht <cmaiku@gmail.com>
parents:
37665
diff
changeset
|
28 | * @section_id: libpurple-queuedoutputstream |
|
37665
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
29 | * @short_description: GOutputStream for queuing data to output |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
30 | * @title: GOutputStream class |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
31 | * |
|
38555
32274f138667
queuedoutputstream: Fix docstring referencing GQueuedOutputStream
Mike Ruprecht <cmaiku@gmail.com>
parents:
38554
diff
changeset
|
32 | * A #PurpleQueuedOutputStream is a #GOutputStream which allows data to be |
|
32274f138667
queuedoutputstream: Fix docstring referencing GQueuedOutputStream
Mike Ruprecht <cmaiku@gmail.com>
parents:
38554
diff
changeset
|
33 | * queued for outputting. It differs from a #GBufferedOutputStream in that |
|
32274f138667
queuedoutputstream: Fix docstring referencing GQueuedOutputStream
Mike Ruprecht <cmaiku@gmail.com>
parents:
38554
diff
changeset
|
34 | * it allows for data to be queued while other operations are in progress. |
|
37665
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
35 | */ |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
36 | |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
37 | #include <gio/gio.h> |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
38 | |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
39 | G_BEGIN_DECLS |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
40 | |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
41 | #define PURPLE_TYPE_QUEUED_OUTPUT_STREAM (purple_queued_output_stream_get_type()) |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
42 | #define PURPLE_QUEUED_OUTPUT_STREAM(o) (G_TYPE_CHECK_INSTANCE_CAST((o), PURPLE_TYPE_QUEUED_OUTPUT_STREAM, PurpleQueuedOutputStream)) |
|
38554
3a878ccb7d2c
queuedoutputstream: Fix GObject class macro definitions
Mike Ruprecht <cmaiku@gmail.com>
parents:
38552
diff
changeset
|
43 | #define PURPLE_QUEUED_OUTPUT_STREAM_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), PURPLE_TYPE_QUEUED_OUTPUT_STREAM, PurpleQueuedOutputStreamClass)) |
|
3a878ccb7d2c
queuedoutputstream: Fix GObject class macro definitions
Mike Ruprecht <cmaiku@gmail.com>
parents:
38552
diff
changeset
|
44 | #define PURPLE_IS_QUEUED_OUTPUT_STREAM(o) (G_TYPE_CHECK_INSTANCE_TYPE((o), PURPLE_TYPE_QUEUED_OUTPUT_STREAM)) |
|
37665
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
45 | #define PURPLE_IS_QUEUED_OUTPUT_STREAM_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE((k), PURPLE_TYPE_QUEUED_OUTPUT_STREAM)) |
|
38564
69406101655c
queuedoutputstream: Fix one more typo in class declaration
Mike Ruprecht <cmaiku@gmail.com>
parents:
38555
diff
changeset
|
46 | #define PURPLE_IS_QUEUED_OUTPUT_STREAM_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), PURPLE_TYPE_QUEUED_OUTPUT_STREAM, PurpleQueuedOutputStreamClass)) |
|
37665
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
47 | |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
48 | /** |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
49 | * PurpleQueuedOutputStream: |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
50 | * |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
51 | * An implementation of #GFilterOutputStream which allows queuing data for |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
52 | * output. This allows data to be queued while other data is being output. |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
53 | * Therefore, data doesn't have to be manually stored while waiting for |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
54 | * stream operations to finish. |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
55 | * |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
56 | * To create a queued output stream, use #purple_queued_output_stream_new(). |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
57 | * |
|
39165
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
58 | * To queue data, use #purple_queued_output_stream_push_bytes_async(). |
|
37665
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
59 | * |
|
39165
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
60 | * If there's a fatal stream error, it's suggested to clear the remaining |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
61 | * bytes queued with #purple_queued_output_stream_clear_queue() to avoid |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
62 | * excessive errors returned in |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
63 | * #purple_queued_output_stream_push_bytes_async()'s async callback. |
|
37665
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
64 | */ |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
65 | typedef struct _PurpleQueuedOutputStream PurpleQueuedOutputStream; |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
66 | typedef struct _PurpleQueuedOutputStreamClass PurpleQueuedOutputStreamClass; |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
67 | typedef struct _PurpleQueuedOutputStreamPrivate PurpleQueuedOutputStreamPrivate; |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
68 | |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
69 | struct _PurpleQueuedOutputStream |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
70 | { |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
71 | GFilterOutputStream parent_instance; |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
72 | |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
73 | /*< protected >*/ |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
74 | PurpleQueuedOutputStreamPrivate *priv; |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
75 | }; |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
76 | |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
77 | struct _PurpleQueuedOutputStreamClass |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
78 | { |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
79 | GFilterOutputStreamClass parent_class; |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
80 | |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
81 | /*< private >*/ |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
82 | /* Padding for future expansion */ |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
83 | void (*_g_reserved1)(void); |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
84 | void (*_g_reserved2)(void); |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
85 | }; |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
86 | |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
87 | GType purple_queued_output_stream_get_type(void) G_GNUC_CONST; |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
88 | |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
89 | /* |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
90 | * purple_queued_output_stream_new |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
91 | * @base_stream: Base output stream to wrap with the queued stream |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
92 | * |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
93 | * Creates a new queued output stream for a base stream. |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
94 | */ |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
95 | PurpleQueuedOutputStream *purple_queued_output_stream_new( |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
96 | GOutputStream *base_stream); |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
97 | |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
98 | /* |
|
39165
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
99 | * purple_queued_output_stream_push_bytes_async |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
100 | * @stream: #PurpleQueuedOutputStream to push bytes to |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
101 | * @bytes: Bytes to queue |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
102 | * @priority: IO priority of the request |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
103 | * @cancellable: (allow-none): Optional #GCancellable object, NULL to ignore |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
104 | * @callback: (scope async): Callback to call when the request is finished |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
105 | * @user_data: (closure): Data to pass to the callback function |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
106 | * |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
107 | * Asynchronously queues and then writes data to the output stream. |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
108 | * Once the data has been written, or an error occurs, the callback |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
109 | * will be called. |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
110 | * |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
111 | * Be careful such that if there's a fatal stream error, all remaining queued |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
112 | * operations will likely return this error. Use |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
113 | * #purple_queued_output_stream_clear_queue() to clear the queue on such |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
114 | * an error to only report it a single time. |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
115 | */ |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
116 | void purple_queued_output_stream_push_bytes_async( |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
117 | PurpleQueuedOutputStream *stream, GBytes *bytes, |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
118 | int io_priority, GCancellable *cancellable, |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
119 | GAsyncReadyCallback callback, gpointer user_data); |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
120 | |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
121 | /* |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
122 | * purple_queued_output_stream_push_bytes_finish |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
123 | * @stream: #PurpleQueuedOutputStream bytes were pushed to |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
124 | * @result: The #GAsyncResult of this operation |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
125 | * @error: A GError location to store the error, or NULL to ignore |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
126 | * |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
127 | * Finishes pushing bytes asynchronously. |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
128 | * |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
129 | * Returns: %TRUE on success, %FALSE if there was an error |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
130 | */ |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
131 | gboolean purple_queued_output_stream_push_bytes_finish( |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
132 | PurpleQueuedOutputStream *stream, |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
133 | GAsyncResult *result, GError **error); |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
134 | |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
135 | /* |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
136 | * purple_queued_output_stream_clear_queue |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
137 | * @stream: #PurpleQueuedOutputStream to clear |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
138 | * |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
139 | * Clears the queue of any pending bytes. However, any bytes that are |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
140 | * in the process of being sent will finish their operation. |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
141 | * |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
142 | * This function is useful for clearing the queue in case of an IO error. |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
143 | * Call this in the async callback in order to clear the queue and avoid |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
144 | * having all #purple_queue_output_stream_push_bytes_async() calls on |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
145 | * this queue return errors if there's a fatal stream error. |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
146 | */ |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
147 | void purple_queued_output_stream_clear_queue(PurpleQueuedOutputStream *stream); |
|
62b8ef4dd1d3
queuedoutputstream: Refactor to behave better with the rest of Gio
Mike Ruprecht <cmaiku@gmail.com>
parents:
38564
diff
changeset
|
148 | |
|
37665
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
149 | G_END_DECLS |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
150 | |
|
3eab84b9b88f
libpurple: Add PurpleQueuedOutputStream for fire and forget output
Mike Ruprecht <cmaiku@gmail.com>
parents:
diff
changeset
|
151 | #endif /* _PURPLE_QUEUED_OUTPUT_STREAM_H */ |