a0260cbc775ebd5f24fa260761ec6785a0960535
[free-sw/xcb/libxcb] / NEWS
1 Release 1.1 (2007-11-04)
2 ========================
3
4 This release requires xcb-proto 1.1, due to the addition of the
5 extension-multiword attribute to the XML schema.
6
7 This release contains several important bug fixes, summarized below. It
8 also contains a patch much like Novell's libxcb-sloppy-lock.diff.
9 Rationale from the commit message follows. The patch and this rationale
10 were authored by Jamey Sharp <jamey@minilop.net>, with agreement from
11 Josh Triplett <josh@freedesktop.org>.
12
13     I strongly opposed proposals like this one for a long time.
14     Originally I had a very good reason: libX11, when compiled to use
15     XCB, would crash soon after a locking correctness violation, so it
16     was better to have an informative assert failure than a mystifying
17     crash soon after.
18
19     It took some time for me to realize that I'd changed the libX11
20     implementation (for unrelated reasons) so that it could survive most
21     invalid locking situations, as long as it wasn't actually being used
22     from multiple threads concurrently.
23
24     The other thing that has changed is that most of the code with
25     incorrect locking has now been fixed. The value of the assert is
26     accordingly lower.
27
28     However, remaining broken callers do need to be fixed. That's why
29     libXCB will still noisily print a stacktrace (if possible) on each
30     assertion failure, even when assert isn't actually invoked to
31     abort() the program; and that's why aborting is still default. This
32     environment variable is provided only for use as a temporary
33     workaround for broken applications.
34
35 Enhancements:
36 * Print a backtrace, if possible, on locking assertion failures.
37 * Skip abort() on locking assertions if LIBXCB_ALLOW_SLOPPY_LOCK is set.
38 * xcb_poll_for_event: Return already-read events before reading again.
39 * Output a configuration summary at the end of ./configure.
40
41 Bug fixes:
42 * Don't hold the xlib-xcb lock while sleeping: that allows deadlock.
43 * Allow unix:<screen> style display names again.
44 * Bug #9119: test xcb_popcount
45 * Fix unit tests for FreeBSD
46 * NetBSD doesn't have AI_ADDRCONFIG: use it only if it's available.
47 * Require libXau >= 0.99.2; earlier versions have a broken .pc file
48 * Use substitition variables in xcb-xinerama.pc.in
49 * Update autogen.sh to one that does objdir != srcdir
50 * Add tools/* and autogen.sh to EXTRA_DIST.
51 * Doxygen can now be fully disabled if desired.
52
53 Documentation improvements:
54 * Many fixes and updates to the tutorial.
55 * Iterators, requests, and replies get partial Doxygen documentation.
56
57
58 Release 1.0 (2006-11-23)
59 ========================
60
61 The "Thanksgiving" release: We feel thankful to have it released.  Five years
62 have passed since XCB's initial commit on September 3rd, 2001:
63     <http://gitweb.freedesktop.org/?p=xcb.git;a=commit;h=09e54c4a3c>
64
65 * Support IPv6.  XCB now supports displays with IPv6 addresses, with or without
66   enclosing square brackets, or with hosts which resolve to IPv6 addresses, by
67   using getaddrinfo instead of gethostbyname, and by including support for
68   authentication for such connections.  This allows such displays as "::1:1.1".
69
70 * XCB now uses the libpthread-stubs, to properly support optional use of
71   pthreads even on platforms which do not have all the necessary pthread stubs
72   in libc or otherwise available by default.
73
74 * Switch from the old AM_PATH_CHECK macro to pkg-config.  check 0.9.4 is now
75   required to build XCB's unit tests.  The version that we were requiring was
76   not actually new enough to let our unit tests compile, and the AM_PATH_CHECK
77   macro is now considered deprecated.  We know that versions of check using
78   pkg-config are new enough to work, and the check dependency was optional
79   anyway, so we've dropped support for older versions.
80
81 * Provide a xcb_prefetch_maximum_request_length counterpart to
82   xcb_get_maximum_request_length.
83
84 * Fix Bug #5958: zero out padding bytes in requests.
85
86 * Change xcb_connect to pass the display number to _xcb_get_auth_info, which
87   passes it to get_authptr.  This allows get_authptr to stop hacking the
88   display number out of the sockaddrs of various address families, such as
89   port - X_TCP_PORT, or the number after the last X in the UNIX socket path.
90
91 * Remove --with-opt and --with-debug options from configure.ac; configure
92   supports the use of custom CFLAGS, so please use that instead.
93
94 * Reove support for the <localfield> tag in protocol descriptions, since they
95   no longer use it, and since new protocol descriptions should not need it
96   either.
97
98 * xcb-proto has no libraries or headers, so don't use XCBPROTO_CFLAGS or
99   XCBPROTO_LIBS.
100
101 * XCB builds which use xdmcp now include it in Requires.private, to support
102   static linking.
103
104 * Replace "long" with uint32_t when used for a 32-bit quantity
105
106 * Various enhancements to the generation of documentation with Doxygen:
107   * Check for doxygen in configure.ac
108   * Fix some Doxygen warnings.
109   * Install documentation.
110   * Handle out-of-tree builds, with srcdir != builddir.  xcb.doxygen now gets
111     generated from xcb.doxygen.in, so that it can use top_builddir and
112     top_srcdir to find source and to output documentation.
113   * Fill in PROJECT_NUMBER from @VERSION@, now that we have it readily
114     available via autoconf.
115
116
117 Release 1.0 RC3 (2006-11-02)
118 ============================
119
120 Note: Version 0.9.4 of the test suite tool "check" provides a broken
121 version of the AM_PATH_CHECK macro, which causes autoconf to fail due to
122 insufficient quoting on the macro names it prints in its deprecation
123 message. We have written a patch to fix this problem, available at:
124 <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>
125 Version 0.9.4-2 of the Debian package for check includes this patch.
126 Users of other distributions who want to re-autotool libxcb will need to
127 apply this patch, use an older version of check, or wait for a fixed
128 upstream version. This bug does not affect users who use the distributed
129 tarballs and do not re-autotool.
130
131 * Add library support for xcb-xinerama, using new protocol description
132   from xcb-proto.
133 * In the generated protocol code, define and use constants for opcode
134   numbers rather than hard-coding them.
135 * In the API conversion script, match only XCB-namespaced XID generators
136   when converting to xcb_generate_id.
137 * Quit treating xproto specially in Makefile.am: handle it like all the
138   extensions.
139 * Generate Doxygen documentation comments in the protocol stubs, and
140   provide a Doxygen config file for building HTML documentation for XCB.
141 * Add note to xcbxlib.h that nothing except Xlib/XCB should use it.
142 * Extend test suite to test xcb_parse_display with NULL argument and
143   display in $DISPLAY.
144
145
146 Release 1.0 RC2 (2006-10-07)
147 ============================
148
149 API changes
150 -----------
151
152 In our announcement of XCB 1.0 RC1, we proposed two API changes for
153 community feedback:
154
155     We would greatly appreciate API review in this final release
156     candidate period. We've had some limited feedback that our attempts
157     to impose static type safety on XIDs in C pose more a hindrance than
158     a help, so we would appreciate discussion over whether this
159     constitutes a "serious issue with the API". Some question also
160     remains of whether xcb_poll_for_event should have the out-parameter
161     'error', now that XCB has a more uniform mechanism for reporting
162     connection errors. Speak now on these points or leave us alone. ;-)
163
164 Since we've received feedback agreeing with our proposed changes, and no
165 objections or requests to keep the existing API, we made both changes
166 and bumped the soname to libxcb.so.1.0.0 in preparation for the release
167 of XCB 1.0.
168
169 * Remove XID wrapper structures and replace them with uint32_t typedefs.
170   XID union types like xcb_drawable_t and xcb_fontable_t also become
171   uint32_t typedefs. The API conversion script now replaces xcb_*_new
172   with calls directly to xcb_generate_id.  This change makes
173   xcb_generate_id part of the client API rather than the extension API,
174   so move xcb_generate_id from xcbext.h to xcb.h.
175
176 * Remove the 'int *error' out-parameter for xcb_poll_for_event. 
177   xcb_poll_for_event now shuts down the xcb_connection_t on fatal
178   errors; use xcb_connection_has_error to check.
179
180 The Xlib-specific API in libxcb-xlib also changed:
181
182 * Stop exposing the XCB IO lock for Xlib's benefit, by removing
183   xcb_get_io_lock from the Xlib-specific XCB API; instead, libxcb-xlib
184   now provides xcb_xlib_lock and xcb_xlib_unlock.
185
186 Code generation changes
187 -----------------------
188
189 * The code generator no longer implicitly imports xproto for extensions.
190   xcb-proto 1.0 RC2 includes the corresponding change to explicitly
191   import xproto in extensions that need it
192
193 * The generated protocol headers now declare "struct foo", "union foo"
194   or "enum foo", not just the typedef "foo" of an unnamed
195   struct/union/enum type.
196
197 Bug Fixes
198 ---------
199
200 * Make Plan 7 'checked' requests work correctly.
201
202 Documentation improvements
203 --------------------------
204
205 * Document xcb_generate_id.
206
207 * Tutorial enhancements.
208
209
210 Release 1.0 RC1 (2006-09-25)
211 ============================
212
213 The Great XCB Renaming
214 ----------------------
215
216 Rename API to follow a new naming convention:
217
218 * XCB_CONSTANTS_UPPERCASE_WITH_UNDERSCORES
219 * xcb_functions_lowercase_with_underscores
220 * xcb_types_lowercase_with_underscores_and_suffix_t
221 * expand all abbreviations like "req", "rep", and "iter"
222
223 Word boundaries for the names in the protocol descriptions fall:
224
225 * Wherever the protocol descriptions already have an underscore
226 * Between a lowercase letter and a subsequent uppercase letter
227 * Before the last uppercase letter in a string of uppercase letters
228   followed by a lowercase letter (such as in LSBFirst between LSB and
229   First)
230 * Before and after a string of digits (with exceptions for sized types
231   like xcb_char2b_t and xcb_glx_float32_t to match the stdint.h
232   convention)
233
234 Also fix up some particular naming issues:
235
236 * Rename shape_op and shape_kind to drop the "shape_" prefix, since
237   otherwise these types end up as xcb_shape_shape_{op,kind}_t.
238 * Remove leading underscores from enums in the GLX protocol description,
239   previously needed to ensure a word separator, but now redundant.
240
241 This renaming breaks code written for the previous API naming
242 convention. The scripts in XCB's tools directory will convert code
243 written for the old API to use the new API; they work well enough that
244 we used them to convert the non-program-generated code in XCB, and when
245 run on the old program-generated code, they almost exactly reproduce the
246 new program-generated code (modulo whitespace and bugs in the old code
247 generator).
248
249 Authors: Vincent Torri, Thomas Hunger, Josh Triplett
250
251 In addition to the API renaming, the library SONAMEs have changed to
252 libxcb.so and libxcb-extname.so. The library major version remains at 0,
253 to become version 1 before 1.0 is released; the SONAME lowercasing means
254 that this will not conflict with XCB 0.9 libraries.
255
256 The header files have moved from /usr/include/X11/XCB/ to
257 /usr/include/xcb/. The XML-XCB protocol descriptions have moved to
258 /usr/share/xcb, with extension descriptions no longer relegated to an
259 extensions/ subdirectory. The API conversion script api_conv.pl will fix
260 references to the header files, and packages using pkg-config will
261 automatically use the new library names.
262
263 Error handling Plan 7
264 ---------------------
265
266 All request functions now come in an "unchecked" and "checked" variant.
267 The checked variant allows callers to handle errors inline where they
268 obtain the reply, or by calling xcb_request_check for requests with no
269 reply. The unchecked variant uses the event queue for errors. Requests
270 with replies default to checked, because the caller must already make a
271 function call to retrieve the reply and can see the error at that time;
272 the unchecked variant uses the suffix _unchecked. Requests without
273 replies default to unchecked, because the caller will not necessarily
274 expect to handle a response, and the checked variant uses the suffix
275 _checked.
276
277 Connection error handling
278 -------------------------
279
280 Fatal connection errors now put the xcb_connection_t object into an
281 error state, at which point all further operations on that connection
282 will fail. Callers can use the new xcb_connection_has_error function to
283 check for this state in a connection. Functions that return a
284 connection, such as the xcb_connect function, may instead return an
285 xcb_connection_t already in an error state.
286
287 In the future we expect to add additional API for getting more
288 information about the error condition that caused the connection to get
289 into an error state.
290
291 Smaller API changes
292 -------------------
293
294 All functions that have been marked 'deprecated' up to now have been
295 removed for this release. After XCB 1.0 is released, functions marked
296 'deprecated' will be preserved until the end of time to maintain
297 compatibility.
298
299 XCB no longer provides a sync function. Most callers of this function
300 should use xcb_flush instead, which usually provides the intended
301 functionality and does not require a round-trip to the server. If you
302 really need this functionality, either use xcb_get_input_focus like sync
303 used to do, or use the xcb_aux_sync function from the xcb-aux library in
304 xcb-util. However, note that we do not consider the libraries in
305 xcb-util remotely stable yet.
306
307 XCB no longer provides xcb_[extension_name]_init functions for each
308 extension. These functions previously caused XCB to issue and process a
309 QueryExtension request. Callers should now directly call
310 xcb_get_extension_data on the xcb_[extension_name]_id, or use
311 xcb_prefetch_extension_data if they do not need to force a round-trip
312 immediately.
313
314 The compatibility functions in xcbxlib.h, provided solely for use by
315 Xlib/XCB, now exist in a separate library libxcb-xlib. We don't want to
316 have to change the libxcb soname if we later change or remove the Xlib
317 compatibility functions, and nothing except Xlib/XCB should ever use
318 them. (Applications which use Xlib/XCB do not need this library either;
319 Xlib/XCB only uses it internally.)
320
321 The descriptions of several extensions have been updated to match the
322 latest versions implemented in the X.org X server.
323
324 GIT Repository split
325 --------------------
326
327 Previously, several XCB-related projects all existed under the umbrella
328 of a single monolithic GIT repository with per-project subdirectories.
329 We have split this repository into individual per-project repositories.
330
331 Josh Triplett and Jamey Sharp wrote a tool called git-split to
332 accomplish this repository split. git-split reconstructs the history of
333 a sub-project previously stored in a subdirectory of a larger
334 repository. It constructs new commit objects based on the existing tree
335 objects for the subtree in each commit, and discards commits which do
336 not affect the history of the sub-project, as well as merges made
337 unnecessary due to these discarded commits.
338
339 We would like to acknowledge the work of the gobby team in creating a
340 collaborative editor which greatly aided the development of git-split
341 (as well as these release notes).
342
343 Build and implementation fixes
344 ------------------------------
345
346 XCB no longer needs proto/x11 from X.org; the XCB header xproto.h
347 provides the definitions from X.h, named according to XCB conventions.
348
349 XCB should now build with non-GNU implementations of Make.
350
351 XCB properly handles 32-bit wrap of sequence numbers, and thus now
352 supports issuing more than 2**32 requests in one connection.
353
354 Fixed bugs #7001, #7261.