5a2391089bb2fc9d4771f24dec873e7dff0dd1fb
[polipo.git] / CHANGES
1 14 April 2014: Polipo 1.1.0:
2
3   * Proper va_list handling for AMD64 and other RISC-like architectures
4     (Juliusz Chroboczek and Aleksandar Kuktin).
5   * Implemented work-around for broken Content-Range headers.
6   * Use 1024 instead of 32 as the length of the listen queue.
7   * Implemented the ability to control the permissions set on the log file.
8   * Implemented the ability to scrub private information from logs.
9   * Fixed a bug that could cause incorrect logging to syslog (thanks
10     to Sami Farin).
11   * Tweaked the portable version of mktime_gmt.  This will hopefully
12     fix the time issues on Windows.  Thanks to MaxWell and Greg.
13   * Changed chunk allocator to use larger arenas on 64-bit arches.
14   * Fixed a bug that could prevent saving objects on disk.  Thanks to
15     Ming Fu.
16   * Fixed a bug that could prevent parsing large headers.  Thanks to
17     Ming Fu.
18   * Fixed an issue that could cause crash messages to go into the disk
19     cache.
20   * Fixed a bug that could cause the default chunk memory to be incorrect
21     on FreeBSD machines.  Thanks to Frank Behrens.
22   * Fixed a number of bugs in the validation of Range requests.  Thanks to
23     Ken Brazier.
24   * Inhibited range requests for non-200 instances, as this breaks some
25     client software.  Thanks to Ken Brazier.
26   * Fix a integer overflow in processing client requests.
27   * Implement authentication on tunnelled connections.  Thanks to
28     Stephen Dolan.
29   * Implement ability to include Cache-Control: no-transform in all
30     requests.  Thanks to Nick Osborn.
31   * Fix a bug in the DNS code that would cause us to ignore CNAMES
32     after a DNS timeout.
33   * Fixed a crash that occurs when a server sends a malformed
34     Cache-Control: header (CVE-2009-3305). Thanks to Stefan Fritsch.
35   * Removed support for read-only caches.  Nobody ever used it.
36   * Changed the default value of diskCacheWriteoutOnClose to 64kB.
37   * Cleaned up naming of Windows support functions. Thanks to Honglei Jiang.
38   * Added support for forbidden tunnels (thanks to Richard Zidlicky).
39   * Fixed a bug that prevented parsing of extremely long literal IPv6
40     addresses (thanks to Jan Braun).
41   * Added support for DOS-style absolute pathnames.  Thanks to Gisle Vanem.
42   * Fixed a bug that could cause infinite revalidation loops.  Thanks to
43     David Rothlisberger.
44   * Fixed a bug that could provide incorrect caching information to clients.
45     Thanks to William Manley.
46   * Support MSVC 2010.  Thanks to Greg Hazel.
47   * Work-around buggy clients that send HTTP:// in uppercase.  Thanks
48     to David Rothlisberger.
49   * Save Cache-Control values to the disk cache.  Thanks to Ruben Alleres.
50   * Allow ~ in logFile.  Thanks to P.J. Hades.
51   * Fixed a bug that could cause infinite revalidation loops with servers
52     that perform sloppy packetisation (IIS, I'm looking at you).
53   * Fail expectations on the local interface.  This might or might not be
54     what CVE-2011-3596 is about, difficult to say since nobody is speaking
55     to me.
56
57 31 January 2010: Polipo 1.0.4.1:
58
59   Cherry-picked fixes from 1.0.5.  Thanks to Julien Cristau.
60
61   * Fixed an integer overflow that may lead to a crash
62     (http://secunia.com/advisories/37607/). Discovered by Jeremy Brown.
63     (CVE-2009-4413)
64   * Fixed a crash that occurs when a server sends a malformed
65     Cache-Control: header (CVE-2009-3305). Patch from Stefan Fritsch.
66   * Prevent an infinite loop when a bodyless 204 or 1xx response is encountered
67   * Don't crash when we get an error while waiting for 100 continue status.
68
69 8 January 2008: Polipo 1.0.4:
70
71   * Fixed the handling of tunnels with a parent proxy (thanks to
72     Richard ┼áputa).
73   * Fixed a bug that could cause connections to be shut down when
74     a server used the old (RFC 2068) semantics of ``100 Continue''
75     (thanks to Thomas Wiesel).
76   * Fixed a crash when a request URL was larger than 10 kB (thanks to
77     Fabian Keil).
78   * Fixed a possible failure to read client requests larger than one
79     chunk.
80
81 6 October 2007: Polipo 1.0.3
82
83   * Changed the default for chunkMemory: it is now 24 MB or
84     one-quarter of physical memory, whichever is smaller.
85   * Support for logging to syslog (thanks to Nix).
86   * Made atom reference counts 32-bit longs; this should fix
87     problems that people were seeing when running Polipo with
88     humongous in-memory caches.
89   * Added Git, Jabber and CVS to default tunnelAllowedPorts.
90   * Fixed a bug that could cause URL matching to fail when using
91     anchored regular expressions (thanks to phuel).
92
93 26 August 2007: Polipo 1.0.2:
94
95   * Fixed a crash that could happen with entities more than 2GB in
96     size.  Such entities are still not supported, but Polipo
97     should no longer crash.
98   * Minor HTTP compliance fixes, due to testing with Co-Advisor.
99   * Fixed a crash that would happen when a POST request was aborted
100     by the server.  Reported by Tero Pelander.
101   * Worked around a DNS-related bug that I'm unable to track down,
102     waiting for a proper fix.
103
104 25 June 2007: Polipo 1.0.1:
105
106   * Made Polipo slightly more aggressive when speaking to
107     HTTP/1.0 servers (thanks to Fabian Keil for noticing that).
108   * Fixed a crash that would happen when a client used
109     Cache-Control: only-if-cached, and the object was not in cache.
110     (Reported by F. Zappa, A. Patala and V. Ghosal.)
111   * Fixed a descriptor leak when running under Windows.
112   * Made Polipo optionally drop connections after servicing
113     a number of connections (maxConnectionAge and maxConnectionRequests).
114
115 6 March 2007: Polipo 1.0.0
116
117   * No changes since 0.9.99.2.
118
119 7 February 2007: Polipo 0.9.99.2
120
121   * Fixed a buffer overflow in urlDirname (the 0.9 branch is not
122     vulnerable) (reported by J. P. Larocque).
123   * Implemented use of IPv6 temporary source addresses (Frank Behrens).
124   * Disabled use of unaligned range requests by default.  This is
125     controlled by the variable allowUnalignedRangeRequests (reported
126     by Chris Moore).
127   * Fixed descriptor leaks in SOCKS error handling (reported by
128     Roger Dingledine).
129   * Implemented maxSideBuffering.
130
131 6 February 2007: Polipo 0.9.12
132
133   * Fixed incorrect caching of redirects (reported by Lawrence Lu).
134   * Fixed a possible hang when falling back to gethostbyname
135     (reported by Chris Moore).
136
137 28 December 2006: Polipo 0.9.99.1
138
139   * Validation improvements and bug fixes.
140   * Don't use cached data when receiving the output from an HTTP/1.0 CGI.
141   * Allowed tunnelling of IMAP and POP traffic by default.
142   * Changed the disk cache expiry and indexing functions to use chunks.
143   * Made the disk cache unreadable by others by default.
144   * Fixed a bug that could cause stale data to be served after
145     a connection failure (reported by Hondza).
146   * Fixed computation of age and rtt for pipelined requests.
147   * Fixed incorrect cachability of redirects (reported by J.-P. Larocque).
148   * Fixed a bug that would cause uncachable objects to become
149     cachable after being reloaded from the on-disk cache (reported
150     by J.-P. Larocque).
151   * Implemented dontTrustVaryETag.
152
153 7 December 2006: Polipo 0.9.11
154
155   * Fixed a crash that could happen when a network interface went down
156     while a DNS query was in progress (reported by Francesco Zappa).
157
158 20 November 2006: Polipo 0.9.99.0:
159
160   * Implemented large buffers for headers larger than a chunk's worth.
161   * Made the HTTP parser lax by default (ignores unknown headers).
162   * Implemented the infrastructure for local POST requests and
163     implemented a real configuration interface (thanks to Theo Honohan).
164   * Made timeouts user-configurable and enforced an invariant between
165     timeouts.
166   * Made logging configurable at runtime (thanks to Frank Behrens).
167   * Implemented the infrastructure for asynchronous handling of 
168     forbidden URLs.
169   * Implemented the ability to redirect instead of returning an
170     error for forbidden URLs.
171   * Implemented support for Squid-style redirectors.
172   * Implemented User-configurable uncacheable URLs, analogous to
173     forbidden URLs (thanks to Joachim Haga).
174   * Implemented the ability to avoid caching pages with cookies
175     and redirects.
176   * Implemented maxPipelineTrain, which can be used to moderate
177   * Polipo's eagerness to pipeline.
178   * Unified parentHost and parentPort into parentProxy.
179   * Ported Polipo to native Windows (thanks to Dan Kennedy).
180   * Implemented disableVia.
181   * Implemented SOCKS support.
182   * Made disableVia and cacheIsShared to be true by default.
183   * Increased the default value of serverMaxSlots to 8.
184   * Made the disk cache code quote all characters except for a
185     small number of ``known safe'' ones.  This is an incompatible
186     change to the on-disk format.
187   * Changed HTTP parser to pass all Pragma headers to the next
188     hop; this should make some media players work through Polipo.
189   * Changed the connection scheduler to avoid pipelining when
190     there are idle connections to a given server.
191   * Made Polipo obey parentProxy when tunnelling (proxying https).
192   * Changed the default value of allowedPorts to be slightly more
193     permissive.
194   * Implemented tweakables for selectively disabling parts of the
195     configuration interface.  Indexing and listing known servers
196     are now disabled by default.
197   * Hide variables containing passwords.
198   * Fixed a bug that could cause incorrect validation when speaking
199     to an HTTP/1.0 server.
200   * Fixed a bug that could cause incorrect validation of Vary objects.
201   * Fixed a crash in the redirector code.
202   * Made disableVia the default, and changed the default value of idleTime.
203   * Made polipo delay serving of partial objects until after a
204     a successful validation.  This should fix Mozilla's prefetching.
205   * On 64-bit platforms, made CHUNK_SIZE default to 8kB.
206
207 2 September 2006: Polipo 0.9.10:
208
209   * Fixed a crash when a client closes a connection at just the
210     wrong time.
211   * Fixed a crash that could happen when a server returned incorrect
212     headers and closed the connection at just the wrong time.
213   * Fixed restarting of connections on a server-side read error;
214     this should avoid the ``connection reset by peer'' problem.
215   * Corrected work-around for DNS servers that export both AAAA and CNAME.
216   * Fix incorrect error handling when overflowing the buffer when saving
217     an entity to disk.
218   * IPv6 tweaks for OpenBSD (thanks to Jun-ichiro itojun Hagino).
219   * Fixed incorrect error-handling on failure to parse a date.
220   * Fixed a deadlock when a tunnel is shut down and the buffer is
221     full.
222   * Fixed an incorrect use of va_start (guaranteed crash on AMD64).
223   * Fixed a possible race condition with a heavily pipelining client.
224   * Fixed a crash due to incorrect handling of write errors in POST.
225
226 23 September 2005: Polipo 0.9.9:
227
228   * Fixed a bug that could cause objects to be incorrectly
229     determined to be dynamic (thanks to Joachim B. Haga).
230   * Fixed a bug that could cause the local web server to expose
231     files that are not under the local root (thanks to Wessel
232     Dankers).
233   * Fixed an off-by-one bug when parsing NL-terminated headers.
234   * Made Polipo forget about failures when finishing on the client side.
235   * Polipo now sends Host headers even when speaking to an upstream
236     proxy.  Some proxies take RFC 2616 literally, and require that
237     (thanks to Zoltan Ivanfi).
238   * Fixed some bugs in staleness computation, and implemented
239     server-side max-age directives (oops!) (thanks to Charley Chu).
240
241 24 January 2005: Polipo 0.9.8:
242
243   * Backported the lax HTTP parser from the head branch.
244   * Fixed a race condition that could cause a crash if a single
245     object was being superseded twice at the same time.
246   * Fixed an incorrect test that caused Polipo to pipeline to all
247     HTTP/1.1 servers, even when they were determined as broken (thanks
248     to Daniel Koukola).
249   * Implemented maxPipelineTrain.
250   * Tweaked for uclibc (thanks to Detlef Riekenberg).
251
252 27 December 2004: Polipo 0.9.7:
253
254   * Fixed a possible crash when tunnelling.
255   * Fixed spurious updates of object sizes when connection is dropped
256     by the client.
257   * Fixed parsing of URLs with explicit port number (thanks to
258     Frank Behrens).
259   * Fixed a possible crash when exiting POST in error.
260   * Fixed a protocol violation when an empty object is not superseded.
261
262 31 October 2004: Polipo 0.9.6:
263   * Fixed a possible crash in ServeObject.
264   * Fixed two possible crashes when relaxTransparency is not false.
265   * Modified the config file parser to make it possible to have
266     backslashes in atoms.
267   * Fixed a violated invariant (leading to a crash) when superseding
268     objects.
269   * Fixed a possible crash in ClientFinish when a pipelined request
270     carries no object.
271   * Fixed a bug in handling of client-side Expect: 100-continue
272     (reported by Charley Chu).
273   * Fixed a scheduling bug that caused server-side requests to be
274     issued in the order opposite to a client-side pipeline (many
275     thanks to Joachim Haga).
276   * Abort when the config file couldn't be parsed (thanks to
277     Joachim Haga).
278   * Fixed error handling in POST and PUT requests, which could
279     cause a crash on an I/O error.
280
281 17 June 2004: Polipo 0.9.5:
282   * Implemented upstream proxy authentication (HTTP Basic only).
283   * Fixed a possible crash when unable to schedule servicing a request.
284   * Fixed a possible crash when tunnelling (proxying https).
285   * Fixed signedness issues to make allowedClients work on PPC
286     (from Gergely Nagy).
287
288 10 May 2004: Polipo 0.9.4:
289   * Fixed a bug (introduced in 0.9.3) that could cause a crash when
290     the download of an object was interrupted and then immediately restarted.
291   * Fixed a bug that could cause stale non-200 replies to be served.
292   * Fixed compilation on FreeBSD 5.2.1 (from Samuel Tardieu).
293   * Fixed definition of *_ROOT in diskcache.c
294
295 6 April 2004: Polipo 0.9.3:
296   * Fix incorrect handling of EPIPE when tunnelling; this could cause
297     crashes if a peer closed a connection when we're writing.
298   * Fix a race condition that could cause ``error message lost in transit''
299     errors if a request was cancelled during connect.
300   * Check for exitFlag in workToDo: faster reaction to signals.
301
302 28 March 2004: Polipo 0.9.2:
303   * Fixed a bug that could cause crashes when writing out small
304     objects (thanks to Frank Behrens).
305   * Made buffer allocation in httpParseHeaders dynamic.
306   * Fixed the declaration of pipelineAdditionalRequests.
307   * Fixed a bug that could cause empty directories to be missed
308     when expiring the disk cache.
309   * Switched the forbidden file to use extended regexps, the
310     previous usage was non-portable (thanks to Frank Behrens).
311
312 9 March 2004: Polipo 0.9.1:
313   * Fixed a bug that could cause chunked encoding failures when
314     going from a 1.0 server to a 1.1 client.
315   * Fixed a bug that prevented comments after some config lines
316     (thanks to Tom Huckstep).
317   * Fixed a possible buffer overflow in dnsDecodeReply.
318   * Fixed portability to systems where rmdir returns EEXIST
319     instead of ENOTEMPTY.
320   * Fixed error handling on fork failures in fillSpecialObject.
321   * Fixed handling of EINTR in wait in specialRequestHandler.
322   * Fixed a bug that caused objects with no headers to fail.
323   * Fixed a minor memory leak in the config file parser.
324   * Minor build fixes for NetBSD.
325   * Added the 68020 and later to the list of architectures that
326     support unaligned access.
327
328 18 February 2004: Polipo 0.9:
329   * Reworked the DNS code to parse ids even when a reply's qdcount
330     is 0.  No longer falls back to gethostbyname when DNS server
331     returns FormErr.
332   * Made the DNS code parse resolv.conf.
333
334 11 Feburary 2004: Polipo 0.8.99.3:
335   * Minor changes to work around Cygwin mis-design.
336   * Fixed printing of n-state variables.
337   * Fixed proxyOffline handling.
338   * Fixed a bug that would cause errors to be reported with the
339     wrong content-type.
340   * Fixed a bug that would cause ``object vanished'' errors when
341     using HEAD for revalidation.
342   * Fixed a bug that could cause failed requests due to ``client
343     reset connection'' errors.
344
345 24 January 2004: Polipo 0.8.99.2:
346   * Cleaned up authentication.
347   * Made authenticated replies cachable in one of the cases allowed
348     by RFC 2616.
349   * Fixed a bug that could, under some circumstances, cause a
350     password-protected object to be cached and returned to a
351     non-authorized client.
352   * Implemented 100-continue, controlled by the variable expectContinue.
353   * Implemented tristate, 4- and 5-state variables.  Split
354     proxyOffline into proxyOffline and relaxTransparency.  This is
355     an incompatible change to the config file format.
356   * Cleaned up the handling of allowed port ranges.  New
357     configuration variable allowedPorts (and new type intlist).
358   * Implemented tunnelling through the CONNECT method (https proxying).
359   * Will now read a request body on error (avoids a deadlock).
360   * Reworked the PUT/POST code to read the reply eagerly rather
361     than waiting for the write to finish (avoids writing the full
362     body on error and avoids the same deadlock as above).
363   * Made server addresses sticky: will now remember which of a
364     servers addresses worked last time, and use that address first.
365
366 16 january 2004: Polipo 0.8.99.1:
367   * Fixed an expiry bug that caused DNS queries to be repeated on
368     each request.
369   * Added the variable ``preciseExpiry'' that prevents trusting
370     the mtime during expiry.
371
372 14 January 2004: Polipo 0.8.99.0:
373   * Implemented IP address-based authentication.
374   * Implemented HTTP ``basic'' authentication.
375   * Implemented variable body offsets for the on-disk cache; this
376     makes the on-disk cache format incompatible with previous versions.
377   * Made the number of server slots configurable.
378   * Partially rewrote the disk cache code.
379   * Fixed a file descriptor leak in the early error handling code.
380   * Fixed a bug in the base64 encoder; this makes the on-disk cache
381     format incompatible with previous versions.
382   * Implemented proper reporting for 100-Continue replies
383     (100-Continue is not implemented yet).
384   * Made the number of server slots configurable at runtime.
385
386 9 January 2004: Polipo 0.8.4:
387   * Log file is now line buffered.
388   * Will reopen the log file on SIGUSR1 and SIGUSR2.
389   * censoredHeaders now defaults to none, and censorReferer to 0.
390   * Fixed a memory allocation bug that could cause a crash.
391
392 21 December 2003: Polipo 0.8.3:
393   * Fixed a potential buffer overflow on C89 systems in snnprintf.
394   * Fixed checking of Via headers.
395   * Added configurable log file.
396   * Added code to run as a daemon.
397   * Made the resolver grok names ending in a ``.''.
398   * Changed Makefile to fit Debian better.
399
400 7 December 2003: Polipo 0.8.2:
401   * Implemented a version of fts for SVR4 systems.
402   * Implemented a version of mktime_gmt that doesn't use setenv.
403   * Fixed code used to determine FQDN.
404   * More unaligned access fixes.
405   * Disabled queryIPv6 when there is no IPv6 support in kernel.
406   * Enabled IPv6 support by default on FreeBSD and NetBSD.
407
408 2 December 2003: Polipo 0.8.1:
409
410   * Fix a possible crash when doing a POST on a busy server.
411   * Fix a possible crash when socket(2) fails; implement switching
412     to a different address when socket(2) fails (e.g. when
413     accessing a double-stack host from an IPv4-only client).
414   * Fix a problem with servers stuck in the ``probing'' state.
415   * Work around a bug in Konqueror that strips question marks from
416     URLs.
417   * Fix incorrect error handling when dealing with connection
418     failures.
419   * Fix a compile problem in dns.c.
420   * Remove dependency on SSL, include MD5 code instead.
421   * Fix signedness of s_maxage.
422
423 23 November 2003: Polipo 0.8:
424
425   * IPv6 support, on both the client and server side, including
426     DNS support and RFC 2732.
427   * Reworked the DNS code.
428   * Made it possible to compile without any particular resolver
429     and without the on-disk cache.
430   * Fixed a problem with the chunking encoder.
431   * Made the config file parser grok octal and hex values, allowed
432     colons and tildes in unquoted strings.
433   * Implemented tilde expansion in some config variables.
434   * Made Polipo slightly less eager to honour range requests for
435     dynamic instances.  Marked generated objects as dynamic. These
436     changes should solve some of the problems with PMM.
437   * Implemented the If-Range header (on both the client and server side).
438   * Implemented support for range requests smaller than one chunk
439     (and hence for pmmSize being smaller than CHUNK_SIZE).
440   * Fixed a bug that caused a deadlock (until a server timeout)
441     when doing a POST/PUT request with no free connection slots.
442   * Fixed a problem when diskCacheRoot didn't end in `/'.
443   * Fixed a refcounting problem that could cause Polipo to crash
444     on a DNS timeout.
445   * Fixed an alignment problem that could cause crashes on 
446     architectures that don't like unaligned memory accesses
447     (thanks to Rob Byrnes).
448   * Fixed a bug with the disk cache that caused spurious ``disk
449     entry changed behind our back'' warnings (and in principle
450     could cause data corruption, although that's very unlikely).
451   * Made opening connections slightly less aggressive -- Polipo
452     would sometimes open two connections where only one was needed.
453   * Modified client-side code to notice client shutdowns earlier
454     and notify the server side straight away.
455
456 7 October 2003: Polipo 0.7
457
458   * Made the Request function a method of objects.
459   * Fixed a bug that could sometimes cause data corruption.
460   * Fixed a bug that could cause sending of incorrect data to
461     the client on a range request.
462   * Fixed POST and PUT requests.
463   * Fixed a bug that could sometimes cause a POST request to use a
464     stale connection.
465   * Included code to do poor man's multiplexing.
466   * Will now open multiple connections to non-persistent servers.
467   * Fixed a bug that could lead to idle connections dying without
468     being noticed.
469   * Fixed probing for pipelining.
470   * Actually use the new time function introduced in 0.5.
471   * Fixed a bug in strcasecmp_n.
472   * forbiddenFile can now be a directory.
473
474 26 September 2003: Polipo 0.6
475
476   * Fixed precondition handling.
477   * Fixed a bug that could lead to lockups when revalidating an object.
478
479 27 June 2003: Polipo 0.5
480
481   * Made the presence of a reader or writer explicit on the client side.
482   * Reworked closing client connections.
483   * Reworked reporting of server-side errors.
484   * Made buffer allocation lazy; idle clients and servers no longer
485     use up buffers.
486   * Reworked UTC time handling to use timegm(3) when available.
487
488 12 March 2003: Polipo 0.4
489
490   * Implemented expiry of the on-disk cache.
491   * Implemented reliable aborting of connections; Polipo should no
492   * longer deadlock when a server falls into a black hole.
493   * Changed direct reads to be more aggressive by using readv in
494     three pieces.
495   * Changed serving of chunked data to be more eager about
496     serving a chunk's end marker.
497   * Implemented better reporting of DNS errors.
498   * Fixed a deadlock with pipelining on the client side.
499   * Removed most of the remaining copies when reading on the
500   * server side.
501   * Fixed a bug that caused some headers to disappear in transit.
502   * Fixed a possible livelock when reading chunked encoding.
503   * Fixed an overflow when pipelining on the server side.
504   * Fixed generation of indexes from the on-disk cache.
505   * Fixed a DNS crash when falling back on gethostbyname.
506
507 1 March 2003: Polipo 0.3
508
509   * Implemented retrying of timed-out DNS requests.
510   * Implemented configuration mechanisms for case-insensitive atoms,
511     time values and atom lists; censoredHeaders can now be configured.
512   * No longer censors User-Agent.  Blame Beppe and Alain.
513   * Changed the handling of hop-by-hop HTTP headers to deal with multiple
514     Connection headers.
515   * Made client-side errors and successful revalidation no longer
516     close the connection.
517   * Fixed a bug that caused the allocation of an extraneous 2MB (!)
518     at startup.  Polipo can run in 100KB once again.
519   * Fixed a refcounting bug and some incorrect frees that could
520     lead to crashes when recovering from a server-side error.
521   * Fixed a bug with POST/PUT that could trigger a failed assertion.
522   * Made sure that POST/PUT don't get scheduled in multiple pieces.
523
524 17 February 2003: Polipo 0.2
525
526   * Fixed an incorrect assertion that could cause crashes when the
527     server is fast.
528   * Fixed (hopefully) logic for 304 replies.
529   * Minor tweaks to scheduling that cause some speed increase when the
530     client is pipelining and the server is fast.
531   * Minor bug fixes and cleanups.
532   * Macro-ified do_log and friends.
533
534 3 February 2003: Polipo 0.1
535
536   * Initial public release.