Top |
gboolean | (*GPollableSourceFunc) () |
GSource * | g_pollable_source_new () |
GSource * | g_pollable_source_new_full () |
gssize | g_pollable_stream_read () |
gssize | g_pollable_stream_write () |
gboolean | g_pollable_stream_write_all () |
gboolean (*GPollableSourceFunc) (GObject *pollable_stream
,gpointer user_data
);
This is the function type of the callback used for the GSource
returned by g_pollable_input_stream_create_source()
and
g_pollable_output_stream_create_source()
.
Since: 2.28
GSource *
g_pollable_source_new (GObject *pollable_stream
);
Utility method for GPollableInputStream and GPollableOutputStream
implementations. Creates a new GSource that expects a callback of
type GPollableSourceFunc. The new source does not actually do
anything on its own; use g_source_add_child_source()
to add other
sources to it to cause it to trigger.
Since: 2.28
GSource * g_pollable_source_new_full (gpointer pollable_stream
,GSource *child_source
,GCancellable *cancellable
);
Utility method for GPollableInputStream and GPollableOutputStream
implementations. Creates a new GSource, as with
g_pollable_source_new()
, but also attaching child_source
(with a
dummy callback), and cancellable
, if they are non-NULL
.
pollable_stream |
the stream associated with the new source. |
[type GObject] |
child_source |
optional child source to attach. |
[nullable] |
cancellable |
optional GCancellable to attach. |
[nullable] |
Since: 2.34
gssize g_pollable_stream_read (GInputStream *stream
,void *buffer
,gsize count
,gboolean blocking
,GCancellable *cancellable
,GError **error
);
Tries to read from stream
, as with g_input_stream_read()
(if
blocking
is TRUE
) or g_pollable_input_stream_read_nonblocking()
(if blocking
is FALSE
). This can be used to more easily share
code between blocking and non-blocking implementations of a method.
If blocking
is FALSE
, then stream
must be a
GPollableInputStream for which g_pollable_input_stream_can_poll()
returns TRUE
, or else the behavior is undefined. If blocking
is
TRUE
, then stream
does not need to be a GPollableInputStream.
stream |
||
buffer |
a buffer to read data into. |
[array length=count][element-type guint8] |
count |
the number of bytes to read |
|
blocking |
whether to do blocking I/O |
|
cancellable |
optional GCancellable object, |
[nullable] |
error |
location to store the error occurring, or |
Since: 2.34
gssize g_pollable_stream_write (GOutputStream *stream
,const void *buffer
,gsize count
,gboolean blocking
,GCancellable *cancellable
,GError **error
);
Tries to write to stream
, as with g_output_stream_write()
(if
blocking
is TRUE
) or g_pollable_output_stream_write_nonblocking()
(if blocking
is FALSE
). This can be used to more easily share
code between blocking and non-blocking implementations of a method.
If blocking
is FALSE
, then stream
must be a
GPollableOutputStream for which
g_pollable_output_stream_can_poll()
returns TRUE
or else the
behavior is undefined. If blocking
is TRUE
, then stream
does not
need to be a GPollableOutputStream.
stream |
||
buffer |
the buffer containing the data to write. |
[array length=count][element-type guint8] |
count |
the number of bytes to write |
|
blocking |
whether to do blocking I/O |
|
cancellable |
optional GCancellable object, |
[nullable] |
error |
location to store the error occurring, or |
Since: 2.34
gboolean g_pollable_stream_write_all (GOutputStream *stream
,const void *buffer
,gsize count
,gboolean blocking
,gsize *bytes_written
,GCancellable *cancellable
,GError **error
);
Tries to write count
bytes to stream
, as with
g_output_stream_write_all()
, but using g_pollable_stream_write()
rather than g_output_stream_write()
.
On a successful write of count
bytes, TRUE
is returned, and
bytes_written
is set to count
.
If there is an error during the operation (including
G_IO_ERROR_WOULD_BLOCK
in the non-blocking case), FALSE
is
returned and error
is set to indicate the error status,
bytes_written
is updated to contain the number of bytes written
into the stream before the error occurred.
As with g_pollable_stream_write()
, if blocking
is FALSE
, then
stream
must be a GPollableOutputStream for which
g_pollable_output_stream_can_poll()
returns TRUE
or else the
behavior is undefined. If blocking
is TRUE
, then stream
does not
need to be a GPollableOutputStream.
stream |
||
buffer |
the buffer containing the data to write. |
[array length=count][element-type guint8] |
count |
the number of bytes to write |
|
blocking |
whether to do blocking I/O |
|
bytes_written |
location to store the number of bytes that was written to the stream. |
[out] |
cancellable |
optional GCancellable object, |
[nullable] |
error |
location to store the error occurring, or |
Since: 2.34
Return value for various IO operations that signal errors via the return value and not necessarily via a GError.
This enum exists to be able to return errors to callers without having to
allocate a GError. Allocating GErrors can be quite expensive for
regularly happening errors like G_IO_ERROR_WOULD_BLOCK
.
In case of G_POLLABLE_RETURN_FAILED
a GError should be set for the
operation to give details about the error that happened.
Since: 2.60