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