Provides functions and structures required for communicating using the Guacamole protocol over a guac_socket connection, such as that provided by guac_client objects. More...
Go to the source code of this file.
Enumerations | |
enum | guac_protocol_status { GUAC_PROTOCOL_STATUS_SUCCESS = 0x0000, GUAC_PROTOCOL_STATUS_UNSUPPORTED = 0x0100, GUAC_PROTOCOL_STATUS_SERVER_ERROR = 0x0200, GUAC_PROTOCOL_STATUS_SERVER_BUSY = 0x0201, GUAC_PROTOCOL_STATUS_UPSTREAM_TIMEOUT = 0x202, GUAC_PROTOCOL_STATUS_UPSTREAM_ERROR = 0x203, GUAC_PROTOCOL_STATUS_RESOURCE_NOT_FOUND = 0x204, GUAC_PROTOCOL_STATUS_RESOURCE_CONFLICT = 0x205, GUAC_PROTOCOL_STATUS_CLIENT_BAD_REQUEST = 0x300, GUAC_PROTOCOL_STATUS_CLIENT_UNAUTHORIZED = 0x0301, GUAC_PROTOCOL_STATUS_CLIENT_FORBIDDEN = 0x0303, GUAC_PROTOCOL_STATUS_CLIENT_TIMEOUT = 0x308, GUAC_PROTOCOL_STATUS_CLIENT_OVERRUN = 0x30D, GUAC_PROTOCOL_STATUS_CLIENT_BAD_TYPE = 0x30F, GUAC_PROTOCOL_STATUS_CLIENT_TOO_MANY = 0x31D } |
Set of all possible status codes returned by protocol operations. More... | |
enum | guac_composite_mode { GUAC_COMP_ROUT = 0x2, GUAC_COMP_ATOP = 0x6, GUAC_COMP_XOR = 0xA, GUAC_COMP_ROVER = 0xB, GUAC_COMP_OVER = 0xE, GUAC_COMP_PLUS = 0xF, GUAC_COMP_RIN = 0x1, GUAC_COMP_IN = 0x4, GUAC_COMP_OUT = 0x8, GUAC_COMP_RATOP = 0x9, GUAC_COMP_SRC = 0xC } |
Composite modes used by Guacamole draw instructions. More... | |
enum | guac_transfer_function { GUAC_TRANSFER_BINARY_BLACK = 0x0, GUAC_TRANSFER_BINARY_WHITE = 0xF, GUAC_TRANSFER_BINARY_SRC = 0x3, GUAC_TRANSFER_BINARY_DEST = 0x5, GUAC_TRANSFER_BINARY_NSRC = 0xC, GUAC_TRANSFER_BINARY_NDEST = 0xA, GUAC_TRANSFER_BINARY_AND = 0x1, GUAC_TRANSFER_BINARY_NAND = 0xE, GUAC_TRANSFER_BINARY_OR = 0x7, GUAC_TRANSFER_BINARY_NOR = 0x8, GUAC_TRANSFER_BINARY_XOR = 0x6, GUAC_TRANSFER_BINARY_XNOR = 0x9, GUAC_TRANSFER_BINARY_NSRC_AND = 0x4, GUAC_TRANSFER_BINARY_NSRC_NAND = 0xB, GUAC_TRANSFER_BINARY_NSRC_OR = 0xD, GUAC_TRANSFER_BINARY_NSRC_NOR = 0x2, GUAC_TRANSFER_BINARY_NDEST_AND = 0x2, GUAC_TRANSFER_BINARY_NDEST_NAND = 0xD, GUAC_TRANSFER_BINARY_NDEST_OR = 0xB, GUAC_TRANSFER_BINARY_NDEST_NOR = 0x4 } |
Default transfer functions. More... | |
enum | guac_line_cap_style { GUAC_LINE_CAP_BUTT = 0x0, GUAC_LINE_CAP_ROUND = 0x1, GUAC_LINE_CAP_SQUARE = 0x2 } |
Supported line cap styles. | |
enum | guac_line_join_style { GUAC_LINE_JOIN_BEVEL = 0x0, GUAC_LINE_JOIN_MITER = 0x1, GUAC_LINE_JOIN_ROUND = 0x2 } |
Supported line join styles. |
Functions | |
int | guac_protocol_send_ack (guac_socket *socket, guac_stream *stream, const char *error, guac_protocol_status status) |
Sends an ack instruction over the given guac_socket connection. | |
int | guac_protocol_send_args (guac_socket *socket, const char **args) |
Sends an args instruction over the given guac_socket connection. | |
int | guac_protocol_send_connect (guac_socket *socket, const char **args) |
Sends a connect instruction over the given guac_socket connection. | |
int | guac_protocol_send_disconnect (guac_socket *socket) |
Sends a disconnect instruction over the given guac_socket connection. | |
int | guac_protocol_send_error (guac_socket *socket, const char *error, guac_protocol_status status) |
Sends an error instruction over the given guac_socket connection. | |
int | guac_protocol_send_log (guac_socket *socket, const char *format,...) |
Sends a log instruction over the given guac_socket connection. | |
int | vguac_protocol_send_log (guac_socket *socket, const char *format, va_list args) |
Sends a log instruction over the given guac_socket connection. | |
int | guac_protocol_send_nest (guac_socket *socket, int index, const char *data) |
Sends a nest instruction over the given guac_socket connection. | |
int | guac_protocol_send_nop (guac_socket *socket) |
Sends a nop instruction (null-operation) over the given guac_socket connection. | |
int | guac_protocol_send_set (guac_socket *socket, const guac_layer *layer, const char *name, const char *value) |
Sends a set instruction over the given guac_socket connection. | |
int | guac_protocol_send_select (guac_socket *socket, const char *protocol) |
Sends a select instruction over the given guac_socket connection. | |
int | guac_protocol_send_sync (guac_socket *socket, guac_timestamp timestamp) |
Sends a sync instruction over the given guac_socket connection. | |
int | guac_protocol_send_audio (guac_socket *socket, const guac_stream *stream, int channel, const char *mimetype, double duration) |
Sends an audio instruction over the given guac_socket connection. | |
int | guac_protocol_send_file (guac_socket *socket, const guac_stream *stream, const char *mimetype, const char *name) |
Sends a file instruction over the given guac_socket connection. | |
int | guac_protocol_send_pipe (guac_socket *socket, const guac_stream *stream, const char *mimetype, const char *name) |
Sends a pipe instruction over the given guac_socket connection. | |
int | guac_protocol_send_blob (guac_socket *socket, const guac_stream *stream, void *data, int count) |
Writes a block of data to the currently in-progress blob which was already created. | |
int | guac_protocol_send_end (guac_socket *socket, const guac_stream *stream) |
Sends an end instruction over the given guac_socket connection. | |
int | guac_protocol_send_video (guac_socket *socket, const guac_stream *stream, const guac_layer *layer, const char *mimetype, double duration) |
Sends a video instruction over the given guac_socket connection. | |
int | guac_protocol_send_arc (guac_socket *socket, const guac_layer *layer, int x, int y, int radius, double startAngle, double endAngle, int negative) |
Sends an arc instruction over the given guac_socket connection. | |
int | guac_protocol_send_cfill (guac_socket *socket, guac_composite_mode mode, const guac_layer *layer, int r, int g, int b, int a) |
Sends a cfill instruction over the given guac_socket connection. | |
int | guac_protocol_send_clip (guac_socket *socket, const guac_layer *layer) |
Sends a clip instruction over the given guac_socket connection. | |
int | guac_protocol_send_close (guac_socket *socket, const guac_layer *layer) |
Sends a close instruction over the given guac_socket connection. | |
int | guac_protocol_send_copy (guac_socket *socket, const guac_layer *srcl, int srcx, int srcy, int w, int h, guac_composite_mode mode, const guac_layer *dstl, int dstx, int dsty) |
Sends a copy instruction over the given guac_socket connection. | |
int | guac_protocol_send_cstroke (guac_socket *socket, guac_composite_mode mode, const guac_layer *layer, guac_line_cap_style cap, guac_line_join_style join, int thickness, int r, int g, int b, int a) |
Sends a cstroke instruction over the given guac_socket connection. | |
int | guac_protocol_send_cursor (guac_socket *socket, int x, int y, const guac_layer *srcl, int srcx, int srcy, int w, int h) |
Sends a cursor instruction over the given guac_socket connection. | |
int | guac_protocol_send_curve (guac_socket *socket, const guac_layer *layer, int cp1x, int cp1y, int cp2x, int cp2y, int x, int y) |
Sends a curve instruction over the given guac_socket connection. | |
int | guac_protocol_send_identity (guac_socket *socket, const guac_layer *layer) |
Sends an identity instruction over the given guac_socket connection. | |
int | guac_protocol_send_lfill (guac_socket *socket, guac_composite_mode mode, const guac_layer *layer, const guac_layer *srcl) |
Sends an lfill instruction over the given guac_socket connection. | |
int | guac_protocol_send_line (guac_socket *socket, const guac_layer *layer, int x, int y) |
Sends a line instruction over the given guac_socket connection. | |
int | guac_protocol_send_lstroke (guac_socket *socket, guac_composite_mode mode, const guac_layer *layer, guac_line_cap_style cap, guac_line_join_style join, int thickness, const guac_layer *srcl) |
Sends an lstroke instruction over the given guac_socket connection. | |
int | guac_protocol_send_png (guac_socket *socket, guac_composite_mode mode, const guac_layer *layer, int x, int y, cairo_surface_t *surface) |
Sends a png instruction over the given guac_socket connection. | |
int | guac_protocol_send_pop (guac_socket *socket, const guac_layer *layer) |
Sends a pop instruction over the given guac_socket connection. | |
int | guac_protocol_send_push (guac_socket *socket, const guac_layer *layer) |
Sends a push instruction over the given guac_socket connection. | |
int | guac_protocol_send_rect (guac_socket *socket, const guac_layer *layer, int x, int y, int width, int height) |
Sends a rect instruction over the given guac_socket connection. | |
int | guac_protocol_send_reset (guac_socket *socket, const guac_layer *layer) |
Sends a reset instruction over the given guac_socket connection. | |
int | guac_protocol_send_start (guac_socket *socket, const guac_layer *layer, int x, int y) |
Sends a start instruction over the given guac_socket connection. | |
int | guac_protocol_send_transfer (guac_socket *socket, const guac_layer *srcl, int srcx, int srcy, int w, int h, guac_transfer_function fn, const guac_layer *dstl, int dstx, int dsty) |
Sends a transfer instruction over the given guac_socket connection. | |
int | guac_protocol_send_transform (guac_socket *socket, const guac_layer *layer, double a, double b, double c, double d, double e, double f) |
Sends a transform instruction over the given guac_socket connection. | |
int | guac_protocol_send_dispose (guac_socket *socket, const guac_layer *layer) |
Sends a dispose instruction over the given guac_socket connection. | |
int | guac_protocol_send_distort (guac_socket *socket, const guac_layer *layer, double a, double b, double c, double d, double e, double f) |
Sends a distort instruction over the given guac_socket connection. | |
int | guac_protocol_send_move (guac_socket *socket, const guac_layer *layer, const guac_layer *parent, int x, int y, int z) |
Sends a move instruction over the given guac_socket connection. | |
int | guac_protocol_send_shade (guac_socket *socket, const guac_layer *layer, int a) |
Sends a shade instruction over the given guac_socket connection. | |
int | guac_protocol_send_size (guac_socket *socket, const guac_layer *layer, int w, int h) |
Sends a size instruction over the given guac_socket connection. | |
int | guac_protocol_send_clipboard (guac_socket *socket, const char *data) |
Sends a clipboard instruction over the given guac_socket connection. | |
int | guac_protocol_send_name (guac_socket *socket, const char *name) |
Sends a name instruction over the given guac_socket connection. | |
int | guac_protocol_decode_base64 (char *base64) |
Decodes the given base64-encoded string in-place. |
Provides functions and structures required for communicating using the Guacamole protocol over a guac_socket connection, such as that provided by guac_client objects.
enum guac_composite_mode |
Composite modes used by Guacamole draw instructions.
Each composite mode maps to a unique channel mask integer.
enum guac_protocol_status |
Set of all possible status codes returned by protocol operations.
These codes relate to Guacamole server/client communication, and not to internal communication of errors within libguac and linked software.
In general:
0x0000 - 0x00FF: Successful operations. 0x0100 - 0x01FF: Operations that failed due to implementation status. 0x0200 - 0x02FF: Operations that failed due to environmental. 0x0300 - 0x03FF: Operations that failed due to user action.
There is a general correspondence of these status codes with HTTP response codes.
Default transfer functions.
There is no current facility in the Guacamole protocol to define custom transfer functions.
int guac_protocol_decode_base64 | ( | char * | base64 | ) |
Decodes the given base64-encoded string in-place.
The base64 string must be NULL-terminated.
base64 | The base64-encoded string to decode. |
int guac_protocol_send_ack | ( | guac_socket * | socket, |
guac_stream * | stream, | ||
const char * | error, | ||
guac_protocol_status | status | ||
) |
Sends an ack instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
stream | The guac_stream associated with the operation this ack is acknowledging. |
error | The human-readable description associated with the error or status update. |
status | The status code related to the error or status. |
int guac_protocol_send_arc | ( | guac_socket * | socket, |
const guac_layer * | layer, | ||
int | x, | ||
int | y, | ||
int | radius, | ||
double | startAngle, | ||
double | endAngle, | ||
int | negative | ||
) |
Sends an arc instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The destination layer. |
x | The X coordinate of the center of the circle containing the arc. |
y | The Y coordinate of the center of the circle containing the arc. |
radius | The radius of the circle containing the arc. |
startAngle | The starting angle, in radians. |
endAngle | The ending angle, in radians. |
negative | Zero if the arc should be drawn in order of increasing angle, non-zero otherwise. |
int guac_protocol_send_args | ( | guac_socket * | socket, |
const char ** | args | ||
) |
Sends an args instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
args | The NULL-terminated array of argument names (strings). |
int guac_protocol_send_audio | ( | guac_socket * | socket, |
const guac_stream * | stream, | ||
int | channel, | ||
const char * | mimetype, | ||
double | duration | ||
) |
Sends an audio instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
stream | The stream to use. |
channel | The index of the audio channel to use. |
mimetype | The mimetype of the data being sent. |
duration | The duration of the sound being sent, in milliseconds. |
int guac_protocol_send_blob | ( | guac_socket * | socket, |
const guac_stream * | stream, | ||
void * | data, | ||
int | count | ||
) |
Writes a block of data to the currently in-progress blob which was already created.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
stream | The stream to use. |
data | The file data to write. |
count | The number of bytes within the given buffer of file data that must be written. |
int guac_protocol_send_cfill | ( | guac_socket * | socket, |
guac_composite_mode | mode, | ||
const guac_layer * | layer, | ||
int | r, | ||
int | g, | ||
int | b, | ||
int | a | ||
) |
Sends a cfill instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
mode | The composite mode to use. |
layer | The destination layer. |
r | The red component of the color of the rectangle. |
g | The green component of the color of the rectangle. |
b | The blue component of the color of the rectangle. |
a | The alpha (transparency) component of the color of the rectangle. |
int guac_protocol_send_clip | ( | guac_socket * | socket, |
const guac_layer * | layer | ||
) |
Sends a clip instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The layer to set the clipping region of. |
int guac_protocol_send_clipboard | ( | guac_socket * | socket, |
const char * | data | ||
) |
Sends a clipboard instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
data | The clipboard data to send. |
int guac_protocol_send_close | ( | guac_socket * | socket, |
const guac_layer * | layer | ||
) |
Sends a close instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The destination layer. |
int guac_protocol_send_connect | ( | guac_socket * | socket, |
const char ** | args | ||
) |
Sends a connect instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
args | The NULL-terminated array of argument values (strings). |
int guac_protocol_send_copy | ( | guac_socket * | socket, |
const guac_layer * | srcl, | ||
int | srcx, | ||
int | srcy, | ||
int | w, | ||
int | h, | ||
guac_composite_mode | mode, | ||
const guac_layer * | dstl, | ||
int | dstx, | ||
int | dsty | ||
) |
Sends a copy instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
srcl | The source layer. |
srcx | The X coordinate of the source rectangle. |
srcy | The Y coordinate of the source rectangle. |
w | The width of the source rectangle. |
h | The height of the source rectangle. |
mode | The composite mode to use. |
dstl | The destination layer. |
dstx | The X coordinate of the destination, where the source rectangle should be copied. |
dsty | The Y coordinate of the destination, where the source rectangle should be copied. |
int guac_protocol_send_cstroke | ( | guac_socket * | socket, |
guac_composite_mode | mode, | ||
const guac_layer * | layer, | ||
guac_line_cap_style | cap, | ||
guac_line_join_style | join, | ||
int | thickness, | ||
int | r, | ||
int | g, | ||
int | b, | ||
int | a | ||
) |
Sends a cstroke instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
mode | The composite mode to use. |
layer | The destination layer. |
cap | The style of line cap to use when drawing the stroke. |
join | The style of line join to use when drawing the stroke. |
thickness | The thickness of the stroke in pixels. |
r | The red component of the color of the rectangle. |
g | The green component of the color of the rectangle. |
b | The blue component of the color of the rectangle. |
a | The alpha (transparency) component of the color of the rectangle. |
int guac_protocol_send_cursor | ( | guac_socket * | socket, |
int | x, | ||
int | y, | ||
const guac_layer * | srcl, | ||
int | srcx, | ||
int | srcy, | ||
int | w, | ||
int | h | ||
) |
Sends a cursor instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
x | The X coordinate of the cursor hotspot. |
y | The Y coordinate of the cursor hotspot. |
srcl | The source layer. |
srcx | The X coordinate of the source rectangle. |
srcy | The Y coordinate of the source rectangle. |
w | The width of the source rectangle. |
h | The height of the source rectangle. |
int guac_protocol_send_curve | ( | guac_socket * | socket, |
const guac_layer * | layer, | ||
int | cp1x, | ||
int | cp1y, | ||
int | cp2x, | ||
int | cp2y, | ||
int | x, | ||
int | y | ||
) |
Sends a curve instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The destination layer. |
cp1x | The X coordinate of the first control point. |
cp1y | The Y coordinate of the first control point. |
cp2x | The X coordinate of the second control point. |
cp2y | The Y coordinate of the second control point. |
x | The X coordinate of the endpoint of the curve. |
y | The Y coordinate of the endpoint of the curve. |
int guac_protocol_send_disconnect | ( | guac_socket * | socket | ) |
Sends a disconnect instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
int guac_protocol_send_dispose | ( | guac_socket * | socket, |
const guac_layer * | layer | ||
) |
Sends a dispose instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The layer to dispose. |
int guac_protocol_send_distort | ( | guac_socket * | socket, |
const guac_layer * | layer, | ||
double | a, | ||
double | b, | ||
double | c, | ||
double | d, | ||
double | e, | ||
double | f | ||
) |
Sends a distort instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The layer to distort with the given transform matrix. |
a | The first value of the affine transform matrix. |
b | The second value of the affine transform matrix. |
c | The third value of the affine transform matrix. |
d | The fourth value of the affine transform matrix. |
e | The fifth value of the affine transform matrix. |
f | The sixth value of the affine transform matrix. |
int guac_protocol_send_end | ( | guac_socket * | socket, |
const guac_stream * | stream | ||
) |
Sends an end instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
stream | The stream to use. |
int guac_protocol_send_error | ( | guac_socket * | socket, |
const char * | error, | ||
guac_protocol_status | status | ||
) |
Sends an error instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
error | The human-readable description associated with the error. |
status | The status code related to the error. |
int guac_protocol_send_file | ( | guac_socket * | socket, |
const guac_stream * | stream, | ||
const char * | mimetype, | ||
const char * | name | ||
) |
Sends a file instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
stream | The stream to use. |
mimetype | The mimetype of the data being sent. |
name | A name describing the file being sent. |
int guac_protocol_send_identity | ( | guac_socket * | socket, |
const guac_layer * | layer | ||
) |
Sends an identity instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The destination layer. |
int guac_protocol_send_lfill | ( | guac_socket * | socket, |
guac_composite_mode | mode, | ||
const guac_layer * | layer, | ||
const guac_layer * | srcl | ||
) |
Sends an lfill instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
mode | The composite mode to use. |
layer | The destination layer. |
srcl | The source layer. |
int guac_protocol_send_line | ( | guac_socket * | socket, |
const guac_layer * | layer, | ||
int | x, | ||
int | y | ||
) |
Sends a line instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The destination layer. |
x | The X coordinate of the endpoint of the line. |
y | The Y coordinate of the endpoint of the line. |
int guac_protocol_send_log | ( | guac_socket * | socket, |
const char * | format, | ||
... | |||
) |
Sends a log instruction over the given guac_socket connection.
This is mainly useful in debugging.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
format | A printf-style format string to log. |
... | Arguments to use when filling the format string for printing. |
int guac_protocol_send_lstroke | ( | guac_socket * | socket, |
guac_composite_mode | mode, | ||
const guac_layer * | layer, | ||
guac_line_cap_style | cap, | ||
guac_line_join_style | join, | ||
int | thickness, | ||
const guac_layer * | srcl | ||
) |
Sends an lstroke instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
mode | The composite mode to use. |
layer | The destination layer. |
cap | The style of line cap to use when drawing the stroke. |
join | The style of line join to use when drawing the stroke. |
thickness | The thickness of the stroke in pixels. |
srcl | The source layer. |
int guac_protocol_send_move | ( | guac_socket * | socket, |
const guac_layer * | layer, | ||
const guac_layer * | parent, | ||
int | x, | ||
int | y, | ||
int | z | ||
) |
Sends a move instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The layer to move. |
parent | The parent layer the specified layer will be positioned relative to. |
x | The X coordinate of the layer. |
y | The Y coordinate of the layer. |
z | The Z index of the layer, relative to other layers in its parent. |
int guac_protocol_send_name | ( | guac_socket * | socket, |
const char * | name | ||
) |
Sends a name instruction over the given guac_socket connection.
socket | The guac_socket connection to use. |
name | The name to send within the name instruction. |
int guac_protocol_send_nest | ( | guac_socket * | socket, |
int | index, | ||
const char * | data | ||
) |
Sends a nest instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
index | The integer index of the stram to send the protocol data over. |
data | A string containing protocol data, which must be UTF-8 encoded and null-terminated. |
int guac_protocol_send_nop | ( | guac_socket * | socket | ) |
Sends a nop instruction (null-operation) over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
int guac_protocol_send_pipe | ( | guac_socket * | socket, |
const guac_stream * | stream, | ||
const char * | mimetype, | ||
const char * | name | ||
) |
Sends a pipe instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
stream | The stream to use. |
mimetype | The mimetype of the data being sent. |
name | An arbitrary name uniquely identifying this pipe. |
int guac_protocol_send_png | ( | guac_socket * | socket, |
guac_composite_mode | mode, | ||
const guac_layer * | layer, | ||
int | x, | ||
int | y, | ||
cairo_surface_t * | surface | ||
) |
Sends a png instruction over the given guac_socket connection.
The PNG image data given will be automatically base64-encoded for transmission.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
mode | The composite mode to use. |
layer | The destination layer. |
x | The destination X coordinate. |
y | The destination Y coordinate. |
surface | A cairo surface containing the image data to send. |
int guac_protocol_send_pop | ( | guac_socket * | socket, |
const guac_layer * | layer | ||
) |
Sends a pop instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The layer to set the clipping region of. |
int guac_protocol_send_push | ( | guac_socket * | socket, |
const guac_layer * | layer | ||
) |
Sends a push instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The layer to set the clipping region of. |
int guac_protocol_send_rect | ( | guac_socket * | socket, |
const guac_layer * | layer, | ||
int | x, | ||
int | y, | ||
int | width, | ||
int | height | ||
) |
Sends a rect instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The destination layer. |
x | The X coordinate of the rectangle. |
y | The Y coordinate of the rectangle. |
width | The width of the rectangle. |
height | The height of the rectangle. |
int guac_protocol_send_reset | ( | guac_socket * | socket, |
const guac_layer * | layer | ||
) |
Sends a reset instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The layer to set the clipping region of. |
int guac_protocol_send_select | ( | guac_socket * | socket, |
const char * | protocol | ||
) |
Sends a select instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
protocol | The protocol to request. |
int guac_protocol_send_set | ( | guac_socket * | socket, |
const guac_layer * | layer, | ||
const char * | name, | ||
const char * | value | ||
) |
Sends a set instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The layer to set the parameter of. |
name | The name of the parameter to set. |
value | The value to set the parameter to. |
int guac_protocol_send_shade | ( | guac_socket * | socket, |
const guac_layer * | layer, | ||
int | a | ||
) |
Sends a shade instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The layer to shade. |
a | The alpha value of the layer. |
int guac_protocol_send_size | ( | guac_socket * | socket, |
const guac_layer * | layer, | ||
int | w, | ||
int | h | ||
) |
Sends a size instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The layer to resize. |
w | The new width of the layer. |
h | The new height of the layer. |
int guac_protocol_send_start | ( | guac_socket * | socket, |
const guac_layer * | layer, | ||
int | x, | ||
int | y | ||
) |
Sends a start instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The destination layer. |
x | The X coordinate of the first point of the subpath. |
y | The Y coordinate of the first point of the subpath. |
int guac_protocol_send_sync | ( | guac_socket * | socket, |
guac_timestamp | timestamp | ||
) |
Sends a sync instruction over the given guac_socket connection.
The current time in milliseconds should be passed in as the timestamp.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
timestamp | The current timestamp (in milliseconds). |
int guac_protocol_send_transfer | ( | guac_socket * | socket, |
const guac_layer * | srcl, | ||
int | srcx, | ||
int | srcy, | ||
int | w, | ||
int | h, | ||
guac_transfer_function | fn, | ||
const guac_layer * | dstl, | ||
int | dstx, | ||
int | dsty | ||
) |
Sends a transfer instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
srcl | The source layer. |
srcx | The X coordinate of the source rectangle. |
srcy | The Y coordinate of the source rectangle. |
w | The width of the source rectangle. |
h | The height of the source rectangle. |
fn | The transfer function to use. |
dstl | The destination layer. |
dstx | The X coordinate of the destination, where the source rectangle should be copied. |
dsty | The Y coordinate of the destination, where the source rectangle should be copied. |
int guac_protocol_send_transform | ( | guac_socket * | socket, |
const guac_layer * | layer, | ||
double | a, | ||
double | b, | ||
double | c, | ||
double | d, | ||
double | e, | ||
double | f | ||
) |
Sends a transform instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
layer | The layer to apply the given transform matrix to. |
a | The first value of the affine transform matrix. |
b | The second value of the affine transform matrix. |
c | The third value of the affine transform matrix. |
d | The fourth value of the affine transform matrix. |
e | The fifth value of the affine transform matrix. |
f | The sixth value of the affine transform matrix. |
int guac_protocol_send_video | ( | guac_socket * | socket, |
const guac_stream * | stream, | ||
const guac_layer * | layer, | ||
const char * | mimetype, | ||
double | duration | ||
) |
Sends a video instruction over the given guac_socket connection.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
stream | The stream to use. |
layer | The destination layer. |
mimetype | The mimetype of the data being sent. |
duration | The duration of the video being sent, in milliseconds. |
int vguac_protocol_send_log | ( | guac_socket * | socket, |
const char * | format, | ||
va_list | args | ||
) |
Sends a log instruction over the given guac_socket connection.
This is mainly useful in debugging.
If an error occurs sending the instruction, a non-zero value is returned, and guac_error is set appropriately.
socket | The guac_socket connection to use. |
format | A printf-style format string to log. |
ap | The va_list containing the arguments to be used when filling the format string for printing. |