| /* |
| * This file generated automatically from shm.xml by c_client.py. |
| * Edit at your peril. |
| */ |
| |
| /** |
| * @defgroup XCB_Shm_API XCB Shm API |
| * @brief Shm XCB Protocol Implementation. |
| * @{ |
| **/ |
| |
| #ifndef __SHM_H |
| #define __SHM_H |
| |
| #include "xcb.h" |
| #include "xproto.h" |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| #define XCB_SHM_MAJOR_VERSION 1 |
| #define XCB_SHM_MINOR_VERSION 2 |
| |
| extern xcb_extension_t xcb_shm_id; |
| |
| typedef uint32_t xcb_shm_seg_t; |
| |
| /** |
| * @brief xcb_shm_seg_iterator_t |
| **/ |
| typedef struct xcb_shm_seg_iterator_t { |
| xcb_shm_seg_t *data; |
| int rem; |
| int index; |
| } xcb_shm_seg_iterator_t; |
| |
| /** Opcode for xcb_shm_completion. */ |
| #define XCB_SHM_COMPLETION 0 |
| |
| /** |
| * @brief xcb_shm_completion_event_t |
| **/ |
| typedef struct xcb_shm_completion_event_t { |
| uint8_t response_type; |
| uint8_t pad0; |
| uint16_t sequence; |
| xcb_drawable_t drawable; |
| uint16_t minor_event; |
| uint8_t major_event; |
| uint8_t pad1; |
| xcb_shm_seg_t shmseg; |
| uint32_t offset; |
| } xcb_shm_completion_event_t; |
| |
| /** Opcode for xcb_shm_bad_seg. */ |
| #define XCB_SHM_BAD_SEG 0 |
| |
| typedef xcb_value_error_t xcb_shm_bad_seg_error_t; |
| |
| /** |
| * @brief xcb_shm_query_version_cookie_t |
| **/ |
| typedef struct xcb_shm_query_version_cookie_t { |
| unsigned int sequence; |
| } xcb_shm_query_version_cookie_t; |
| |
| /** Opcode for xcb_shm_query_version. */ |
| #define XCB_SHM_QUERY_VERSION 0 |
| |
| /** |
| * @brief xcb_shm_query_version_request_t |
| **/ |
| typedef struct xcb_shm_query_version_request_t { |
| uint8_t major_opcode; |
| uint8_t minor_opcode; |
| uint16_t length; |
| } xcb_shm_query_version_request_t; |
| |
| /** |
| * @brief xcb_shm_query_version_reply_t |
| **/ |
| typedef struct xcb_shm_query_version_reply_t { |
| uint8_t response_type; |
| uint8_t shared_pixmaps; |
| uint16_t sequence; |
| uint32_t length; |
| uint16_t major_version; |
| uint16_t minor_version; |
| uint16_t uid; |
| uint16_t gid; |
| uint8_t pixmap_format; |
| uint8_t pad0[15]; |
| } xcb_shm_query_version_reply_t; |
| |
| /** Opcode for xcb_shm_attach. */ |
| #define XCB_SHM_ATTACH 1 |
| |
| /** |
| * @brief xcb_shm_attach_request_t |
| **/ |
| typedef struct xcb_shm_attach_request_t { |
| uint8_t major_opcode; |
| uint8_t minor_opcode; |
| uint16_t length; |
| xcb_shm_seg_t shmseg; |
| uint32_t shmid; |
| uint8_t read_only; |
| uint8_t pad0[3]; |
| } xcb_shm_attach_request_t; |
| |
| /** Opcode for xcb_shm_detach. */ |
| #define XCB_SHM_DETACH 2 |
| |
| /** |
| * @brief xcb_shm_detach_request_t |
| **/ |
| typedef struct xcb_shm_detach_request_t { |
| uint8_t major_opcode; |
| uint8_t minor_opcode; |
| uint16_t length; |
| xcb_shm_seg_t shmseg; |
| } xcb_shm_detach_request_t; |
| |
| /** Opcode for xcb_shm_put_image. */ |
| #define XCB_SHM_PUT_IMAGE 3 |
| |
| /** |
| * @brief xcb_shm_put_image_request_t |
| **/ |
| typedef struct xcb_shm_put_image_request_t { |
| uint8_t major_opcode; |
| uint8_t minor_opcode; |
| uint16_t length; |
| xcb_drawable_t drawable; |
| xcb_gcontext_t gc; |
| uint16_t total_width; |
| uint16_t total_height; |
| uint16_t src_x; |
| uint16_t src_y; |
| uint16_t src_width; |
| uint16_t src_height; |
| int16_t dst_x; |
| int16_t dst_y; |
| uint8_t depth; |
| uint8_t format; |
| uint8_t send_event; |
| uint8_t pad0; |
| xcb_shm_seg_t shmseg; |
| uint32_t offset; |
| } xcb_shm_put_image_request_t; |
| |
| /** |
| * @brief xcb_shm_get_image_cookie_t |
| **/ |
| typedef struct xcb_shm_get_image_cookie_t { |
| unsigned int sequence; |
| } xcb_shm_get_image_cookie_t; |
| |
| /** Opcode for xcb_shm_get_image. */ |
| #define XCB_SHM_GET_IMAGE 4 |
| |
| /** |
| * @brief xcb_shm_get_image_request_t |
| **/ |
| typedef struct xcb_shm_get_image_request_t { |
| uint8_t major_opcode; |
| uint8_t minor_opcode; |
| uint16_t length; |
| xcb_drawable_t drawable; |
| int16_t x; |
| int16_t y; |
| uint16_t width; |
| uint16_t height; |
| uint32_t plane_mask; |
| uint8_t format; |
| uint8_t pad0[3]; |
| xcb_shm_seg_t shmseg; |
| uint32_t offset; |
| } xcb_shm_get_image_request_t; |
| |
| /** |
| * @brief xcb_shm_get_image_reply_t |
| **/ |
| typedef struct xcb_shm_get_image_reply_t { |
| uint8_t response_type; |
| uint8_t depth; |
| uint16_t sequence; |
| uint32_t length; |
| xcb_visualid_t visual; |
| uint32_t size; |
| } xcb_shm_get_image_reply_t; |
| |
| /** Opcode for xcb_shm_create_pixmap. */ |
| #define XCB_SHM_CREATE_PIXMAP 5 |
| |
| /** |
| * @brief xcb_shm_create_pixmap_request_t |
| **/ |
| typedef struct xcb_shm_create_pixmap_request_t { |
| uint8_t major_opcode; |
| uint8_t minor_opcode; |
| uint16_t length; |
| xcb_pixmap_t pid; |
| xcb_drawable_t drawable; |
| uint16_t width; |
| uint16_t height; |
| uint8_t depth; |
| uint8_t pad0[3]; |
| xcb_shm_seg_t shmseg; |
| uint32_t offset; |
| } xcb_shm_create_pixmap_request_t; |
| |
| /** Opcode for xcb_shm_attach_fd. */ |
| #define XCB_SHM_ATTACH_FD 6 |
| |
| /** |
| * @brief xcb_shm_attach_fd_request_t |
| **/ |
| typedef struct xcb_shm_attach_fd_request_t { |
| uint8_t major_opcode; |
| uint8_t minor_opcode; |
| uint16_t length; |
| xcb_shm_seg_t shmseg; |
| uint8_t read_only; |
| uint8_t pad0[3]; |
| } xcb_shm_attach_fd_request_t; |
| |
| /** |
| * @brief xcb_shm_create_segment_cookie_t |
| **/ |
| typedef struct xcb_shm_create_segment_cookie_t { |
| unsigned int sequence; |
| } xcb_shm_create_segment_cookie_t; |
| |
| /** Opcode for xcb_shm_create_segment. */ |
| #define XCB_SHM_CREATE_SEGMENT 7 |
| |
| /** |
| * @brief xcb_shm_create_segment_request_t |
| **/ |
| typedef struct xcb_shm_create_segment_request_t { |
| uint8_t major_opcode; |
| uint8_t minor_opcode; |
| uint16_t length; |
| xcb_shm_seg_t shmseg; |
| uint32_t size; |
| uint8_t read_only; |
| uint8_t pad0[3]; |
| } xcb_shm_create_segment_request_t; |
| |
| /** |
| * @brief xcb_shm_create_segment_reply_t |
| **/ |
| typedef struct xcb_shm_create_segment_reply_t { |
| uint8_t response_type; |
| uint8_t nfd; |
| uint16_t sequence; |
| uint32_t length; |
| uint8_t pad0[24]; |
| } xcb_shm_create_segment_reply_t; |
| |
| /** |
| * Get the next element of the iterator |
| * @param i Pointer to a xcb_shm_seg_iterator_t |
| * |
| * Get the next element in the iterator. The member rem is |
| * decreased by one. The member data points to the next |
| * element. The member index is increased by sizeof(xcb_shm_seg_t) |
| */ |
| void |
| xcb_shm_seg_next (xcb_shm_seg_iterator_t *i); |
| |
| /** |
| * Return the iterator pointing to the last element |
| * @param i An xcb_shm_seg_iterator_t |
| * @return The iterator pointing to the last element |
| * |
| * Set the current element in the iterator to the last element. |
| * The member rem is set to 0. The member data points to the |
| * last element. |
| */ |
| xcb_generic_iterator_t |
| xcb_shm_seg_end (xcb_shm_seg_iterator_t i); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| */ |
| xcb_shm_query_version_cookie_t |
| xcb_shm_query_version (xcb_connection_t *c); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| * This form can be used only if the request will cause |
| * a reply to be generated. Any returned error will be |
| * placed in the event queue. |
| */ |
| xcb_shm_query_version_cookie_t |
| xcb_shm_query_version_unchecked (xcb_connection_t *c); |
| |
| /** |
| * Return the reply |
| * @param c The connection |
| * @param cookie The cookie |
| * @param e The xcb_generic_error_t supplied |
| * |
| * Returns the reply of the request asked by |
| * |
| * The parameter @p e supplied to this function must be NULL if |
| * xcb_shm_query_version_unchecked(). is used. |
| * Otherwise, it stores the error if any. |
| * |
| * The returned value must be freed by the caller using free(). |
| */ |
| xcb_shm_query_version_reply_t * |
| xcb_shm_query_version_reply (xcb_connection_t *c, |
| xcb_shm_query_version_cookie_t cookie /**< */, |
| xcb_generic_error_t **e); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| * This form can be used only if the request will not cause |
| * a reply to be generated. Any returned error will be |
| * saved for handling by xcb_request_check(). |
| */ |
| xcb_void_cookie_t |
| xcb_shm_attach_checked (xcb_connection_t *c, |
| xcb_shm_seg_t shmseg, |
| uint32_t shmid, |
| uint8_t read_only); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| */ |
| xcb_void_cookie_t |
| xcb_shm_attach (xcb_connection_t *c, |
| xcb_shm_seg_t shmseg, |
| uint32_t shmid, |
| uint8_t read_only); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| * This form can be used only if the request will not cause |
| * a reply to be generated. Any returned error will be |
| * saved for handling by xcb_request_check(). |
| */ |
| xcb_void_cookie_t |
| xcb_shm_detach_checked (xcb_connection_t *c, |
| xcb_shm_seg_t shmseg); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| */ |
| xcb_void_cookie_t |
| xcb_shm_detach (xcb_connection_t *c, |
| xcb_shm_seg_t shmseg); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| * This form can be used only if the request will not cause |
| * a reply to be generated. Any returned error will be |
| * saved for handling by xcb_request_check(). |
| */ |
| xcb_void_cookie_t |
| xcb_shm_put_image_checked (xcb_connection_t *c, |
| xcb_drawable_t drawable, |
| xcb_gcontext_t gc, |
| uint16_t total_width, |
| uint16_t total_height, |
| uint16_t src_x, |
| uint16_t src_y, |
| uint16_t src_width, |
| uint16_t src_height, |
| int16_t dst_x, |
| int16_t dst_y, |
| uint8_t depth, |
| uint8_t format, |
| uint8_t send_event, |
| xcb_shm_seg_t shmseg, |
| uint32_t offset); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| */ |
| xcb_void_cookie_t |
| xcb_shm_put_image (xcb_connection_t *c, |
| xcb_drawable_t drawable, |
| xcb_gcontext_t gc, |
| uint16_t total_width, |
| uint16_t total_height, |
| uint16_t src_x, |
| uint16_t src_y, |
| uint16_t src_width, |
| uint16_t src_height, |
| int16_t dst_x, |
| int16_t dst_y, |
| uint8_t depth, |
| uint8_t format, |
| uint8_t send_event, |
| xcb_shm_seg_t shmseg, |
| uint32_t offset); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| */ |
| xcb_shm_get_image_cookie_t |
| xcb_shm_get_image (xcb_connection_t *c, |
| xcb_drawable_t drawable, |
| int16_t x, |
| int16_t y, |
| uint16_t width, |
| uint16_t height, |
| uint32_t plane_mask, |
| uint8_t format, |
| xcb_shm_seg_t shmseg, |
| uint32_t offset); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| * This form can be used only if the request will cause |
| * a reply to be generated. Any returned error will be |
| * placed in the event queue. |
| */ |
| xcb_shm_get_image_cookie_t |
| xcb_shm_get_image_unchecked (xcb_connection_t *c, |
| xcb_drawable_t drawable, |
| int16_t x, |
| int16_t y, |
| uint16_t width, |
| uint16_t height, |
| uint32_t plane_mask, |
| uint8_t format, |
| xcb_shm_seg_t shmseg, |
| uint32_t offset); |
| |
| /** |
| * Return the reply |
| * @param c The connection |
| * @param cookie The cookie |
| * @param e The xcb_generic_error_t supplied |
| * |
| * Returns the reply of the request asked by |
| * |
| * The parameter @p e supplied to this function must be NULL if |
| * xcb_shm_get_image_unchecked(). is used. |
| * Otherwise, it stores the error if any. |
| * |
| * The returned value must be freed by the caller using free(). |
| */ |
| xcb_shm_get_image_reply_t * |
| xcb_shm_get_image_reply (xcb_connection_t *c, |
| xcb_shm_get_image_cookie_t cookie /**< */, |
| xcb_generic_error_t **e); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| * This form can be used only if the request will not cause |
| * a reply to be generated. Any returned error will be |
| * saved for handling by xcb_request_check(). |
| */ |
| xcb_void_cookie_t |
| xcb_shm_create_pixmap_checked (xcb_connection_t *c, |
| xcb_pixmap_t pid, |
| xcb_drawable_t drawable, |
| uint16_t width, |
| uint16_t height, |
| uint8_t depth, |
| xcb_shm_seg_t shmseg, |
| uint32_t offset); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| */ |
| xcb_void_cookie_t |
| xcb_shm_create_pixmap (xcb_connection_t *c, |
| xcb_pixmap_t pid, |
| xcb_drawable_t drawable, |
| uint16_t width, |
| uint16_t height, |
| uint8_t depth, |
| xcb_shm_seg_t shmseg, |
| uint32_t offset); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| * This form can be used only if the request will not cause |
| * a reply to be generated. Any returned error will be |
| * saved for handling by xcb_request_check(). |
| */ |
| xcb_void_cookie_t |
| xcb_shm_attach_fd_checked (xcb_connection_t *c, |
| xcb_shm_seg_t shmseg, |
| int32_t shm_fd, |
| uint8_t read_only); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| */ |
| xcb_void_cookie_t |
| xcb_shm_attach_fd (xcb_connection_t *c, |
| xcb_shm_seg_t shmseg, |
| int32_t shm_fd, |
| uint8_t read_only); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| */ |
| xcb_shm_create_segment_cookie_t |
| xcb_shm_create_segment (xcb_connection_t *c, |
| xcb_shm_seg_t shmseg, |
| uint32_t size, |
| uint8_t read_only); |
| |
| /** |
| * |
| * @param c The connection |
| * @return A cookie |
| * |
| * Delivers a request to the X server. |
| * |
| * This form can be used only if the request will cause |
| * a reply to be generated. Any returned error will be |
| * placed in the event queue. |
| */ |
| xcb_shm_create_segment_cookie_t |
| xcb_shm_create_segment_unchecked (xcb_connection_t *c, |
| xcb_shm_seg_t shmseg, |
| uint32_t size, |
| uint8_t read_only); |
| |
| /** |
| * Return the reply |
| * @param c The connection |
| * @param cookie The cookie |
| * @param e The xcb_generic_error_t supplied |
| * |
| * Returns the reply of the request asked by |
| * |
| * The parameter @p e supplied to this function must be NULL if |
| * xcb_shm_create_segment_unchecked(). is used. |
| * Otherwise, it stores the error if any. |
| * |
| * The returned value must be freed by the caller using free(). |
| */ |
| xcb_shm_create_segment_reply_t * |
| xcb_shm_create_segment_reply (xcb_connection_t *c, |
| xcb_shm_create_segment_cookie_t cookie /**< */, |
| xcb_generic_error_t **e); |
| |
| /** |
| * Return the reply fds |
| * @param c The connection |
| * @param reply The reply |
| * |
| * Returns a pointer to the array of reply fds of the reply. |
| * |
| * The returned value points into the reply and must not be free(). |
| * The fds are not managed by xcb. You must close() them before freeing the reply. |
| */ |
| int * |
| xcb_shm_create_segment_reply_fds (xcb_connection_t *c /**< */, |
| xcb_shm_create_segment_reply_t *reply); |
| |
| |
| #ifdef __cplusplus |
| } |
| #endif |
| |
| #endif |
| |
| /** |
| * @} |
| */ |