chiark / gitweb /
dcc43b81c4d7be41e9a2884b7c00be83b6711f94
[adns.git] / changelog
1 adns (1.5.1) UPSTREAM; urgency=medium
2
3   * Portability fix for systems where socklen_t is bigger than int.
4   * Fix for malicious optimisation of memcpy in test suite, which
5     causes failure with gcc-4.1.9 -O3.  See Debian bug #772718.
6   * Fix TCP async connect handling.  The bug is hidden on Linux and on most
7     systems where the nameserver is on localhost.  If it is not hidden,
8     adns's TCP support is broken unless adns_if_noautosys is used.
9   * Fix addr queries (including subqueries, ie including deferencing MX
10     lookups etc.) not to crash when one of the address queries returns
11     tempfail.  Also, do not return a spurious pointer to the application
12     when one of the address queries returns a permanent error (although,
13     the application almost certainly won't use this pointer because the
14     associated count is zero).
15   * adnsresfilter: Fix addrtextbuf buffer size.  This is not actually a
16     problem in real compiled code but should be corrected.
17   * Properly include harness.h in adnstest.c in regress/.  Suppresses
18     a couple of compiler warnings (implicit declaration of Texit, etc.)
19
20  -- Ian Jackson <ijackson@chiark.greenend.org.uk>  Fri, 12 Aug 2016 22:53:59 +0100
21
22 adns (1.5.0) UPSTREAM; urgency=low
23
24   * Release 1.5.0.  No changes since 1.5.0~rc1.
25
26  -- Ian Jackson <ijackson@chiark.greenend.org.uk>  Sun, 26 Oct 2014 14:57:10 +0000
27
28 adns (1.5.0~rc1) UPSTREAM; urgency=low
29
30   ABI/API changes:
31   * Provide adns_qf_cname_strict flag, currently ignored because it's the
32     default.  This will allow us to make this not the default in the future
33     while retaining forward and backward API and ABI compatibility.
34   * Add `sizeforce' enum member value to force enum types in the APIs to be
35     big (which will avoids theoretical future ABI-incompatibility).
36   * Reject unknown flags passed by our caller.  This will make it ABI-safe
37     (although not ABI-backward-compatible) to add new flags in the future,
38     as newer clients running against this old library will get ENOSYS.
39
40   resolv.conf parsing:
41   * Support `adns_ignoreunkcfg' resolv.conf option to ignore unknown
42     options and keywords in resolv.conf.
43   * Ignore various BIND9 resolv.conf keywords and options.
44   * Fix resolv.conf option word splitting.
45
46   Tests, build system, coding style, etc.:
47   * Test cases show rrtype flag values in hex.
48   * Parallelise `make check'.
49   * Make vbuf__append_quoted1035 no longer extern (there are no out-of-file
50     callers).
51   * Remove all RCSids.
52   * When releasing, check that the `make dist' tarball is identical to git.
53     And provide a test mode for the RELEASE-CHECKLIST doc/script.
54   * Add `make dist' tarball signature to .gitignore.
55   * More correctly and effectively work around bugs in make (Debian #4073,
56     #756123) affecting regress.
57
58  -- Ian Jackson <ijackson@chiark.greenend.org.uk>  Sun, 26 Oct 2014 13:24:00 +0000
59
60 adns (1.5.0~rc0) UPSTREAM; urgency=low
61
62   New features:
63   * Support for queries about IPv6 data in all applicable adns
64     query types (including AAAA, PTR, and adns_r_addr queries).
65     (Thanks very much to Mark Wooding.)
66   * Support for transport over IPv6.  (Thanks to Mark Wooding again.)
67   * adns_addr2text and adns_text2addr: Convenient functions for
68     converting between addresses and address literals.
69
70   Bugfixes:
71   * Fix a crashing bug in adnslogres.  (Debian#392102.)
72   * Do all checks of checked PTR owner name before actually sending the
73     query, and reject IPv4 PTR owner names whose labels have leading zero
74     digits or values >255.
75
76   Build system fixes and improvements:
77   * `make clean' removes the pipes.
78   * Work around bugs in make (Debian #4073, #756123) affecting regress.
79   * Do not include Makefile and src/config.h in distribution tarball.
80
81   Regression test debugging improvements:
82   * Provide gdbwrap convenience script.
83   * Honour ADNS_TEST_DEBUG env. var.  (Mark Wooding.)
84
85   Other improvements:
86   * Licence changed to GPLv3 (still LGPLv2 for adns.h).
87   * Source code cleanups.  (Some from Mark Wooding.)
88   * Now in git.
89   * Documentation and webpage updates.
90
91  -- Ian Jackson <ijackson@chiark.greenend.org.uk>  Mon, 20 Oct 2014 01:29:50 +0100
92
93 adns (1.4); urgency=low
94
95   Improvements for multithreaded programs:
96   * New documentation comment in adns.h explaining thread guarantees
97     (or lack of them), replaces `single-threaded' note at the top.
98   * Fix string conversion of adns_r_addr not to use a static buffer
99     (function csp_addr) so as to make thread promise true.
100   * Make an internal variable const-correct (expectdomain in pa_ptr).
101
102  -- Ian Jackson <ian@davenant.greenend.org.uk>  Tue, 17 Oct 2006 17:05:08 +0100
103
104 adns (1.3); urgency=low
105
106   Portability fixes:
107   * Cast ptrdiff_t to int for %.*s length in adnsheloex and adnslogres,
108     as is required.  (Report from Jim Meyering.)
109   * In configure.in, quote macro name argument to define() to
110     suppress spurious autoconf error.  (Report from Mihai Ibanescu.)
111   * Use autoconf's values for {bin,lib,include}dir rather than inventing
112     our own from @exec_prefix@, making configure --libdir work.
113     (Patch from Mihai Ibanescu.)
114   * Remove spurious `_' from {bin,lib,include}dir Makefile variables.
115     (Report from Mihai Ibanescu.)
116   * Do away with `mismatch' variable in parse.c:adns__findrr_anychk so that
117     overzealous GCC cannot complain about members of eo_fls being
118     uninitialised.  (Report from Jim Meyering.)
119
120  -- Ian Jackson <ian@davenant.greenend.org.uk>  Tue,  6 Jun 2006 20:22:30 +0100
121
122 adns (1.2); urgency=medium
123
124   New features:
125   * Support for SRV RRs.
126   * Support for unknown RR types (according to RFC3597) via adns_r_unknown.
127   * Allow `;'-comments in resolv.conf (report from Colin Charles).    
128   * New adnsheloex client courtesy of Tony Finch.
129   * New adns_init_logfn etc. for having logging use a callback function.
130
131   Bugfixes:
132   * Fix error in prototype in definition of adns__parse_domain.
133   * Add missing ENOTSOCK to hcommon.c.m4 (was already in hcommon.c!)
134
135   Portability fixes prompted by Bernd Eckenfels, the Debian maintainer:
136   * Correct type of various printf arguments: ptrdiff_t != int.
137   * Do not print size of leaked blocks of memory (this causes
138     a spurious regression test failure on some platforms).
139   * Provide adns_if_none and adns_qf_none (which will help with compilers
140     which complain about plain `0' being passed where an enum is wanted).
141   * adnstest converts some errno values to EFOOBAR: all of the ones
142     mentioned in adns.h, at least.  This makes the regression test
143     more portable (fixes problem noticed by Bernd Eckenfels).
144   * Add -Wno-pointer-sign if GCC has that option.
145
146   Documentation improvements:
147   * Add documentation comment by definition of adns_r_ptr_raw type enum.
148   * Document in adns.h EINVAL from adns_init meaning bad configuration.
149   * Include several new references to related programs to README.html.
150   * Redacted the TODO list.
151   * New LICENCE.WAIVERS file for GPL-incompatility workarounds.
152   * Clarified GPL-vs-LGPL: a bit less hostile and a bit more mercenary.
153   * Copyright notices updated.
154
155   Packaging changes:
156   * Update MINOR to 2 and DISTVERSION and ADNS_VERSION_STRING to 1.2.
157   * Reran autoconf/autoheader (autoconf Debian 2.13-54).
158   * Create $(bin_dir) and $(lib_dir) on `make install', and also
159     make a libadns.so.1 -> libadns.so.1.<minor> link.  (Suggestions
160     and patch from Nix of esperi.org.uk.)
161   * Add .PHONY: install to Makefile, to help people with demented fs's.
162   * Darwin listed in INSTALL.
163
164   Minor test harness improvements:
165   * Hgettimeofday calls Tensurerecordfile (was Tensureinput/outputfile).
166   * Add bind(2) and listen(2) wrappers (for epithet, but harmless in adns).
167
168  -- Ian Jackson <ian@davenant.greenend.org.uk>  Sat,  8 Apr 2006 15:41:28 +0100
169
170 adns (1.1); urgency=medium
171
172   Major bugfixes:
173   * Do not spin if connect() fails immediately (!)
174   * Stop searching on a CNAME (even if it's broken).
175   * When search list runs out, _qf_owner sets owner to query domain.
176   * Fix bogus multiple updates to p in transmit.c (!)
177
178   Portability improvements:
179   * Fix up spurious #undef's in hredirect.h.
180   * Don't use <sys/select.h> any more, it was a mistake made in pre-1.0
181     (and there doesn't seem to be much explanation why).
182   * Understand and sort of check OpenBSD `lookup' resolv.conf directive.
183   * #include <stdlib.h> in internal.h (for abort etc).
184   * Always #include <sys/types.h> before <sys/socket.h> (for FreeBSD 4.6).
185
186   Cosmetic and documentation improvements:
187   * Added wishlist entry re configurable port no.
188   * Problem with SERVFAIL in TODO.
189   * README.html: mentioned Jarle Aase's Windows port, and other fixes.
190   * Some better source code formatting/wrapping.
191
192  -- Ian Jackson <ian@davenant.greenend.org.uk>  Tue,  1 Jul 2003 22:55:29 +0100
193
194 adns (1.0); urgency=medium
195
196   Bugfixes:
197   * Treat 8-bit characters in email addrs as RFC822 `special' (=> quote).
198   * Fix incorrect `compressed datagram contains loop' error.
199   * Actually compile shared libraries by default !
200   * Fix adnsresfilter usage message to include correct default timeout.
201
202   General improvements:
203   * adnshost, adnslogres, adnsresfilter have options for config override. 
204   * adnsresfilter has --debug option.
205   * Improvements to adnslogres (incl. new -c option) from Tony Finch.
206   * adnslogres has --help option, all utilities support --version.
207   * Documentation improved somewhat, including new GPL-vs-LGPL file.
208
209   Changes for non-BETA release:
210   * Change shared library soname to 1.0.
211   * Do not install adnstest test utility.
212
213   Regression test improvements:
214   * Tests now include adnshost, adnslogres and adnsresfilter.
215   * Test cancellation both before and after query completion.
216
217   Portability fixes and cleanups:
218   * adnstest: setvbuf(stdout,...) before we do first output.
219   * Cope with compilers that don't do `inline'.
220   * Add and fix various missing system #includes.
221   * Find install-sh properly when we need to use it, and chmod it +x.
222   * Do not use variadic macro, use stdarg instead (adnslogres.c).
223   * Regression tests work even if some syscalls are already macros.
224   * #include "config.h" before "adns.h".
225   * Cast a sizeof(...) in src/event.c to unsigned long before printing.
226   * Add pre-generated versions of m4-generated files in regress/.
227   * Kill bogus warning, adh-main.c: `arg2' might be used uninitialized ...
228   * Add extra {...} near adnslogres.c:167 to kill spurious warning.
229   * Use `printf' instead of `echo -n'.
230   * Add list of tested platforms in INSTALL file.
231
232  -- Ian Jackson <ian@davenant.greenend.org.uk>  Sun, 17 Sep 2000 15:15:58 +0100
233
234 adns (0.9) BETA; urgency=high
235
236   Bug fixes:
237   * Don't make _processany always kill the TCP connection with the message
238     `TCP connection failed: poll/select: exceptional condition detected'.
239   * Call MEM_ROUND in __transfer_interim (avoids assert fail
240     `qu->interim_allocd>=0' on some platforms eg 64 bit).
241   * adnsresfilter doesn't resolve textual prefixes of addresses (eg,
242     10.0.0.1 out of 10.0.0.123) if input happens to block at that point.
243   * Do not spin if TCP connection blocks for writing (and add test case).
244   * Fail queries if TCP dies repeatedly, rather than retrying many times.
245   * Do not abort in a couple of places if TCP unexpectedly broken.
246   * Do not free something twice if query fails and is then cancelled.
247
248   Portability/compilation fixes:
249   * Move `extern "C" {' to after #include <...>'s.
250   * Pass LDFLAGS from configure on to ld via settings.make.in.
251   * make clean deletes *.so and *.so.* files.
252   * New --disable-dynamic configure option for non-ELF systems.
253   * Use AC_PROG_INSTALL (=> perhaps install-sh), to avoid bad `install'.
254
255   Minor improvements:
256   * Do not print warning if sendto() gives EAGAIN.
257   * adnsresfilter default timeout changed to 1000ms.
258   * m1test script can invoke `hrecord' differently.
259   * regress/output-<case>.report file contains more useful info.
260   * TODO list and other docs updated slightly.
261   * Referrals with RD+RA set, or RCODE=Refused, don't generate warnings,
262     just debug messages.  BIND does this kind of thing all the time.
263
264  -- Ian Jackson <ian@davenant.greenend.org.uk>  Wed,  9 Aug 2000 16:59:28 +0100
265
266 adns (0.8) BETA; urgency=medium
267
268   Bugfixes:
269   * Race near adns_beforeselect which could cause infinite timeout fixed
270     (it's now less agressive, and will more often return a zero timeout.)
271   * Fixed infrequent race causing assertion failure in adns__tcp_broken
272     `ads->tcpstate == server_connecting || ads->tcpstate == server_ok'.
273   * Spurious `server failure on unidentifiable query' warning suppressed.
274   * If we get a referral, don't also always complain falsely about RD==0.
275   * adnslogres: cast chars to unsigned char before using ctype.h macros.
276   * In _beforeselect, global failure now means zero timeout, and in
277     tcp_events, really never try to do anything with the TCP connection if
278     act is zero.  This might possibly cause an infinite delay (ie, lockup)
279     if things go badly wrong *and* a really unlikely race happens.
280   * Test suite `lines of syscall left' value is correct; !0 is failure.
281
282   Portability fixes:
283   * install-sh (from autoconf 2.12 Debian r13) included.
284   * adnslogres: do not call equivalent of printf("%.*s",0,(char*)0).
285
286   Documentation improvements:
287   * Security/performance note added, about local nameservers and DNSSEC.
288   * Documented that adns_rr_info _rr_hostaddr ( ) for address list
289     means permanent failure, and ? means temporary failure.
290   * Typo (*now for now in _beforeselect description) in adns.h fixed.
291   * Copyright notices updated.
292   
293   Changes to produce more defensive code:
294   * In adns_wait, assert that the timeout is not infinite.
295   * Make qu->id start out as -2 when initially allocated.
296
297  -- Ian Jackson <ian@davenant.greenend.org.uk>  Sun,  7 May 2000 23:37:13 +0100
298
299 adns (0.7) BETA; urgency=medium
300
301   * New adns_submit_reverse_any for eg RBL lookups, and corresponding
302     option to adnshost.
303   * README updated (from www home page).
304
305   * In answers, quote all except alphanums and - _ / + (and document).
306   * Don't reject specials in cnames even without adns_qf_quotefail_cname.
307   * Better checking of long domain names and labels in queries.
308   * answer->owner may be null on error.  Documented, and adnshost copes.
309   * Better reporting of unexpected or weird replies from nameserver.
310   * Add test case for recursion (infinite loop) domain compression.
311
312  -- Ian Jackson <ian@davenant.greenend.org.uk>  Thu,  2 Mar 2000 01:55:53 +0000
313
314 adns (0.6) BETA; urgency=high
315
316   Core library bugfixes:
317   * Avoid infinite timeouts, causing lockup, when they should be zero !
318   * TCP handling revamped (avoids undefined behaviour due to reentrancy).
319   * Do not fail assertion if _qf_owner, _qf_search, domain ends in `.'.
320   * Many memory leaks fixed.
321
322   Cool new utility:
323   * adnsresfilter is like `cat' but converts addresses to names without
324     delaying the output.  Pipe `netstat -n', `tcpdump -ln', etc. into it.
325
326   Test and client program bug and portability fixes:
327   * Dynamic library building works properly.
328   * adnshost prints somewhat better messages about some wrong usages.
329   * Include <stdlib.h> and <sys/types.h> in adnshost.h.
330   * adnslogres: parsing and error checking improved (Tony Finch).
331   * Regression tests can cope with zero-length reads.
332   * Regression tests check for memory leaks.
333   * adnstest copes with empty query type list.
334   * adnstest uninitialised memory bug fixed.
335
336   General improvements
337   * Better control of adnshost output and error messages (new -F options).
338   * New adns_if_logpid option (functionality suggested by Tony Finch).
339   * New fanftest test program from Tony Finch (ignored by `make install').
340   * Reads /etc/resolv-adns.conf if it exists.
341   * Declare flags parameters as enums again, not ints.
342
343  -- Ian Jackson <ian@davenant.greenend.org.uk>  Wed, 24 Nov 1999 17:13:03 +0000
344
345 adns (0.5) unstable; urgency=high
346
347   New features:
348   * adnslogres, ~100x faster replacement for Apache logresolve;
349     Thanks to Tony Finch for the program and the performance figure.
350   * Internal consistency checking with assert if right options set.
351   * adns_wait_poll function like adns_wait but uses poll, not select.
352   * adns_reverse_submit function for easy in-addr queries.
353   * adns_errtypeabbrev funcion for getting eg "permfail" from _s_nodata.
354   * adnshost utility for scripts and the like (rather alpha).
355
356   Incompatible changes:
357   * RRs with mailboxes never rejected due to strange chars if _raw.
358   * Lack of a mailbox produces `.' not `<>'.
359   * Better usage messages (and no default query domain) for adnstest.
360   * Return EAGAIN from _check instead of EWOULDBLOCK.
361   * adns_rr_info on _r_mx etc. shows status type abbrev and status number.
362   
363   Bugfixes:
364   * Do not invoke __autosys indirectly from __procdgram (result: coredump
365     usually in memmove, unless adns_if_noautosys was used).
366   * Do not scramble innards when a query on the output queue is cancelled.
367   * Do not close tcp socket twice.
368   * Mailboxes containing spaces in their names are quoted.
369   * Give ESRCH, not EAGAIN, if _check called with no queries outstanding.
370   * adns_rr_hostaddr naddrs is -1 on temporary failure (as documented).
371   * Reject TXT RRs with no strings.
372   * Correct error messages for qname CNAME foo, foo CNAME bar.
373   * adns_processany actually does something.
374   * Fixed typos in adns.h.
375
376   General improvements:
377   * Promise not to change fds in adns_beforepoll (if now is specified).
378   * Improved textual error string for _s_prohibitedcname.
379   * New comment in adns_processany and return 0 (not r which is 0).
380   * Documentation of resolv.conf directives and options, and of environment
381     variables understood, in adns.h
382   * Regression test scripts set EF_DISABLE_BANNER (for Electric Fence).
383
384   Portability and build improvements:
385   * Give install the '-c' flag (otherwise some delete the original !).
386   * Do not remove top-level Makefile on `make clean'.
387   * Don't complain so much about poll(2) tests if not available.
388   * Do not give -u 0 -g 0 options to install.
389   * Remove trailing , from some enums in adns.h.
390   * Dynamically linked clients now made with -l, so as to avoid rpath.
391   * Do not use $^ in make rules (should help with non-GNU make).
392   * Declare flags parameters as ints not enums because C++ is crap.
393
394  -- Ian Jackson <ian@davenant.greenend.org.uk>  Wed, 13 Oct 1999 02:24:35 +0100
395
396 adns (0.4) unstable; urgency=high
397
398   General important bugfixes:
399   * make _qf_owner work if _qf_search not specified, and test it (oops!)
400   * ads->configerrno now initialised (in setup.c).
401   * timercmp(,,<=) doesn't work - use !timercmp(,,>).
402   * Changed memory semantics of internal queries to fix bugs.
403   * Restarting a TCP-using query (eg due to CNAME) doesn't abort.
404   
405   Fixes for handling of broken kinds of reply:
406   * Only accept a reply from the subset of servers we sent the query.
407   * Ignore CNAME(s) in answer after RR(s) (and test).
408
409   Other bugfixes and improvements:
410   * adns_s_systemfail is in table of errors (for eg adns_strerror).
411   * Do not ship config.cache, Makefile, etc.
412   * Improvements to install instructions, TODO, etc.
413   * Regression tests compile on systems without poll(2).
414   * Do not install adnstest_s.
415   * _submit returns ENOSYS, not adns_s_unknownquery; documented, tested.
416   * <adns.h> includes <sys/types.h>, <sys/time.h>, <unistd.h>.
417
418  -- Ian Jackson <ian@davenant.greenend.org.uk>  Thu, 5 Aug 1999 01:17:38 +0100
419
420 adns (0.3) unstable; urgency=low
421
422   Incompatible changes:
423   * Low adns_status values (below adns_s_max_tempfail) renumbered to make
424     room for future locally-induced and locally-detected errors.
425   * Event loop functions for use by select(2) renamed and tidied up.
426   
427   Features / improvements:
428   * New adns_errabbrev() for getting status abbreviation strings.
429   * regress/checkall prints summary list of failed tests, if any.
430   * Event loop functions for poll(2), and some raw variants.
431   * adnstest has ability to use poll(2), and user can set initflags.
432   * checkall prints passed list as well as failed list, if any failed.
433   * You can iterate over outstanding queries (but only once at a time).
434   
435   Bugfixes:
436   * Non-RFC822 mailbox `domain' formatting now works, and clarified.
437   * Rejection of bad characters in domains (without quoteok) works.
438   * Clean up parents from adns->childw (otherwise would abort/segfault).
439   * In adnstest, allocate enough space for, and terminate, query types.
440   * In adnstest, don't print errno values as adns_status values.
441  
442   * Added TODO file.
443   * Made adnstest.c test context pointers.
444
445  -- Ian Jackson <ian@davenant.greenend.org.uk>  Thu, 15 Jul 1999 00:23:12 +0100
446
447 adns (0.2) experimental; urgency=low
448
449   Portability fixes for compilation on various platforms:
450   * Include <sys/socket.h> and <netinet/in.h> in files with <arpa/inet.h>.
451   * Don't use GCC union assignment feature (.rrs=0 => .rrs.untyped=0).
452   * Explictly cast things to [const] struct sockaddr* in syscall args.
453   * Check whether we need -lsocket.
454   * Include <sys/times.h> in a few more files.
455   * Include <unistd.h> and <sys/time.h> for select.
456   * Look for inet_aton and inet_ntoa (in -lnsl and -lsocket).
457   * LDLIBS removed from dependency lists (some makes don't support this).
458   * An `ambiguous else' warning from some compilers in types.c is removed.
459
460   Other changes:
461   * Added COPYING (copy of the GPL).
462   * Regression test failure output improved.
463   * Missing targets in regress/Makefile.in added.
464   * Regression test doesn't rely on value of fcntl flags eg O_NONBLOCK.
465
466  -- Ian Jackson <ian@davenant.greenend.org.uk>  Thu, 20 May 1999 00:27:32 +0100
467
468 adns (0.1) experimental; urgency=low
469
470   * Initial public alpha release.
471
472  -- Ian Jackson <ian@davenant.greenend.org.uk>  Sat, 17 April 1999 17:42:19
473
474 Local variables:
475 mode: debian-changelog
476 fill-column: 75
477 End: