mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-25 21:46:14 +01:00
docs: Move the GIOStream SECTION
Move the contents to the struct docs. Signed-off-by: Philip Withnall <philip@tecnocode.co.uk> Helps: #3037
This commit is contained in:
parent
71ff617159
commit
eefda8158e
@ -32,57 +32,56 @@
|
|||||||
#include "gtask.h"
|
#include "gtask.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SECTION:giostream
|
* GIOStream:
|
||||||
* @short_description: Base class for implementing read/write streams
|
|
||||||
* @include: gio/gio.h
|
|
||||||
* @see_also: #GInputStream, #GOutputStream
|
|
||||||
*
|
*
|
||||||
* GIOStream represents an object that has both read and write streams.
|
* `GIOStream` represents an object that has both read and write streams.
|
||||||
* Generally the two streams act as separate input and output streams,
|
* Generally the two streams act as separate input and output streams,
|
||||||
* but they share some common resources and state. For instance, for
|
* but they share some common resources and state. For instance, for
|
||||||
* seekable streams, both streams may use the same position.
|
* seekable streams, both streams may use the same position.
|
||||||
*
|
*
|
||||||
* Examples of #GIOStream objects are #GSocketConnection, which represents
|
* Examples of `GIOStream` objects are [class@Gio.SocketConnection], which represents
|
||||||
* a two-way network connection; and #GFileIOStream, which represents a
|
* a two-way network connection; and [class@Gio.FileIOStream], which represents a
|
||||||
* file handle opened in read-write mode.
|
* file handle opened in read-write mode.
|
||||||
*
|
*
|
||||||
* To do the actual reading and writing you need to get the substreams
|
* To do the actual reading and writing you need to get the substreams
|
||||||
* with g_io_stream_get_input_stream() and g_io_stream_get_output_stream().
|
* with [method@Gio.IOStream.get_input_stream] and
|
||||||
|
* [method@Gio.IOStream.get_output_stream].
|
||||||
*
|
*
|
||||||
* The #GIOStream object owns the input and the output streams, not the other
|
* The `GIOStream` object owns the input and the output streams, not the other
|
||||||
* way around, so keeping the substreams alive will not keep the #GIOStream
|
* way around, so keeping the substreams alive will not keep the `GIOStream`
|
||||||
* object alive. If the #GIOStream object is freed it will be closed, thus
|
* object alive. If the `GIOStream` object is freed it will be closed, thus
|
||||||
* closing the substreams, so even if the substreams stay alive they will
|
* closing the substreams, so even if the substreams stay alive they will
|
||||||
* always return %G_IO_ERROR_CLOSED for all operations.
|
* always return `G_IO_ERROR_CLOSED` for all operations.
|
||||||
*
|
*
|
||||||
* To close a stream use g_io_stream_close() which will close the common
|
* To close a stream use [method@Gio.IOStream.close] which will close the common
|
||||||
* stream object and also the individual substreams. You can also close
|
* stream object and also the individual substreams. You can also close
|
||||||
* the substreams themselves. In most cases this only marks the
|
* the substreams themselves. In most cases this only marks the
|
||||||
* substream as closed, so further I/O on it fails but common state in the
|
* substream as closed, so further I/O on it fails but common state in the
|
||||||
* #GIOStream may still be open. However, some streams may support
|
* `GIOStream` may still be open. However, some streams may support
|
||||||
* "half-closed" states where one direction of the stream is actually shut down.
|
* ‘half-closed’ states where one direction of the stream is actually shut down.
|
||||||
*
|
*
|
||||||
* Operations on #GIOStreams cannot be started while another operation on the
|
* Operations on `GIOStream`s cannot be started while another operation on the
|
||||||
* #GIOStream or its substreams is in progress. Specifically, an application can
|
* `GIOStream` or its substreams is in progress. Specifically, an application can
|
||||||
* read from the #GInputStream and write to the #GOutputStream simultaneously
|
* read from the [class@Gio.InputStream] and write to the
|
||||||
* (either in separate threads, or as asynchronous operations in the same
|
* [class@Gio.OutputStream] simultaneously (either in separate threads, or as
|
||||||
* thread), but an application cannot start any #GIOStream operation while there
|
* asynchronous operations in the same thread), but an application cannot start
|
||||||
* is a #GIOStream, #GInputStream or #GOutputStream operation in progress, and
|
* any `GIOStream` operation while there is a `GIOStream`, `GInputStream` or
|
||||||
* an application can’t start any #GInputStream or #GOutputStream operation
|
* `GOutputStream` operation in progress, and an application can’t start any
|
||||||
* while there is a #GIOStream operation in progress.
|
* `GInputStream` or `GOutputStream` operation while there is a `GIOStream`
|
||||||
|
* operation in progress.
|
||||||
*
|
*
|
||||||
* This is a product of individual stream operations being associated with a
|
* This is a product of individual stream operations being associated with a
|
||||||
* given #GMainContext (the thread-default context at the time the operation was
|
* given [type@GLib.MainContext] (the thread-default context at the time the
|
||||||
* started), rather than entire streams being associated with a single
|
* operation was started), rather than entire streams being associated with a
|
||||||
* #GMainContext.
|
* single `GMainContext`.
|
||||||
*
|
*
|
||||||
* GIO may run operations on #GIOStreams from other (worker) threads, and this
|
* GIO may run operations on `GIOStream`s from other (worker) threads, and this
|
||||||
* may be exposed to application code in the behaviour of wrapper streams, such
|
* may be exposed to application code in the behaviour of wrapper streams, such
|
||||||
* as #GBufferedInputStream or #GTlsConnection. With such wrapper APIs,
|
* as [class@Gio.BufferedInputStream] or [class@Gio.TlsConnection]. With such
|
||||||
* application code may only run operations on the base (wrapped) stream when
|
* wrapper APIs, application code may only run operations on the base (wrapped)
|
||||||
* the wrapper stream is idle. Note that the semantics of such operations may
|
* stream when the wrapper stream is idle. Note that the semantics of such
|
||||||
* not be well-defined due to the state the wrapper stream leaves the base
|
* operations may not be well-defined due to the state the wrapper stream leaves
|
||||||
* stream in (though they are guaranteed not to crash).
|
* the base stream in (though they are guaranteed not to crash).
|
||||||
*
|
*
|
||||||
* Since: 2.22
|
* Since: 2.22
|
||||||
*/
|
*/
|
||||||
|
@ -40,11 +40,6 @@ G_BEGIN_DECLS
|
|||||||
typedef struct _GIOStreamPrivate GIOStreamPrivate;
|
typedef struct _GIOStreamPrivate GIOStreamPrivate;
|
||||||
typedef struct _GIOStreamClass GIOStreamClass;
|
typedef struct _GIOStreamClass GIOStreamClass;
|
||||||
|
|
||||||
/**
|
|
||||||
* GIOStream:
|
|
||||||
*
|
|
||||||
* Base class for read-write streams.
|
|
||||||
**/
|
|
||||||
struct _GIOStream
|
struct _GIOStream
|
||||||
{
|
{
|
||||||
GObject parent_instance;
|
GObject parent_instance;
|
||||||
|
Loading…
Reference in New Issue
Block a user