libguac
0.9.11-incubating
|
Provides functions and structures for parsing the Guacamole protocol. More...
Go to the source code of this file.
Data Structures | |
struct | guac_parser |
A Guacamole protocol parser, which reads individual instructions, filling its own internal structure with the most recently read instruction data. More... | |
Functions | |
guac_parser * | guac_parser_alloc () |
Allocates a new parser. More... | |
int | guac_parser_append (guac_parser *parser, void *buffer, int length) |
Appends data from the given buffer to the given parser. More... | |
int | guac_parser_length (guac_parser *parser) |
Returns the number of unparsed bytes stored in the given parser's internal buffers. More... | |
int | guac_parser_shift (guac_parser *parser, void *buffer, int length) |
Removes up to length bytes from internal buffer of unparsed bytes, storing them in the given buffer. More... | |
void | guac_parser_free (guac_parser *parser) |
Frees all memory allocated to the given parser. More... | |
int | guac_parser_read (guac_parser *parser, guac_socket *socket, int usec_timeout) |
Reads a single instruction from the given guac_socket connection. More... | |
int | guac_parser_expect (guac_parser *parser, guac_socket *socket, int usec_timeout, const char *opcode) |
Reads a single instruction from the given guac_socket. More... | |
Provides functions and structures for parsing the Guacamole protocol.
guac_parser* guac_parser_alloc | ( | ) |
Allocates a new parser.
int guac_parser_append | ( | guac_parser * | parser, |
void * | buffer, | ||
int | length | ||
) |
Appends data from the given buffer to the given parser.
The data will be appended, if possible, to the in-progress instruction as a reference and thus the buffer must remain valid throughout the life of the current instruction. This function may modify the contents of the buffer when those contents are part of an element within the instruction being read.
parser | The parser to append data to. |
buffer | A buffer containing data that should be appended to this parser. |
length | The number of bytes available for appending within the buffer. |
int guac_parser_expect | ( | guac_parser * | parser, |
guac_socket * | socket, | ||
int | usec_timeout, | ||
const char * | opcode | ||
) |
Reads a single instruction from the given guac_socket.
This operates identically to guac_parser_read(), except that an error is returned if the expected opcode is not received.
If an error occurs reading the instruction, NULL is returned, and guac_error is set appropriately.
If the instruction read is not the expected instruction, NULL is returned, and guac_error is set to GUAC_STATUS_BAD_STATE.
parser | The guac_parser to read instruction data from. |
socket | The guac_socket connection to use. |
usec_timeout | The maximum number of microseconds to wait before giving up. |
opcode | The opcode of the instruction to read. |
void guac_parser_free | ( | guac_parser * | parser | ) |
Frees all memory allocated to the given parser.
parser | The parser to free. |
int guac_parser_length | ( | guac_parser * | parser | ) |
Returns the number of unparsed bytes stored in the given parser's internal buffers.
parser | The parser to return the length of. |
int guac_parser_read | ( | guac_parser * | parser, |
guac_socket * | socket, | ||
int | usec_timeout | ||
) |
Reads a single instruction from the given guac_socket connection.
This may result in additional data being read from the guac_socket, stored internally within a buffer for future parsing. Future calls to guac_parser_read() will read from the interal buffer before reading from the guac_socket. Data from the internal buffer can be removed and used elsewhere through guac_parser_shift().
If an error occurs reading the instruction, non-zero is returned, and guac_error is set appropriately.
parser | The guac_parser to read instruction data from. |
socket | The guac_socket connection to use. |
usec_timeout | The maximum number of microseconds to wait before giving up. |
int guac_parser_shift | ( | guac_parser * | parser, |
void * | buffer, | ||
int | length | ||
) |
Removes up to length bytes from internal buffer of unparsed bytes, storing them in the given buffer.
parser | The parser to remove unparsed bytes from. |
buffer | The buffer to store the unparsed bytes within. |
length | The length of the given buffer. |