Disable Xevie and Xprint by default
[free-sw/xcb/libxcb] / NEWS
1 Release 1.11 (2014-08-01)
2 =========================
3 * Force structures with 64-bit fields to be packed
4 * Add support for <pad align="n">
5 * Use X.org's build machinery from xorg-macros
6 * Fix leak with xcb_disconnect() and connections in an error state
7 * Make xcb_disconnect(NULL) safe
8 * Use less #include statements in generated code
9 * Automatically validate the Requires lines in our .pc.in files
10 * Fix a race that resulted in a failed assertion
11 * Improve launchd secure socket support
12 * Improve API documentation
13 * Remove trailing whitespaces
14 * c_client.py: prefix all monkey-patched fields with c_
15 * c_client.py: make the man page output deterministic
16 * c_client.py: remove useless generated comments
17 * xcb.h: add 'struct' before xcb_setup_t, xcb_query_extension_reply_t
18
19 Release 1.10 (2013-12-22)
20 =========================
21 * Bump libxcb-xkb SONAME due to ABI break introduced in 1.9.2
22 * Enable libxcb-xkb by default
23 * Bump libxcb-sync SONAME
24 * c_client.py: Fix _sizeof() functions
25 * c_client.py: Do not create pointers in unions
26 * c_client.py: Always initialize xcb_align_to
27 * Re-introduce xcb_ge_event_t (deprecated, xcb_ge_generic_event_t should be
28   used instead)
29 * Fix alignment issues in FD passing code
30 * Fix poll() if POLLIN == ROLLRDNORM|POLLRDBAND
31 * Use /usr/spool/sockets/X11/ on HP-UX for UNIX sockets
32 * Make xsltproc optional
33
34 Release 1.9.3 (2013-11-07)
35 ==========================
36 * Check if we need to define _XOPEN_SOURCE for struct msghdr.msg_control
37 * Add configure option to enable or disable fd passing with sendmsg
38 * Switch to using the CMSG_* macros for FD passing
39 * Initialize automake earlier (bugfix for #66413)
40
41 Release 1.9.2 (2013-11-07)
42 ==========================
43 * Add Present extension
44 * Add DRI3 library
45 * Add event queue splitting
46 * Add support for receiving fds in replies
47 * Add xcb_send_fd API
48 * Remove xcb_ge_event_t from xcb.h
49 * c_client.py: Inject full_sequence into GE events
50 * c_client.py: Handle multiple expr. in a bitcase
51
52 Release 1.9.1 (2013-05-30)
53 ==========================
54 * Fix python code to work with python-3
55 * Security fix for integer overflow in read_packet() [CVE-2013-2064]
56
57 Release 1.9 (2012-10-05)
58 ========================
59 * Always include "config.h" at the start of all C source files.
60 * Add AC_USE_SYSTEM_EXTENSIONS to allow use of more system functionality
61 * Return connection failure if display string specifies non-existent screen
62 * c_client: Fix parallel-make issue creating 'man' directory
63 * xcb_connect: launchd: Don't fall back on tcp if $DISPLAY is a path to a launchd socket
64 * c_client.py: generate manpages
65 * Allow xcb_send_request with >MAX_IOV iovecs
66 * Add a .gitignore for src/man/
67 * Fix a multi-thread deadlock
68
69 Release 1.8.1 (2012-03-09)
70 ==========================
71 - Fix a busy loop on BSD and Mac OS
72 - Bump xcb-proto requirement
73 - Fallback to TCP if no protocol is specified and the UNIX connection fails
74 - Update use of error_connection under WIN32 to _xcb_conn_ret_error()
75 - Fix build of xcb_auth.c with XDMCP on WIN32
76 - Revert "Fix include order with Xdmcp on WIN32"
77 - darwin: Use read(2) rather than recv(2)
78 - Add xkb_internals and xkb_issues to EXTRA_DIST.
79
80 Release 1.8 (2012-01-11)
81 ========================
82 - xcb_disconnect: call shutdown() to force a disconnect
83 - Use special path to sockets when running under Solaris Trusted Extensions
84 - Remove unused DECnet code
85 - Add #include <sys/socket.h> to xcb_conn.c
86 - Make launchd code in xcb_util.c match surrounding code indent levels
87 - If protocol is "unix", use a Unix domain socket, not TCP
88 - Added more error states and removed global error_connection
89 - Handle XGE events with the "send event" flag
90 - added xcb_sumof() with restriction to uint8_t
91 - xkb: updated configure.ac/Makefile.am
92 - xkb: added pkg config file
93 - special case 'intermixed variable and fixed size fields': fixed reply side, needs testing
94 - added accessors for special cases
95 - Add support for building with Python 3
96 - Insert, not append explicit xcbgen dir python path
97 - xcb_request_check: Sync even if an event was read for this sequence.
98 - _xcb_conn_wait: Shut down the connection on unexpected poll() events.
99 - xcb_send_request: Send all requests using a common internal send_request.
100 - xcb_request_check: Hold the I/O lock while deciding to sync.
101 - xcb_discard_reply: Simplify by re-using poll_for_reply helper.
102 - xcb_in: Use 64-bit sequence numbers internally everywhere.
103 - Enable AM_SILENT_RULES on automake 1.11 or newer.
104 - Factor reader_list management out of wait_for_reply.
105 - Dequeue readers that can't receive any new responses.
106 - Delete the old c-client.xsl.
107 - Keep ALIGNOF definition out of the public namespace.
108 - darwin: Don't use poll() when expected to run on darwin10 and prior
109 - Add Win32
110 - Allow disconnecting connections that are in error state.
111 - Make xcb_take_socket keep flushing until idle
112 - Support pre-IPv6 systems (without getaddrinfo)
113 - Drop AI_ADDRCONFIG when resolving TCP addresses
114 - xcb_auth: Fix memory leak in _xcb_get_auth_info.
115 - Don't emit out-of-module sizeof definitions
116 - Clean up a couple of warnings in xprint
117 - Prevent reply waiters from being blocked.
118 - Prevent theoretical double free and leak on get_peer_sock_name.
119 - Introduce a variant of xcb_poll_for_event for examining event queue.
120 - xcb_take_socket: Document sequence wrap requirements
121 - Compute alignment correctly
122 - Fix a dead-lock due to xcb_poll_for_reply
123
124 Release 1.7 (2010-08-13)
125 ========================
126 - Always wake up readers after writing
127 - Get rid of PATH_MAX and MAXPATHLEN
128 - Add ~ operator support in code generator
129 - xcb_open: Improve protocol/host parsing
130 - xcb_connect_to_display_with_auth_info: Fix memory leak
131 - Report which extensions are being built
132
133 Release 1.6 (2010-04-09)
134 ========================
135 - darwin: xnu doesn't support poll on ttys on the master side
136 - Fix descriptor leak on memory error path
137 - Support xcb_discard_reply
138 - Open the X11 socket with close-on-exec flag
139 - Fix authentication on hpux and Hurd
140
141 Release 1.5 (2009-12-03)
142 ========================
143 - setsockopt(SO_KEEPALIVE) on TCP display connections
144 - Add DRI2 support
145 - Fix check dependency
146 - Cygwin build fix: Add -no-undefined to libtool flags
147
148 Release 1.4 (2009-07-15)
149 ========================
150 * Add majorCode, minorCode and resourceID fields to X generic error
151 * Fix precedence bug: wrong length for big-requests preceded by sync
152 * Fix libxcb-randr version info
153
154 Release 1.3 (2009-05-29)
155 ========================
156 * Copy full IPv4 mapping (Bug #20665)
157 * Fix XID allocation
158 * Use poll() instead of select() when available
159 * Fix local socket connection on Hurd
160 * Fix XDM-AUTHORIZATION-1
161 * Disable Nagle on TCP socket
162
163 Release 1.2 (2009-02-17)
164 ========================
165 * Stop packaging auto-generated C files into tarball.
166
167 Release 1.1.93 (2008-12-11)
168 ===========================
169 Enhancements:
170 * Apple: Enable support for launchd DISPLAY socket
171 * Treat XIDs the same as other cardinal values.
172
173 Release 1.1.92 (2008-11-01)
174 ===========================
175 Enhancements:
176 * Added small fix to support trailing fixed fields; also warning for non-pad fixed fields
177 * Fixed overly aggressive warning about fixed field following variable
178 * Added generation of extern "C" for compatibility with C++
179 * Remove libxcb-xlib and xcbxlib.h.
180 * Inline _xcb_lock_io, _xcb_unlock_io, and _xcb_wait_io.
181 * Track 64-bit sequence numbers internally.
182 * Use sequence number ranges in pending replies
183 * Remove duplicate XCB_EXTENSION calls for Composite extension
184 * Factorize m4 macros and add one to set X extensions
185 * Allow compile-time setting for XCB queue buffer size
186 * Support handing off socket write permission to external code.
187 * Add support for the abstract socket namespace under Linux
188
189 Bug fixes:
190 * Fix tiny memory leak in read_packet
191 * Fix some fd leaks in _xcb_open_*()
192
193 Release 1.1 (2007-11-04)
194 ========================
195
196 This release requires xcb-proto 1.1, due to the addition of the
197 extension-multiword attribute to the XML schema.
198
199 This release contains several important bug fixes, summarized below. It
200 also contains a patch much like Novell's libxcb-sloppy-lock.diff.
201 Rationale from the commit message follows. The patch and this rationale
202 were authored by Jamey Sharp <jamey@minilop.net>, with agreement from
203 Josh Triplett <josh@freedesktop.org>.
204
205     I strongly opposed proposals like this one for a long time.
206     Originally I had a very good reason: libX11, when compiled to use
207     XCB, would crash soon after a locking correctness violation, so it
208     was better to have an informative assert failure than a mystifying
209     crash soon after.
210
211     It took some time for me to realize that I'd changed the libX11
212     implementation (for unrelated reasons) so that it could survive most
213     invalid locking situations, as long as it wasn't actually being used
214     from multiple threads concurrently.
215
216     The other thing that has changed is that most of the code with
217     incorrect locking has now been fixed. The value of the assert is
218     accordingly lower.
219
220     However, remaining broken callers do need to be fixed. That's why
221     libXCB will still noisily print a stacktrace (if possible) on each
222     assertion failure, even when assert isn't actually invoked to
223     abort() the program; and that's why aborting is still default. This
224     environment variable is provided only for use as a temporary
225     workaround for broken applications.
226
227 Enhancements:
228 * Print a backtrace, if possible, on locking assertion failures.
229 * Skip abort() on locking assertions if LIBXCB_ALLOW_SLOPPY_LOCK is set.
230 * xcb_poll_for_event: Return already-read events before reading again.
231 * Output a configuration summary at the end of ./configure.
232
233 Bug fixes:
234 * Don't hold the xlib-xcb lock while sleeping: that allows deadlock.
235 * Allow unix:<screen> style display names again.
236 * Bug #9119: test xcb_popcount
237 * Fix unit tests for FreeBSD
238 * NetBSD doesn't have AI_ADDRCONFIG: use it only if it's available.
239 * Require libXau >= 0.99.2; earlier versions have a broken .pc file
240 * Use substitition variables in xcb-xinerama.pc.in
241 * Update autogen.sh to one that does objdir != srcdir
242 * Add tools/* and autogen.sh to EXTRA_DIST.
243 * Doxygen can now be fully disabled if desired.
244
245 Documentation improvements:
246 * Many fixes and updates to the tutorial.
247 * Iterators, requests, and replies get partial Doxygen documentation.
248
249
250 Release 1.0 (2006-11-23)
251 ========================
252
253 The "Thanksgiving" release: We feel thankful to have it released.  Five years
254 have passed since XCB's initial commit on September 3rd, 2001:
255     <http://gitweb.freedesktop.org/?p=xcb.git;a=commit;h=09e54c4a3c>
256
257 * Support IPv6.  XCB now supports displays with IPv6 addresses, with or without
258   enclosing square brackets, or with hosts which resolve to IPv6 addresses, by
259   using getaddrinfo instead of gethostbyname, and by including support for
260   authentication for such connections.  This allows such displays as "::1:1.1".
261
262 * XCB now uses the libpthread-stubs, to properly support optional use of
263   pthreads even on platforms which do not have all the necessary pthread stubs
264   in libc or otherwise available by default.
265
266 * Switch from the old AM_PATH_CHECK macro to pkg-config.  check 0.9.4 is now
267   required to build XCB's unit tests.  The version that we were requiring was
268   not actually new enough to let our unit tests compile, and the AM_PATH_CHECK
269   macro is now considered deprecated.  We know that versions of check using
270   pkg-config are new enough to work, and the check dependency was optional
271   anyway, so we've dropped support for older versions.
272
273 * Provide a xcb_prefetch_maximum_request_length counterpart to
274   xcb_get_maximum_request_length.
275
276 * Fix Bug #5958: zero out padding bytes in requests.
277
278 * Change xcb_connect to pass the display number to _xcb_get_auth_info, which
279   passes it to get_authptr.  This allows get_authptr to stop hacking the
280   display number out of the sockaddrs of various address families, such as
281   port - X_TCP_PORT, or the number after the last X in the UNIX socket path.
282
283 * Remove --with-opt and --with-debug options from configure.ac; configure
284   supports the use of custom CFLAGS, so please use that instead.
285
286 * Reove support for the <localfield> tag in protocol descriptions, since they
287   no longer use it, and since new protocol descriptions should not need it
288   either.
289
290 * xcb-proto has no libraries or headers, so don't use XCBPROTO_CFLAGS or
291   XCBPROTO_LIBS.
292
293 * XCB builds which use xdmcp now include it in Requires.private, to support
294   static linking.
295
296 * Replace "long" with uint32_t when used for a 32-bit quantity
297
298 * Various enhancements to the generation of documentation with Doxygen:
299   * Check for doxygen in configure.ac
300   * Fix some Doxygen warnings.
301   * Install documentation.
302   * Handle out-of-tree builds, with srcdir != builddir.  xcb.doxygen now gets
303     generated from xcb.doxygen.in, so that it can use top_builddir and
304     top_srcdir to find source and to output documentation.
305   * Fill in PROJECT_NUMBER from @VERSION@, now that we have it readily
306     available via autoconf.
307
308
309 Release 1.0 RC3 (2006-11-02)
310 ============================
311
312 Note: Version 0.9.4 of the test suite tool "check" provides a broken
313 version of the AM_PATH_CHECK macro, which causes autoconf to fail due to
314 insufficient quoting on the macro names it prints in its deprecation
315 message. We have written a patch to fix this problem, available at:
316 <http://bugs.debian.org/cgi-bin/bugreport.cgi/check-m4-am-path-check-use-quadrigraphs-in-macro-names-to-unbreak-autoconf.patch?bug=395466;msg=20;att=1>
317 Version 0.9.4-2 of the Debian package for check includes this patch.
318 Users of other distributions who want to re-autotool libxcb will need to
319 apply this patch, use an older version of check, or wait for a fixed
320 upstream version. This bug does not affect users who use the distributed
321 tarballs and do not re-autotool.
322
323 * Add library support for xcb-xinerama, using new protocol description
324   from xcb-proto.
325 * In the generated protocol code, define and use constants for opcode
326   numbers rather than hard-coding them.
327 * In the API conversion script, match only XCB-namespaced XID generators
328   when converting to xcb_generate_id.
329 * Quit treating xproto specially in Makefile.am: handle it like all the
330   extensions.
331 * Generate Doxygen documentation comments in the protocol stubs, and
332   provide a Doxygen config file for building HTML documentation for XCB.
333 * Add note to xcbxlib.h that nothing except Xlib/XCB should use it.
334 * Extend test suite to test xcb_parse_display with NULL argument and
335   display in $DISPLAY.
336
337
338 Release 1.0 RC2 (2006-10-07)
339 ============================
340
341 API changes
342 -----------
343
344 In our announcement of XCB 1.0 RC1, we proposed two API changes for
345 community feedback:
346
347     We would greatly appreciate API review in this final release
348     candidate period. We've had some limited feedback that our attempts
349     to impose static type safety on XIDs in C pose more a hindrance than
350     a help, so we would appreciate discussion over whether this
351     constitutes a "serious issue with the API". Some question also
352     remains of whether xcb_poll_for_event should have the out-parameter
353     'error', now that XCB has a more uniform mechanism for reporting
354     connection errors. Speak now on these points or leave us alone. ;-)
355
356 Since we've received feedback agreeing with our proposed changes, and no
357 objections or requests to keep the existing API, we made both changes
358 and bumped the soname to libxcb.so.1.0.0 in preparation for the release
359 of XCB 1.0.
360
361 * Remove XID wrapper structures and replace them with uint32_t typedefs.
362   XID union types like xcb_drawable_t and xcb_fontable_t also become
363   uint32_t typedefs. The API conversion script now replaces xcb_*_new
364   with calls directly to xcb_generate_id.  This change makes
365   xcb_generate_id part of the client API rather than the extension API,
366   so move xcb_generate_id from xcbext.h to xcb.h.
367
368 * Remove the 'int *error' out-parameter for xcb_poll_for_event. 
369   xcb_poll_for_event now shuts down the xcb_connection_t on fatal
370   errors; use xcb_connection_has_error to check.
371
372 The Xlib-specific API in libxcb-xlib also changed:
373
374 * Stop exposing the XCB IO lock for Xlib's benefit, by removing
375   xcb_get_io_lock from the Xlib-specific XCB API; instead, libxcb-xlib
376   now provides xcb_xlib_lock and xcb_xlib_unlock.
377
378 Code generation changes
379 -----------------------
380
381 * The code generator no longer implicitly imports xproto for extensions.
382   xcb-proto 1.0 RC2 includes the corresponding change to explicitly
383   import xproto in extensions that need it
384
385 * The generated protocol headers now declare "struct foo", "union foo"
386   or "enum foo", not just the typedef "foo" of an unnamed
387   struct/union/enum type.
388
389 Bug Fixes
390 ---------
391
392 * Make Plan 7 'checked' requests work correctly.
393
394 Documentation improvements
395 --------------------------
396
397 * Document xcb_generate_id.
398
399 * Tutorial enhancements.
400
401
402 Release 1.0 RC1 (2006-09-25)
403 ============================
404
405 The Great XCB Renaming
406 ----------------------
407
408 Rename API to follow a new naming convention:
409
410 * XCB_CONSTANTS_UPPERCASE_WITH_UNDERSCORES
411 * xcb_functions_lowercase_with_underscores
412 * xcb_types_lowercase_with_underscores_and_suffix_t
413 * expand all abbreviations like "req", "rep", and "iter"
414
415 Word boundaries for the names in the protocol descriptions fall:
416
417 * Wherever the protocol descriptions already have an underscore
418 * Between a lowercase letter and a subsequent uppercase letter
419 * Before the last uppercase letter in a string of uppercase letters
420   followed by a lowercase letter (such as in LSBFirst between LSB and
421   First)
422 * Before and after a string of digits (with exceptions for sized types
423   like xcb_char2b_t and xcb_glx_float32_t to match the stdint.h
424   convention)
425
426 Also fix up some particular naming issues:
427
428 * Rename shape_op and shape_kind to drop the "shape_" prefix, since
429   otherwise these types end up as xcb_shape_shape_{op,kind}_t.
430 * Remove leading underscores from enums in the GLX protocol description,
431   previously needed to ensure a word separator, but now redundant.
432
433 This renaming breaks code written for the previous API naming
434 convention. The scripts in XCB's tools directory will convert code
435 written for the old API to use the new API; they work well enough that
436 we used them to convert the non-program-generated code in XCB, and when
437 run on the old program-generated code, they almost exactly reproduce the
438 new program-generated code (modulo whitespace and bugs in the old code
439 generator).
440
441 Authors: Vincent Torri, Thomas Hunger, Josh Triplett
442
443 In addition to the API renaming, the library SONAMEs have changed to
444 libxcb.so and libxcb-extname.so. The library major version remains at 0,
445 to become version 1 before 1.0 is released; the SONAME lowercasing means
446 that this will not conflict with XCB 0.9 libraries.
447
448 The header files have moved from /usr/include/X11/XCB/ to
449 /usr/include/xcb/. The XML-XCB protocol descriptions have moved to
450 /usr/share/xcb, with extension descriptions no longer relegated to an
451 extensions/ subdirectory. The API conversion script api_conv.pl will fix
452 references to the header files, and packages using pkg-config will
453 automatically use the new library names.
454
455 Error handling Plan 7
456 ---------------------
457
458 All request functions now come in an "unchecked" and "checked" variant.
459 The checked variant allows callers to handle errors inline where they
460 obtain the reply, or by calling xcb_request_check for requests with no
461 reply. The unchecked variant uses the event queue for errors. Requests
462 with replies default to checked, because the caller must already make a
463 function call to retrieve the reply and can see the error at that time;
464 the unchecked variant uses the suffix _unchecked. Requests without
465 replies default to unchecked, because the caller will not necessarily
466 expect to handle a response, and the checked variant uses the suffix
467 _checked.
468
469 Connection error handling
470 -------------------------
471
472 Fatal connection errors now put the xcb_connection_t object into an
473 error state, at which point all further operations on that connection
474 will fail. Callers can use the new xcb_connection_has_error function to
475 check for this state in a connection. Functions that return a
476 connection, such as the xcb_connect function, may instead return an
477 xcb_connection_t already in an error state.
478
479 In the future we expect to add additional API for getting more
480 information about the error condition that caused the connection to get
481 into an error state.
482
483 Smaller API changes
484 -------------------
485
486 All functions that have been marked 'deprecated' up to now have been
487 removed for this release. After XCB 1.0 is released, functions marked
488 'deprecated' will be preserved until the end of time to maintain
489 compatibility.
490
491 XCB no longer provides a sync function. Most callers of this function
492 should use xcb_flush instead, which usually provides the intended
493 functionality and does not require a round-trip to the server. If you
494 really need this functionality, either use xcb_get_input_focus like sync
495 used to do, or use the xcb_aux_sync function from the xcb-aux library in
496 xcb-util. However, note that we do not consider the libraries in
497 xcb-util remotely stable yet.
498
499 XCB no longer provides xcb_[extension_name]_init functions for each
500 extension. These functions previously caused XCB to issue and process a
501 QueryExtension request. Callers should now directly call
502 xcb_get_extension_data on the xcb_[extension_name]_id, or use
503 xcb_prefetch_extension_data if they do not need to force a round-trip
504 immediately.
505
506 The compatibility functions in xcbxlib.h, provided solely for use by
507 Xlib/XCB, now exist in a separate library libxcb-xlib. We don't want to
508 have to change the libxcb soname if we later change or remove the Xlib
509 compatibility functions, and nothing except Xlib/XCB should ever use
510 them. (Applications which use Xlib/XCB do not need this library either;
511 Xlib/XCB only uses it internally.)
512
513 The descriptions of several extensions have been updated to match the
514 latest versions implemented in the X.org X server.
515
516 GIT Repository split
517 --------------------
518
519 Previously, several XCB-related projects all existed under the umbrella
520 of a single monolithic GIT repository with per-project subdirectories.
521 We have split this repository into individual per-project repositories.
522
523 Josh Triplett and Jamey Sharp wrote a tool called git-split to
524 accomplish this repository split. git-split reconstructs the history of
525 a sub-project previously stored in a subdirectory of a larger
526 repository. It constructs new commit objects based on the existing tree
527 objects for the subtree in each commit, and discards commits which do
528 not affect the history of the sub-project, as well as merges made
529 unnecessary due to these discarded commits.
530
531 We would like to acknowledge the work of the gobby team in creating a
532 collaborative editor which greatly aided the development of git-split
533 (as well as these release notes).
534
535 Build and implementation fixes
536 ------------------------------
537
538 XCB no longer needs proto/x11 from X.org; the XCB header xproto.h
539 provides the definitions from X.h, named according to XCB conventions.
540
541 XCB should now build with non-GNU implementations of Make.
542
543 XCB properly handles 32-bit wrap of sequence numbers, and thus now
544 supports issuing more than 2**32 requests in one connection.
545
546 Fixed bugs #7001, #7261.