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_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(). | |
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(). | |
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) |
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] |
Reimplemented from Gio::BufferedInputStream.
DataStreamByteOrder Gio::DataInputStream::get_byte_order | ( | ) | const |
Gets the byte order for the data input stream.
DataStreamNewlineType Gio::DataInputStream::get_newline_type | ( | ) | const |
Gets the current newline type for the stream.
const GDataInputStream* Gio::DataInputStream::gobj | ( | ) | const [inline] |
Provides access to the underlying C GObject.
Reimplemented from Gio::BufferedInputStream.
GDataInputStream* Gio::DataInputStream::gobj | ( | ) | [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.
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.
Glib::PropertyProxy<DataStreamByteOrder> Gio::DataInputStream::property_byte_order | ( | ) |
The byte order.
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.
Glib::PropertyProxy<DataStreamNewlineType> Gio::DataInputStream::property_newline_type | ( | ) |
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 | ( | ) |
non-cancellable version of read_byte()
Reimplemented from Gio::BufferedInputStream.
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.
gint16 Gio::DataInputStream::read_int16 | ( | ) |
non-cancellable version of read_int16()
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 Glib::data_stream_get_byte_order() and Glib::data_stream_set_byte_order().
cancellable | Optional Cancellable object, 0 to ignore. |
gint32 Gio::DataInputStream::read_int32 | ( | ) |
non-cancellable version of read_int32()
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. |
gint64 Gio::DataInputStream::read_int64 | ( | ) |
non-cancellable version of read_int64()
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. |
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). |
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. |
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. |
guint16 Gio::DataInputStream::read_uint16 | ( | ) |
non-cancellable version of read_uint16()
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 Glib::data_stream_get_byte_order() and Glib::data_stream_set_byte_order().
cancellable | Optional Cancellable object, 0 to ignore. |
guint32 Gio::DataInputStream::read_uint32 | ( | ) |
non-cancellable version of read_uint32()
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. |
guint64 Gio::DataInputStream::read_uint64 | ( | ) |
non-cancellable version of read_uint64()
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. |
bool Gio::DataInputStream::read_until | ( | std::string & | data, | |
const std::string & | stop_chars | |||
) |
A non-cancellable version of read_until().
stop_chars | Characters to terminate the read. | |
data | A string to fill with the read data. |
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.
data | A string to fill with the read data. | |
stop_chars | Characters to terminate the read. | |
cancellable | A cancellable object. |
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.
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. |
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. |
void Gio::DataInputStream::set_newline_type | ( | DataStreamNewlineType | type | ) |
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 availible.
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. |