generator: support listelement-ref
[free-sw/xcb/libxcb] / src / xcbext.h
1 /*
2  * Copyright (C) 2001-2004 Bart Massey and Jamey Sharp.
3  * All Rights Reserved.
4  *
5  * Permission is hereby granted, free of charge, to any person obtaining a
6  * copy of this software and associated documentation files (the "Software"),
7  * to deal in the Software without restriction, including without limitation
8  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9  * and/or sell copies of the Software, and to permit persons to whom the
10  * Software is furnished to do so, subject to the following conditions:
11  * 
12  * The above copyright notice and this permission notice shall be included in
13  * all copies or substantial portions of the Software.
14  * 
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18  * AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
19  * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
20  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
21  * 
22  * Except as contained in this notice, the names of the authors or their
23  * institutions shall not be used in advertising or otherwise to promote the
24  * sale, use or other dealings in this Software without prior written
25  * authorization from the authors.
26  */
27
28 #ifndef __XCBEXT_H
29 #define __XCBEXT_H
30
31 #include "xcb.h"
32
33 #ifdef __cplusplus
34 extern "C" {
35 #endif
36
37 /* xcb_ext.c */
38
39 struct xcb_extension_t {
40     const char *name;
41     int global_id;
42 };
43
44
45 /* xcb_out.c */
46
47 typedef struct {
48     size_t count;
49     xcb_extension_t *ext;
50     uint8_t opcode;
51     uint8_t isvoid;
52 } xcb_protocol_request_t;
53
54 enum xcb_send_request_flags_t {
55     XCB_REQUEST_CHECKED = 1 << 0,
56     XCB_REQUEST_RAW = 1 << 1,
57     XCB_REQUEST_DISCARD_REPLY = 1 << 2,
58     XCB_REQUEST_REPLY_FDS = 1 << 3
59 };
60
61 /**
62  * @brief Send a request to the server.
63  * @param c: The connection to the X server.
64  * @param flags: A combination of flags from the xcb_send_request_flags_t enumeration.
65  * @param vector: Data to send; must have two iovecs before start for internal use.
66  * @param request: Information about the request to be sent.
67  * @return The request's sequence number on success, 0 otherwise.
68  *
69  * This function sends a new request to the X server. The data of the request is
70  * given as an array of @c iovecs in the @p vector argument. The length of that
71  * array and the neccessary management information are given in the @p request
72  * argument.
73  *
74  * When this function returns, the request might or might not be sent already.
75  * Use xcb_flush() to make sure that it really was sent.
76  *
77  * Please note that this function is not the prefered way for sending requests.
78  * It's better to use the generated wrapper functions.
79  *
80  * Please note that xcb might use index -1 and -2 of the @p vector array internally,
81  * so they must be valid!
82  */
83 unsigned int xcb_send_request(xcb_connection_t *c, int flags, struct iovec *vector, const xcb_protocol_request_t *request);
84
85 /**
86  * @brief Send a file descriptor to the server in the next call to xcb_send_request.
87  * @param c: The connection to the X server.
88  * @param fd: The file descriptor to send.
89  *
90  * After this function returns, the file descriptor given is owned by xcb and
91  * will be closed eventually.
92  *
93  * FIXME: How the heck is this supposed to work in a thread-safe way? There is a
94  * race between two threads doing xcb_send_fd(); xcb_send_request(); at the same
95  * time.
96  */
97 void xcb_send_fd(xcb_connection_t *c, int fd);
98
99 /**
100  * @brief Take over the write side of the socket
101  * @param c: The connection to the X server.
102  * @param return_socket: Callback function that will be called when xcb wants
103  *                        to use the socket again.
104  * @param closure: Argument to the callback function.
105  * @param flags: A combination of flags from the xcb_send_request_flags_t enumeration.
106  * @param sent: Location to the sequence number of the last sequence request.
107  *              Must not be NULL.
108  * @return 1 on success, else 0.
109  *
110  * xcb_take_socket allows external code to ask XCB for permission to
111  * take over the write side of the socket and send raw data with
112  * xcb_writev. xcb_take_socket provides the sequence number of the last
113  * request XCB sent. The caller of xcb_take_socket must supply a
114  * callback which XCB can call when it wants the write side of the
115  * socket back to make a request. This callback synchronizes with the
116  * external socket owner and flushes any output queues if appropriate.
117  * If you are sending requests which won't cause a reply, please note the
118  * comment for xcb_writev which explains some sequence number wrap issues.
119  *
120  * All replies that are generated while the socket is owned externally have
121  * @p flags applied to them. For example, use XCB_REQUEST_CHECK if you don't
122  * want errors to go to xcb's normal error handling, but instead having to be
123  * picked up via xcb_wait_for_reply(), xcb_poll_for_reply() or
124  * xcb_request_check().
125  */
126 int xcb_take_socket(xcb_connection_t *c, void (*return_socket)(void *closure), void *closure, int flags, uint64_t *sent);
127
128 /**
129  * @brief Send raw data to the X server.
130  * @param c: The connection to the X server.
131  * @param vector: Array of data to be sent.
132  * @param count: Number of entries in @p vector.
133  * @param requests: Number of requests that are being sent.
134  * @return 1 on success, else 0.
135  *
136  * You must own the write-side of the socket (you've called
137  * xcb_take_socket, and haven't returned from return_socket yet) to call
138  * xcb_writev. Also, the iovec must have at least 1 byte of data in it.
139  * You have to make sure that xcb can detect sequence number wraps correctly.
140  * This means that the first request you send after xcb_take_socket must cause a
141  * reply (e.g. just insert a GetInputFocus request). After every (1 << 16) - 1
142  * requests without a reply, you have to insert a request which will cause a
143  * reply. You can again use GetInputFocus for this. You do not have to wait for
144  * any of the GetInputFocus replies, but can instead handle them via
145  * xcb_discard_reply().
146  */
147 int xcb_writev(xcb_connection_t *c, struct iovec *vector, int count, uint64_t requests);
148
149
150 /* xcb_in.c */
151
152 /**
153  * @brief Wait for the reply of a given request.
154  * @param c: The connection to the X server.
155  * @param request: Sequence number of the request as returned by xcb_send_request().
156  * @param e: Location to store errors in, or NULL. Ignored for unchecked requests.
157  *
158  * Returns the reply to the given request or returns null in the event of
159  * errors. Blocks until the reply or error for the request arrives, or an I/O
160  * error occurs.
161  */
162 void *xcb_wait_for_reply(xcb_connection_t *c, unsigned int request, xcb_generic_error_t **e);
163
164 /**
165  * @brief Poll for the reply of a given request.
166  * @param c: The connection to the X server.
167  * @param request: Sequence number of the request as returned by xcb_send_request().
168  * @param reply: Location to store the reply in, must not be NULL.
169  * @param e: Location to store errors in, or NULL. Ignored for unchecked requests.
170  * @return 1 when the reply to the request was returned, else 0.
171  *
172  * Checks if the reply to the given request already received. Does not block.
173  */
174 int xcb_poll_for_reply(xcb_connection_t *c, unsigned int request, void **reply, xcb_generic_error_t **error);
175
176 /**
177  * @brief Don't use this, only needed by the generated code.
178  * @param c: The connection to the X server.
179  * @param reply: A reply that was received from the server
180  * @param replylen: The size of the reply.
181  * @return Pointer to the location where received file descriptors are stored.
182  */
183 int *xcb_get_reply_fds(xcb_connection_t *c, void *reply, size_t replylen);
184
185
186 /* xcb_util.c */
187
188 /**
189  * @param mask: The mask to check
190  * @return The number of set bits in the mask
191  */
192 int xcb_popcount(uint32_t mask);
193
194 /**
195  * @param list: The base of an array
196  * @param len: The length of the array
197  * @return The sum of all entries in the array.
198  */
199 int xcb_sumof(uint8_t *list, int len);
200
201 #ifdef __cplusplus
202 }
203 #endif
204
205 #endif