glibmm
2.31.22
|
An implementation of BufferedInputStream that allows for high-level data manipulation of arbitrary data (including binary operations). More...
#include <giomm/datainputstream.h>
Public Member Functions | |
virtual | ~DataInputStream () |
GDataInputStream* | gobj () |
Provides access to the underlying C GObject. | |
const GDataInputStream* | gobj () const |
Provides access to the underlying C GObject. | |
GDataInputStream* | gobj_copy () |
Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs. | |
void | set_byte_order (DataStreamByteOrder order) |
This function sets the byte order for the given stream. | |
DataStreamByteOrder | get_byte_order () const |
Gets the byte order for the data input stream. | |
void | set_newline_type (DataStreamNewlineType type) |
Sets the newline type for the stream. | |
DataStreamNewlineType | get_newline_type () const |
Gets the current newline type for the stream. | |
guchar | read_byte (const Glib::RefPtr< Cancellable >& cancellable) |
Reads an unsigned 8-bit/1-byte value from stream. | |
guchar | read_byte () |
non-cancellable version of read_byte() | |
gint16 | read_int16 (const Glib::RefPtr< Cancellable >& cancellable) |
Reads a 16-bit/2-byte value from stream. | |
gint16 | read_int16 () |
non-cancellable version of read_int16() | |
guint16 | read_uint16 (const Glib::RefPtr< Cancellable >& cancellable) |
Reads an unsigned 16-bit/2-byte value from stream. | |
guint16 | read_uint16 () |
non-cancellable version of read_uint16() | |
gint32 | read_int32 (const Glib::RefPtr< Cancellable >& cancellable) |
Reads a signed 32-bit/4-byte value from stream. | |
gint32 | read_int32 () |
non-cancellable version of read_int32() | |
guint32 | read_uint32 (const Glib::RefPtr< Cancellable >& cancellable) |
Reads an unsigned 32-bit/4-byte value from stream. | |
guint32 | read_uint32 () |
non-cancellable version of read_uint32() | |
gint64 | read_int64 (const Glib::RefPtr< Cancellable >& cancellable) |
Reads a 64-bit/8-byte value from stream. | |
gint64 | read_int64 () |
non-cancellable version of read_int64() | |
guint64 | read_uint64 (const Glib::RefPtr< Cancellable >& cancellable) |
Reads an unsigned 64-bit/8-byte value from stream. | |
guint64 | read_uint64 () |
non-cancellable version of read_uint64() | |
bool | read_line (std::string& line, const Glib::RefPtr< Cancellable >& cancellable) |
Reads a line from the data input stream. | |
bool | read_line (std::string& line) |
A non-cancellable version of read_line(). | |
void | read_line_utf8 (std::string& line, const Glib::RefPtr< Cancellable >& cancellable, gsize& length) |
Reads a UTF-8 encoded line from the data input stream. | |
void | read_line_utf8 (std::string& line, const Glib::RefPtr< Cancellable >& cancellable) |
A read_line_utf8() convenience overload. | |
void | read_line_utf8 (std::string& line, gsize& length) |
A read_line_utf8() convenience overload. | |
void | read_line_utf8 (std::string& line) |
A read_line_utf8() convenience overload. | |
void | read_line_async (const SlotAsyncReady& slot, const Glib::RefPtr< Cancellable >& cancellable, int io_priority=Glib::PRIORITY_DEFAULT) |
The asynchronous version of read_until(). | |
bool | read_line_finish (const Glib::RefPtr< AsyncResult >& result, std::string& data) |
Finish an asynchronous call started by read_line_async(). | |
void | read_line_finish_utf8 (const Glib::RefPtr< AsyncResult >& result, std::string& data, gsize& length) |
Finish an asynchronous call started by g_data_input_stream_read_line_async(). | |
void | read_line_finish_utf8 (const Glib::RefPtr< AsyncResult >& result, std::string& data) |
A read_line_finish_utf8() convenience overload. | |
bool | read_until (std::string& data, const std::string& stop_chars, const Glib::RefPtr< Cancellable >& cancellable) |
Reads a string from the data input stream, up to the first occurrence of any of the stop characters. | |
bool | read_until (std::string& data, const std::string& stop_chars) |
A non-cancellable version of read_until(). | |
void | read_until_async (const std::string& stop_chars, const SlotAsyncReady& slot, const Glib::RefPtr< Cancellable >& cancellable, int io_priority=Glib::PRIORITY_DEFAULT) |
The asynchronous version of read_until(). | |
bool | read_until_finish (const Glib::RefPtr< AsyncResult >& result, std::string& data) |
Finish an asynchronous call started by read_until_async(). | |
bool | read_upto (std::string& data, const std::string& stop_chars, const Glib::RefPtr< Cancellable >& cancellable) |
Reads a string from the data input stream, up to the first occurrence of any of the stop characters. | |
bool | read_upto (std::string& data, const std::string& stop_chars) |
A non-cancellable version of read_upto(). | |
void | read_upto_async (const std::string& stop_chars, const SlotAsyncReady& slot, const Glib::RefPtr< Cancellable >& cancellable, int io_priority=Glib::PRIORITY_DEFAULT) |
The asynchronous version of read_upto(). | |
bool | read_upto_finish (const Glib::RefPtr< AsyncResult >& result, std::string& data) |
Finish an asynchronous call started by read_upto_async(). | |
Glib::PropertyProxy < DataStreamByteOrder > | property_byte_order () |
The byte order. | |
Glib::PropertyProxy_ReadOnly < DataStreamByteOrder > | property_byte_order () const |
The byte order. | |
Glib::PropertyProxy < DataStreamNewlineType > | property_newline_type () |
The accepted types of line ending. | |
Glib::PropertyProxy_ReadOnly < DataStreamNewlineType > | property_newline_type () const |
The accepted types of line ending. | |
Static Public Member Functions | |
static Glib::RefPtr < DataInputStream > | create (const Glib::RefPtr< InputStream >& base_stream) |
Creates a new InputStream from the given base_stream, with a buffer set to the default size (4 kilobytes). | |
Protected Member Functions | |
DataInputStream (const Glib::RefPtr< InputStream >& base_stream) | |
Related Functions | |
(Note that these are not member functions.) | |
Glib::RefPtr < Gio::DataInputStream > | wrap (GDataInputStream* object, bool take_copy=false) |
A Glib::wrap() method for this object. |
An implementation of BufferedInputStream that allows for high-level data manipulation of arbitrary data (including binary operations).
virtual Gio::DataInputStream::~DataInputStream | ( | ) | [virtual] |
Gio::DataInputStream::DataInputStream | ( | const Glib::RefPtr< InputStream >& | base_stream | ) | [explicit, protected] |
static Glib::RefPtr<DataInputStream> Gio::DataInputStream::create | ( | const Glib::RefPtr< InputStream >& | base_stream | ) | [static] |
Creates a new InputStream from the given base_stream, with a buffer set to the default size (4 kilobytes).
base_stream | An InputStream. |
Reimplemented from Gio::BufferedInputStream.
Gets the byte order for the data input stream.
Gets the current newline type for the stream.
GDataInputStream* Gio::DataInputStream::gobj | ( | ) | [inline] |
Provides access to the underlying C GObject.
Reimplemented from Gio::BufferedInputStream.
const GDataInputStream* Gio::DataInputStream::gobj | ( | ) | const [inline] |
Provides access to the underlying C GObject.
Reimplemented from Gio::BufferedInputStream.
GDataInputStream* Gio::DataInputStream::gobj_copy | ( | ) |
Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs.
Reimplemented from Gio::BufferedInputStream.
The byte order.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly< DataStreamByteOrder > Gio::DataInputStream::property_byte_order | ( | ) | const |
The byte order.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
The accepted types of line ending.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly< DataStreamNewlineType > Gio::DataInputStream::property_newline_type | ( | ) | const |
The accepted types of line ending.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
guchar Gio::DataInputStream::read_byte | ( | const Glib::RefPtr< Cancellable >& | cancellable | ) |
Reads an unsigned 8-bit/1-byte value from stream.
cancellable | Optional Cancellable object, 0 to ignore. |
Reimplemented from Gio::BufferedInputStream.
guchar Gio::DataInputStream::read_byte | ( | ) |
non-cancellable version of read_byte()
Reimplemented from Gio::BufferedInputStream.
gint16 Gio::DataInputStream::read_int16 | ( | const Glib::RefPtr< Cancellable >& | cancellable | ) |
Reads a 16-bit/2-byte value from stream.
In order to get the correct byte order for this read operation, see g_data_input_stream_get_byte_order() and g_data_input_stream_set_byte_order().
cancellable | Optional Cancellable object, 0 to ignore. |
gint16 Gio::DataInputStream::read_int16 | ( | ) |
non-cancellable version of read_int16()
gint32 Gio::DataInputStream::read_int32 | ( | const Glib::RefPtr< Cancellable >& | cancellable | ) |
Reads a signed 32-bit/4-byte value from stream.
In order to get the correct byte order for this read operation, see Glib::data_stream_get_byte_order() and Glib::data_stream_set_byte_order().
The operation can be cancelled by triggering the cancellable object from another thread. If the operation was cancelled, a Gio::Error will be thrown with CANCELLED.
cancellable | Cancellable object. |
gint32 Gio::DataInputStream::read_int32 | ( | ) |
non-cancellable version of read_int32()
gint64 Gio::DataInputStream::read_int64 | ( | const Glib::RefPtr< Cancellable >& | cancellable | ) |
Reads a 64-bit/8-byte value from stream.
In order to get the correct byte order for this read operation, see Glib::data_stream_get_byte_order() and Glib::data_stream_set_byte_order().
The operation can be cancelled by triggering the cancellable object from another thread. If the operation was cancelled, a Gio::Error will be thrown with CANCELLED.
cancellable | Cancellable object. |
gint64 Gio::DataInputStream::read_int64 | ( | ) |
non-cancellable version of read_int64()
bool Gio::DataInputStream::read_line | ( | std::string & | line, |
const Glib::RefPtr< Cancellable >& | cancellable | ||
) |
Reads a line from the data input stream.
The operation can be cancelled by triggering the cancellable object from another thread. If the operation was cancelled, a Gio::Error with CANCELLED will be thrown.
data | A string to fill with the read data (without the newlines). |
cancellable | A cancellable object. |
bool Gio::DataInputStream::read_line | ( | std::string & | line | ) |
A non-cancellable version of read_line().
data | A string to fill with the read data (without the newlines). |
void Gio::DataInputStream::read_line_async | ( | const SlotAsyncReady& | slot, |
const Glib::RefPtr< Cancellable >& | cancellable, | ||
int | io_priority = Glib::PRIORITY_DEFAULT |
||
) |
The asynchronous version of read_until().
It is an error to have two outstanding calls to this function.
slot | The slot to call when the request is satisfied. |
cancellable | A cancellable object. |
io_priority | The I/O priority of the request. |
bool Gio::DataInputStream::read_line_finish | ( | const Glib::RefPtr< AsyncResult >& | result, |
std::string & | data | ||
) |
Finish an asynchronous call started by read_line_async().
result | The AsyncResult that was provided to the callback slot. |
data | A string to fill with the read data. |
void Gio::DataInputStream::read_line_finish_utf8 | ( | const Glib::RefPtr< AsyncResult >& | result, |
std::string & | data, | ||
gsize & | length | ||
) |
Finish an asynchronous call started by g_data_input_stream_read_line_async().
result | The AsyncResult that was provided to the callback. |
length | A #gsize to get the length of the data read in. |
0
and error will be set. For UTF-8 conversion errors, the set error domain is CONVERT_ERROR. If there's no content to read, it will still return 0
, but error won't be set. void Gio::DataInputStream::read_line_finish_utf8 | ( | const Glib::RefPtr< AsyncResult >& | result, |
std::string & | data | ||
) |
A read_line_finish_utf8() convenience overload.
void Gio::DataInputStream::read_line_utf8 | ( | std::string & | line, |
const Glib::RefPtr< Cancellable >& | cancellable, | ||
gsize & | length | ||
) |
Reads a UTF-8 encoded line from the data input stream.
If cancellable is not 0
, then the operation can be cancelled by triggering the cancellable object from another thread. If the operation was cancelled, the error IO_ERROR_CANCELLED will be returned.
length | A #gsize to get the length of the data read in. |
cancellable | Optional Cancellable object, 0 to ignore. |
0
and error will be set. For UTF-8 conversion errors, the set error domain is CONVERT_ERROR. If there's no content to read, it will still return 0
, but error won't be set. void Gio::DataInputStream::read_line_utf8 | ( | std::string & | line, |
const Glib::RefPtr< Cancellable >& | cancellable | ||
) |
A read_line_utf8() convenience overload.
void Gio::DataInputStream::read_line_utf8 | ( | std::string & | line, |
gsize & | length | ||
) |
A read_line_utf8() convenience overload.
void Gio::DataInputStream::read_line_utf8 | ( | std::string & | line | ) |
A read_line_utf8() convenience overload.
guint16 Gio::DataInputStream::read_uint16 | ( | const Glib::RefPtr< Cancellable >& | cancellable | ) |
Reads an unsigned 16-bit/2-byte value from stream.
In order to get the correct byte order for this read operation, see g_data_input_stream_get_byte_order() and g_data_input_stream_set_byte_order().
cancellable | Optional Cancellable object, 0 to ignore. |
guint16 Gio::DataInputStream::read_uint16 | ( | ) |
non-cancellable version of read_uint16()
guint32 Gio::DataInputStream::read_uint32 | ( | const Glib::RefPtr< Cancellable >& | cancellable | ) |
Reads an unsigned 32-bit/4-byte value from stream.
In order to get the correct byte order for this read operation, see Glib::data_stream_get_byte_order() and Glib::data_stream_set_byte_order().
The operation can be cancelled by triggering the cancellable object from another thread. If the operation was cancelled, a Gio::Error will be thrown with CANCELLED.
cancellable | Cancellable object. |
guint32 Gio::DataInputStream::read_uint32 | ( | ) |
non-cancellable version of read_uint32()
guint64 Gio::DataInputStream::read_uint64 | ( | const Glib::RefPtr< Cancellable >& | cancellable | ) |
Reads an unsigned 64-bit/8-byte value from stream.
In order to get the correct byte order for this read operation, see Glib::data_stream_get_byte_order().
The operation can be cancelled by triggering the cancellable object from another thread. If the operation was cancelled, a Gio::Error will be thrown with CANCELLED.
cancellable | Cancellable object. |
guint64 Gio::DataInputStream::read_uint64 | ( | ) |
non-cancellable version of read_uint64()
bool Gio::DataInputStream::read_until | ( | std::string & | data, |
const std::string & | stop_chars, | ||
const Glib::RefPtr< Cancellable >& | cancellable | ||
) |
Reads a string from the data input stream, up to the first occurrence of any of the stop characters.
Note that, in contrast to read_until_async(), this function consumes the stop character that it finds.
Don't use this function in new code. Its functionality is inconsistent with read_until_async(). Both functions will be marked as deprecated in a future release. Use read_upto() instead, but note that that method does not consume the stop character.
data | A string to fill with the read data. |
stop_chars | Characters to terminate the read. |
cancellable | A cancellable object. |
bool Gio::DataInputStream::read_until | ( | std::string & | data, |
const std::string & | stop_chars | ||
) |
A non-cancellable version of read_until().
Note that, in contrast to read_until_async(), this function consumes the stop character that it finds.
Don't use this function in new code. Its functionality is inconsistent with read_until_async(). Both functions will be marked as deprecated in a future release. Use read_upto() instead, but note that that method does not consume the stop character.
stop_chars | Characters to terminate the read. |
data | A string to fill with the read data. |
void Gio::DataInputStream::read_until_async | ( | const std::string & | stop_chars, |
const SlotAsyncReady& | slot, | ||
const Glib::RefPtr< Cancellable >& | cancellable, | ||
int | io_priority = Glib::PRIORITY_DEFAULT |
||
) |
The asynchronous version of read_until().
It is an error to have two outstanding calls to this function.
Note that, in contrast to ead_until(), this function does not consume the stop character that it finds. You must read it for yourself.
Don't use this function in new code. Its functionality is inconsistent with read_until(). Both functions will be marked as deprecated in a future release. Use read_upto_async() instead.
stop_chars | Characters to terminate the read. |
slot | The slot to call when the request is satisfied. |
cancellable | A cancellable object. |
io_priority | The I/O priority of the request. |
bool Gio::DataInputStream::read_until_finish | ( | const Glib::RefPtr< AsyncResult >& | result, |
std::string & | data | ||
) |
Finish an asynchronous call started by read_until_async().
result | The AsyncResult that was provided to the callback slot. |
data | A string to fill with the read data. |
bool Gio::DataInputStream::read_upto | ( | std::string & | data, |
const std::string & | stop_chars, | ||
const Glib::RefPtr< Cancellable >& | cancellable | ||
) |
Reads a string from the data input stream, up to the first occurrence of any of the stop characters.
In contrast to read_until(), this method does <emphasis>not</emphasis> consume the stop character. You have to use read_byte() to get it before calling read_upto() again.
data | A string to fill with the read data. |
stop_chars | Characters to terminate the read. |
cancellable | A cancellable object. |
bool Gio::DataInputStream::read_upto | ( | std::string & | data, |
const std::string & | stop_chars | ||
) |
A non-cancellable version of read_upto().
stop_chars | Characters to terminate the read. |
data | A string to fill with the read data. |
void Gio::DataInputStream::read_upto_async | ( | const std::string & | stop_chars, |
const SlotAsyncReady& | slot, | ||
const Glib::RefPtr< Cancellable >& | cancellable, | ||
int | io_priority = Glib::PRIORITY_DEFAULT |
||
) |
The asynchronous version of read_upto().
It is an error to have two outstanding calls to this function.
In contrast to read_until(), this method does <emphasis>not</emphasis> consume the stop character. You have to use read_byte() to get it before calling read_upto() again.
stop_chars | Characters to terminate the read. |
slot | The slot to call when the request is satisfied. |
cancellable | A cancellable object. |
io_priority | The I/O priority of the request. |
bool Gio::DataInputStream::read_upto_finish | ( | const Glib::RefPtr< AsyncResult >& | result, |
std::string & | data | ||
) |
Finish an asynchronous call started by read_upto_async().
Note that this function does <emphasis>not</emphasis> consume the stop character. You have to use read_byte() to get it before calling read_upto_async() again.
result | The AsyncResult that was provided to the callback slot. |
data | A string to fill with the read data. |
void Gio::DataInputStream::set_byte_order | ( | DataStreamByteOrder | order | ) |
This function sets the byte order for the given stream.
All subsequent reads from the stream will be read in the given order.
order | A DataStreamByteOrder to set. |
Sets the newline type for the stream.
Note that using G_DATA_STREAM_NEWLINE_TYPE_ANY is slightly unsafe. If a read chunk ends in "CR" we must read an additional byte to know if this is "CR" or "CR LF", and this might block if there is no more data available.
type | The type of new line return as DataStreamNewlineType. |
Glib::RefPtr< Gio::DataInputStream > wrap | ( | GDataInputStream * | object, |
bool | take_copy = false |
||
) | [related] |
A Glib::wrap() method for this object.
object | The C instance. |
take_copy | False if the result should take ownership of the C instance. True if it should take a new copy or ref. |