8ebd6b09f19d4af2bd5c3565eedcf703bb64cf70
[mmh] / ChangeLog
1 2005-11-08  Oliver Kiddle  <okiddle@yahoo.co.uk>
2
3         * bug #10230: etc/Makefile.in, man/Makefile.in, uip/Makefile.in:
4         Michael De La Rue: prepend DESTDIR to install locations
5
6         * configure.in, */Makefile.in, mts/smtp/smtp.c: replace obsolete
7         autoconf macros
8
9 2005-11-06  Peter Maydell  <pmaydell@chiark.greenend.org.uk>
10
11         * sbr/fmt_rfc2047.c, sbr/fmt_scan.c, h/prototypes.h: fix various
12         possible overruns of the buffers in fmt_scan() which would cause
13         crashes if scan was run with '-width 16536' or similar.
14
15         * uip/popsbr.c: fix compile error which only showed up if nmh
16         was configured with --enable-apop.
17
18         * Debian Bug# 245932, RedHat Bug# 172388: uip/mhparse.c: don't
19         crash when handling a multipart MIME message with an invalid
20         Content-Type header (file handle was being fclose()d twice).
21
22         * sbr/Makefile.in: adjust lex command to work on both old and
23         new versions of flex.
24
25         * configure.in: add an AC_PREREQ() so autoconf 2.13 gives a helpful
26         error message and the Debian autoconf-version-guessing wrapper
27         doesn't guess wrongly.
28
29 2005-11-02  Oliver Kiddle  <okiddle@yahoo.co.uk>
30
31         * Debian Bug# 320069: Nick Rusnov: uip/popsbr.c: fail when
32         kpop connection attempted without KPOP support compiled in
33
34         * Debian Bug# 320090: Nick Rusnov: sbr/Makefile.in: fix for newer
35         version of flex and remove autogenerated file from cvs
36
37         * patch #1155: uip/flist.c: speed up flist by skipping stat on
38         files with numbers as names
39
40         * docs/Makefile.in: include new files in distribution
41
42 2005-10-11  Bill Wohler  <wohler@newt.com>
43
44         * docs/FAQ: fold questions into MH FAQ and distribute that instead
45
46 2005-10-05  Oliver Kiddle  <okiddle@yahoo.co.uk>
47
48         * Harald Geyer: h/mh.h, uip/replsbr.c: back out previous change
49         (fork/vfork) and replace with code that handles the issue directly
50
51 2005-05-18  Oliver Kiddle  <okiddle@yahoo.co.uk>
52
53         * Debian Bug# 143485: Nick Rusnov: h/mh.h: use fork instead of
54         vfork on Linux
55
56         * Debian Bug# 261592: Harald Geyer: uip/mhlsbr.c, uip/replsbr.c:
57         test/report error writing to stdout
58
59         * mts/smtp/smtp.c, uip/popsbr.c: correct SASL include file locations
60
61         * docs/COMPLETION-BASH: bash completion definitions from Debian
62
63         * patch #2863: savannah@brisammon.fastmail.fm: sbr/folder_read.c:
64         fix a bug affecting AFS where nmh was setting the READONLY flag
65         for a folder even when you do have write access to the folder
66
67         * Carl Mummert: h/fmt_compile.h, man/mh-format.man,
68         sbr/fmt_compile.c, sbr/fmt_scan.c: add unquote() function for
69         removing quotes from RFC-2822 encoded headers
70
71 2005-02-23  Oliver Kiddle  <okiddle@yahoo.co.uk>
72
73         * use iconv to convert RFC-2047 encoded headers to the
74         character set used by the current locale
75
76         * sbr/folder_read.c fix Debian bug #202667: crash when a
77         message's filename overflows an int when converted
78
79         * Updated config.guess and config.sub to the most recent
80         versions (from automake 1.9.5)
81
82 2005-02-21  Oliver Kiddle  <okiddle@yahoo.co.uk>
83
84         * sbr/getpass.c fix bug where inc crashed on failing to reopen
85         the terminal
86
87 2005-01-27  Oliver Kiddle  <okiddle@yahoo.co.uk>
88
89         * Added -proxy option to inc and msgchk. Based on old patch
90         from Michael Richardson.
91
92         * On systems where it is available, use nl_langinfo to get the
93         character set if MM_CHARSET is unset
94
95 2005-01-21  Oliver Kiddle  <okiddle@yahoo.co.uk>
96
97         * sbr/check_charset.c US-ASCII is a subset of UTF-8 so can be
98         handled directly when UTF-8 is being used
99
100 2004-12-17  Oliver Kiddle  <okiddle@yahoo.co.uk>
101
102         * uip/mhmisc.c Fix -part option to mhshow/mhlist/mhstore to
103         find sub-parts of the specified part
104
105 2004-11-19  Jon Steinhart  <jon@fourwinds.com>
106
107         * h/prototypes.h, sbr/folder_addmsg.c, uip/mhstoresbr.c,
108         uip/rcvstore.c, uip/refile.c: Added mail directory argument to
109         folder_addmsg in order to make it possible to provide a path to
110         the ext_hook call that is mailpath-based.  A problem existed when
111         a folder was a symbolic link and the pwd call would return the
112         path relative to the filesystem, not to mailpath.  A new argument
113         was needed because there was otherwise no reasonable way to get
114         that path.
115
116 2004-11-16  Jon Steinhart  <jon@fourwinds.com>
117
118         * sbr/folder_pack.c: Fixed problem where the refile hook was being
119         called after a message was renamed so that it wasn't around for
120         the hook.  The hook is now called before the message file is
121         renamed.
122
123         * sbr/folder_addmsg.c: Fixed wrong directory for hook when
124         refiling with -src option.
125
126 2004-10-15  Jon Steinhart  <jon@fourwinds.com>
127
128         * uip/sortm.c: Fixed calling of external hooks.
129
130 2004-10-12  Jon Steinhart  <jon@fourwinds.com>
131
132         * uip/inc.c: Fixed another weird bug caused by the static
133         mailpath being overwritten.
134
135         * uip/sendsbr.c: Fixed bug that caused anno to mangle headers.
136
137         * sbr/lock_file.c: Fixed strange bug that prevented a lock from
138         ever being obtained if getting it failed the first time.  The
139         problem was that the string of XXXXXX that is required by
140         mkstemp() was overwritten the first time through, and so all
141         subsequent times failed because mkstemp() failed.  The fix
142         reinitializes the tmp file string.
143
144         * uip/inc.c: Fixed bug in which the static maildir was overwritted
145         if a format string was read from the profile.
146
147         * sbr/folder_delmsgs.c: Fixed bug that was producing an incorrect
148         path for the external hook.
149
150 2003-10-06  Glenn Burkhardt <glenn@aoi-industries.com>
151
152         * uip/slocal.c, configure.in: db configuration fix for Debian; yet
153           another location for ndbm.
154
155 2003-09-30  Glenn Burkhardt <glenn@aoi-industries.com>
156
157         * Fix 'pick' so handling of options "-list" and "-seq" are
158         independent.
159         * Fix 'inc' realloc error when bringing in more than 100 msgs
160         to empty folder.
161         * Patches submitted by Nick Rusnov from Debian archive applied:
162
163         Debian Bug#
164            136976 - Handle binary content messages
165            143427 - mh-format.man typo
166            144098 - 'spost; should have same behavior as 'post'
167                     w.r.t. mts.conf masquerade line
168            149745 - slocal ignores 'N' result of previous command
169            152728 - increase SMTP timeouts to conform to RFC 1123
170                     The timeouts suggested by the RFC seem long
171                     to me - but the RFC is still listed as active.
172            181867 - typo for nmh.man
173         
174 2003-08-10  Jeffrey C Honig  <jch@honig.net>
175
176         * Fix problem where parsing of address/date fields in fmt_compile
177         is optimized to the first instance.  The first instance may be in
178         contitional code which will result in cached data to
179         be used.  Instead, convert c_flags to a flags field from a boolean
180         and parse on the first use.
181         * Remove some unused flag bits.
182
183 Fri Jul 01 22:02:00 2003 Glenn Burkhardt <glenn@aoi-industries.com>
184
185         * Applied fixes for configuration problems with Solaris and
186           systems with gdbm instead of db1 (includes bug #2024)
187         * Fixes for bugs 
188           #578  - repl leaks umask 
189           #1393 - sortm core dumps 
190           #1650 - msh leaks file descriptors
191           #1730 - Double free() in mhfree.c:free_encoding()
192           #3356 - In-Reply-To header in default replcomps should be 
193                   RFC2822 compliant 
194         * Revised man page for mh-format (bug #2031)
195         * New replcomps, etc, with Fcc: +outbox in default versions
196         
197 Sat Mar 17 03:18:15 2001 Dan Harkless <dan-nmh@dilvish.speed.net>
198
199         * Ken Hornstein's configure.in Cyrus SASL checks were doing 
200         `x"$with_cyrus_sasl" != "no"' instead of `... != x"no"'.
201
202 Tue Mar 06 21:04:27 2001 Dan Harkless <dan-nmh@dilvish.speed.net>
203
204         * Found some historical information about MH in RFC 808.
205         Supplemented it with info from Jerry Peek's MH book and added it
206         to docs/README.about.
207
208 Tue Feb 6 20:35:40 2001 Shantonu Sen <ssen@mit.edu>
209
210         * sbr/dtime.c Use the same Y2K correction code as dtimep.lex
211
212         * sbr/dtimep.lex Restrict the parser to accept either
213         a numerical timezone offset, or a symbolic one (e.g. EST),
214         but not both (Since "2000 -400 EDT" might cause a double
215         subtraction of 60 minutes if both are parsed. One should be
216         enough).
217
218 Mon Feb 05 20:22:54 2001 Dan Harkless <dan-nmh@dilvish.speed.net>
219
220         * -L isn't sufficient for specifying the path of the Cyrus SASL
221         shared library.  That'll allow us to link successfully, but on
222         many/most OSes that won't allow us to find libsasl at runtime.  On
223         Solaris, we need to specify the library path with -R as well (or
224         else the user will have to use the $LD_LIBRARY_PATH kludge, which
225         is considered harmful).  This fix should be extended to other OSes
226         as well.
227
228         * Print whether we have SASL support in the "nmh configuration"
229         summary configure prints out.
230
231         * Say in README.developers to use `\date' in case anyone is like
232         me and has `date' aliased in their shell to use a nonstandard (but
233         subjectively more readable) format.
234
235 Thu Jan 25 21:15:52 2001 Shantonu Sen <ssen@mit.edu>
236
237         * man/mh-chart.man has updated synposes of
238         all nmh commands.
239
240 Tue Jan 23 20:26:15 2001 Shantonu Sen <ssen@mit.edu>
241
242         * etc/digestcomps tried to force dates into a
243         19xx when it's not necessary.
244         
245 Fri Jan 19 21:22:08 2001 Shantonu Sen <ssen@mit.edu>
246
247         * First round of manpage updates finished. They
248         are standardized on -man macros, with minimal
249         roff mark-up.
250
251         * man/tmac.h.in is no longer needed, since the
252         manpages do not depend on them anymore. Note:
253         strict "man" programs that didn't allow ".so"
254         sourcing outside the man tree will now format
255         the man pages correctly.
256
257         * man/vmh.1 is no longer built, since uip/vmh isn't
258         
259 Tue Jan 9 6:01:22 2001 Shantonu Sen <ssen@mit.edu>
260
261         * Finished manpages ali-prev
262
263         * Removed deprecated files from the repository.
264         Specifically, those rooted in zotnet/ and mts/sendmail
265         mts/mmdf. "cvs update -dP" will give a pruned directory
266         structure.
267
268         * Updated docs/Makefile.in to include README.manpages, and
269         uip/Makefile.in to include popi.c (which isn't being built,
270         though). This allows "make nmhdist" to create an archive that
271         is file-for-file identical to the current cvs repository.
272
273 Sun Dec 31 20:48:50 2000 Shantonu Sen <ssen@mit.edu>
274
275         * Create docs/README.manpages, which details
276         the formatting rules I've been using.
277
278         * Finished ali-inc.
279         
280 Sat Dec 30 9:50:13 2000 Shantonu Sen <ssen@mit.edu>
281
282         * Created a new file "DATE" to hold the date
283         of the most recent nmh release. This date will be
284         used in the manpages.
285
286         * Updated docs/README.developers to add the step
287         of updating DATE. Also, updated configure to
288         read in the contents of the file as the variable
289         $DATE.
290
291         * Started work on updating man pages, with only
292         ali finished so far. Changes: 1) no dependence
293         on an external macro file, 2) uses only
294         -man macros (although I may be mistaken in this),
295         3) syntax in the SYNOPSIS is a little more
296         in line with standard UNIX documentation, such as
297         bold flags and italicized parameters.
298
299 Sun Dec 24 10:06:30 2000 Shantonu Sen <ssen@mit.edu>
300
301         * Updated INSTALL with information about the
302         --with-locking option.
303
304         * Fixed the Hesiod tests in configure.in. In
305         systems where res_send was in -lresolv, this
306         information was not being communicated to the
307         HESIOD_LIBS var. Now, if res_send is not found
308         in the default libraries, it's assumed to be
309         in -lresolv, and thus -lresolv is appended to
310         HESIOD_LIBS, which will need that to avoid
311         undefined symbols problems.
312
313         * Fixed the Kerberos tests in configure.in. New
314         versions of Kerberos 5 have renamed -lcrypto
315         to -lk5crypto (circa krb5 1.1 or thereabouts). The
316         new test tries to determine if -lk5crypto exists. If so,
317         this is a new krb5 system. If not, test for -lcrypto
318         and the rest of old krb5. If that fails, look
319         for a genuine krb4 installation.
320         
321 Fri Dec 22 22:08:51 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
322
323         * -apop and -noapop were not documented in msgchk.man.
324         -snoop was documented but didn't appear in the usage SYNOPSIS.
325
326 Fri Dec 22 23:42:16 2000 Shantonu Sen <ssen@mit.edu>
327
328         * Made a new ./configure option called
329         "--with-locking" that allows the file
330         locking mechanism to be chosen there instead of
331         requiring a manual edit of config.h.
332
333         * If the option is not explicitly set, or an
334         invalid option is specified, "dot" locking is
335         chosen. Valid options are "dot", "fcntl",
336         "flock", and "lockf". We need a way to tell
337         the user that these are the valid options, and
338         change the flag "--with-locking" if it's not
339         descriptive enough.
340
341 Fri Dec 22 19:21:29 2000 Shantonu Sen <ssen@mit.edu>
342
343         * Remove the lex-specific memory hints at the
344         beginning of sbr/dtimep.lex. We've already
345         committed to supporting flex only, since
346         lex does not easily allow us to parse a single
347         string, as well as other problems documented
348         below and on nmh-workers.
349
350         * Added a switch statement to configure.in to
351         test for Mac OS X. If this is the case, LDFLAGS
352         should not contain "-s" since the linker rejects
353         the flag.
354
355         * Updated MACHINES to include Mac OS X Public Beta,
356         as well as Linux 2.4 running glibc 2.2.
357
358 Wed Dec 20 16:00:46 2000 Shantonu Sen <ssen@mit.edu>
359
360         * Marked deprecated directories in docs/README.developers
361         as deprecated, with pointers to the new code location.
362         Eventually these deprecated directories should go away.
363
364 Tue Dec 19 19:16:37 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
365
366         * -apop and -noapop were not documented in inc.man.  -snoop was
367         documented but didn't appear in the usage SYNOPSIS.
368
369 Thu Dec 14 14:32:09 2000 Shantonu Sen <ssen@mit.edu>
370
371         * Updated config.guess and config.sub to the most recent
372         versions on ftp://ftp.gnu.org/pub/gnu/config, dated
373         12-07-00. This should prevent configure from failing
374         on newer operating systems because config.{guess,sub}
375         couldn't correctly identify them.
376
377 Thu Dec 14 1:30:44 2000 Shantonu Sen <ssen@mit.edu>
378
379         * Fixed the circular dependency created when I moved
380         zotnet/mts to mts/generic and merged them into libmts.
381         mts/generic/client.c and mts/generic/mts.c are now in sbr/
382         (and thus in libmh), which makes libmh self-contained and
383         not depending on an external archive.
384
385         * All include statements now look for mts.h in h/. The
386         Makefiles and configure script have been modified so that
387         mts/generic is no longer built.
388
389 Mon Dec 11 22:08:07 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
390
391         * When Shantonu made the new libmts.a, he swapped $(MTSLIB) and
392         libmh.a in sbr/Makefile.in so that libmh.a comes first, but this
393         causes the build to fail on Solaris, because libmts.a has to get
394         ruserpass() out of libmh.a.  Swapping them back to the way Ken
395         Hornstein's patch (which I applied on Jul 20) put them, with
396         libmh.a correctly coming second.  If there are times when libmts.a
397         needs to come second, then it would appear there's a circular
398         dependency and someone (Shantonu?) did an mts merge incorrectly.
399
400 Fri Sep 8 01:36:23 2000 Shantonu Sen <ssen@mit.edu>
401
402         * Took out bad time textual time zones like BST and JST.
403         I found them online somewhere, but am not sure if they're
404         correct.        
405         
406 Fri Sep 8 00:36:48 2000 Shantonu Sen <ssen@mit.edu>
407
408         * Moved zotnet/mts to mts/generic. This code reorganization
409         makes the entire zotnet tree deprecated -- bboards is unneeded,
410         mf was was moved to sbr, tws was rewritten and moved to sbr, and
411         now finally mts.
412
413         * Created a new static library called libmts.a used during
414         compilation which includes the generic mts code and the
415         smtp/sendmail code. This supercedes the functionality of the
416         old libsmtp.a and the remains of libzot.a.
417
418         * Updated header includes to reference the new location of mts.h
419         in mts/generic/mts.h. Also, update the configure and top-level
420         Makefile not to descend into zotnet. Also, they don't descend
421         into mts/mmdf and mts/sendmail (the sendmail code has been
422         merged into the smtp code).
423
424         * Added #include <h/nmh.h> to h/md5.h, since my compile was
425         complaining about implicitly-declared memcpy and memset, which
426         appear to be in strings.h. In any event, nmh.h should take care
427         of it for us.
428
429         * When doing a "make nmhdist", notice that the generated
430         snapshot does not include zotnet of the mts directories as noted
431         above. Since they are no longer compiled, and I don't see any
432         obvious code path to get to them, end-users should probably
433         not need them. If you think otherwise, turn Makefile generation
434         back on in configure.in and turn on recursion into those dirs
435         in the appropriate Makefile.in
436
437 Wed Sep 6 22:40:03 2000 Shantonu Sen <ssen@mit.edu>
438
439         * Tracked down the problem in the new dtimep where time
440         zones were being radically misreported. It was because the
441         parser knew about military time zones (such as M or E) but in
442         some cases did not know about the textual representation of
443         some zones (like MET). When it encountered one of these, the
444         date parser misread MET as the military time zone T (well, first
445         zone M, then E, and finally T). I took military zones out, and
446         things seem much better. Also, the default behavior of parsing
447         time zones appears to default to GMT in the absence of better
448         info, which is less bogus than assuming the mail came from the
449         current time zone, which was the behavior in 1.04.
450
451 Thu Aug 10 13:22:13 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
452
453         * Decided that limiting the message number columns to 3 on my
454         scan.MMDDYY and scan.YYYYMMDD (to try to regain space taken by
455         extra date info) was ill-conceived.  It's not that tough to get
456         past 999 messages, though I imagine it's rather rare to exceed
457         9999.  Changed these to 4.  Also put the "replied / encrypted"
458         column back in YYYYMMDD -- I've never seen it show anything but a
459         space, but that space is useful if you use scan, grep, and awk
460         (with the default field separator) to grab message numbers (I know
461         -- pick should really be used for these purposes...).
462
463 Mon Aug  7 20:11:09 CEST 2000 Ruud de Rooij <ruud@ruud.org>
464
465         * Modify umask set by mhshow to enable user execute bit, so that
466         viewers that create temporary directories (e.g., lynx) will be
467         able to access them.
468
469 Thu Aug 03 17:14:08 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
470
471         * TODO: Allow multiple simultaneous differing contexts, probably
472         each tied to a parent (terminal) process.
473
474 Tue Aug  1 10:48:05 EDT 2000 Kimmo Suominen <kim@tac.nyc.ny.us>
475
476         * Makefile install rules should not look for generated files in
477         the source tree -- this will happen to work when configuring and
478         building inside the source tree but will fail when using an
479         external build tree.  Fixed etc/Makefile.in.
480
481 Mon Jul 24 16:20:45 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
482
483         * When Shantonu wrote the new, more portable dtimep.lex, he left
484         out the #ifdef DSTXXX stuff for some reason.  Not a good idea, as
485         that code is required for proper printing of numeric-offset
486         timezones that have daylight saving time.  Without that code,
487         -0700 during DST gets printed as MST instead of PDT.
488
489         * Renamed DSTXXX as ADJUST_NUMERIC_ONLY_TZ_OFFSETS_WRT_DST and
490         added an explanatory comment by its #definition.
491
492         * Updated README.developers with the fact that zotnet/tws is going away.
493
494 Thu Jul 20 20:30:52 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
495
496         * Moved Kimmo's new "--with-hash-backup" to be output with the
497         rest of the --with options in the configure --help output.  Also,
498         people did not preserve my alphabetization of the --with options
499         when they added new ones.  Re-alphabetized.
500
501         * One more pass at README.developers now that it's clear that my
502         previously-suggested one-line autoconf-file commit can cause
503         unnecessary local makes and an out-of-sync stamp-h.in file, but
504         would not cause problems for other people using the CVS files.
505
506         * Ken Hornstein's SASL patch was not integrated properly with
507         Ruud's new merged mts/sendmail code.  Kimmo has since fixed nmh so
508         it compiles, but according to Ken, the SASL stuff still does not
509         work.  Integrating a patch from him for this.
510
511         * Last pass at README.developers -- Kimmo's 5-step commit was
512         overkill.  You only need 3 steps, since configure.in is the only
513         autoconf file with the RCS $Id keyword.
514
515         * Applied Kurt J. Lidl <lidl@eng.us.uu.net>'s $MAILHOST patch:
516
517             I have a small patch that would be nice to be included --
518             basically, it allows the usage of the "MAILHOST" environment
519             variable, without having to have HESIOD turned on.  I need
520             this functionality for my environment, where we have identical
521             /usr/local on all my machines (so I cannot just hardcode into
522             the mts.conf file), and I have multiple POP mail servers for
523             my users.
524
525         Modified inc.man to reflect that along with "pophost:" and -host, 
526         $MAILHOST can now activate POP mail inclusion as well.
527
528         * Fixed warnings from diff on first-time install of nmh.  Also
529         added 'echo's clarifying the etc file installation activities.
530
531 Tue Jul 18 19:36:59 EDT 2000 Kimmo Suominen <kim@tac.nyc.ny.us>
532
533         * Added the answer to Dan's question in README.developers.
534
535 Mon Jul 17 19:10:36 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
536
537         * Clarified and made some corrections to Kimmo's README.developers
538         changes (BTW, if anyone can explain why the RCS Ids are able to cause
539         problems with the dependencies, please fill in the explanation --
540         I never encountered a problem with the old single-commit method).
541
542 Sat Jul 15 23:13:49 EDT 2000 Kimmo Suominen <kim@tac.nyc.ny.us>
543
544         * Add configure option --with-hash-backup so the backup prefix can
545         be easily changed from "," to "#".
546
547         * Simplified sbr/Makefile.in so that it works with any make.
548
549         * Use mkstemp in sbr/lock_file.c.
550
551         * Commits of autoconf-related files apparently can't all be done
552         in one shot due to RCS Ids changing when committing -- updated
553         README.developers.
554
555 Tue Jul 11 14:18:01 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
556
557         * Clarified post.man and send.man for those not completely up on
558         SASL terminology.  "SASL encryption layers are not supported for
559         SMTP" means that encryption is supported for the authentication
560         but not for the subsequent data stream.
561
562 Sat Jul  8 01:36:19 EDT 2000 Kimmo Suominen <kim@tac.nyc.ny.us>
563
564         * Applied Ken Hornstein <kenh@cmf.nrl.navy.mil>'s patches
565         implementing SASL support for POP3 and SMTP.  If nmh is compiled
566         with SASL support, using the -sasl switch on the inc, msgchk,
567         post, and send commands will enable authentication encryption for
568         SMTP, and both authentication and data stream encryption for POP3.
569
570 Sat Jun 10 18:37:59 CEST 2000 Ruud de Rooij <ruud@ruud.org>
571
572         * Merged mts/sendmail functionality into mts/smtp; switching between
573         smtp and sendmail delivery method is now controlled by mts.conf.
574
575         * If tsort cannot deal with loops, in addition to defining tsort as
576         cat, also define lorder as echo.
577         
578         * Removed uip/popi.c from list of sources.
579
580 Thu Jun 08 19:36:57 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
581
582         * New dtimep.lex didn't parse day names properly.  Fixed.  Also
583         clarified ambiguous comments preceding day_map[] array (from old
584         dtimep.lex) that probably led to the erroneous cp++ being added.
585
586 Wed Jun  7 20:52:33 CEST 2000 Ruud de Rooij <ruud@ruud.org>
587
588         * Added one more mkstemp invocation to uip/spost.c (which was in a
589         #if 0 block).
590
591         * Applied patch from Peter Maydell to clean up permissions handling
592         and error handling in uip/inc.c.
593
594 Mon Jun  5 22:10:07 CEST 2000 Ruud de Rooij <ruud@ruud.org>
595
596         * Use cat instead of tsort if tsort cannot deal with loops in its
597         input (which is the case for tsort from GNU textutils).
598
599 Mon Jun  5 21:14:36 CEST 2000 Ruud de Rooij <ruud@ruud.org>
600
601         * If lockfile is present, and its dotlockfile program is setgid,
602         inc does not need to be setgid.
603
604 Sun Jun  4 21:35:40 CEST 2000 Ruud de Rooij <ruud@ruud.org>
605
606         * Added autoconf test for Miquel van Smoorenburg's liblockfile
607         library, as found on Debian systems.
608
609         * Added liblockfile support to sbr/lock_file.c.
610         
611 Wed May 31 7:19:30 2000 Shantonu Sen <ssen@mit.edu>
612         
613         * Fixed up dtimep.lex a bit. Added back memory options for AIX to
614         increase available memory.  Took out %option noyywrap, which
615         wasn't understood by AT&T lex, as well as the -i
616         case-insensitivity flag.
617
618 Wed May 31 07:40:45 2000 Doug Morris <doug@mhost.com>
619
620         * Added a lint target to the Makefiles and a check in autoconf
621         to determine whether lint or lclint exists on the system. 
622
623 Fri May 30 19:21:48 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
624
625         * etc/Makefile.in was incorrectly installing mts.conf.in and
626         sendfiles.in -- fixed.  Generated sendfiles script was not a
627         dependency of the `all' target, and was incorrectly included in
628         the distribution.  Changed the suffix for the backed-up previous
629         versions of the etc files from the ambiguous .old to .prev.  Added
630         call to diff -- only keep the .prev files around if different from
631         the newly-installed versions (intentionally didn't redirect output
632         to /dev/null so you'll notice when your changed versions are
633         getting moved aside).
634
635         * INSTALL never documented the etc/*.old thing.  Documented the
636         new etc/*.prev thing (including a note to watch for diff output).
637
638         * Applied Alec Wolman <wolman@cs.washington.edu>'s dropsbr.c patch:
639
640             In the map_write routine, a call is made to map_open and this
641             call is supposed to set the "clear" variable to 0 or 1,
642             depending on whether the map file is empty or not.  In
643             mh6.8.3, this worked because map_open would set "clear" by
644             calling the mbx_Xopen routine.  In nmh, the code for mbx_Xopen
645             was merged into mbx_open, but the interface for mbx_open
646             doesn't support the clear variable, so that functionality was
647             lost.  The map_open interface still contains "int *clear" in
648             the prototype, but never sets it.
649
650             My patch eliminates "clear" from the map_open interface (I
651             checked to make sure that map_write is the only client of
652             map_open).  Furthermore, my patch also sets the "clear"
653             variable properly at the beginning of map_write by calling
654             fstat().  This eliminates the bug in that the value of "clear"
655             being used later in the routine was just stack garbage.
656
657             Having a bad value of clear causes this next bug to be
658             triggered: The fp file pointer was being opened with fdopen,
659             but in two of the three switch cases it wasn't being closed.
660             In certain cases, this was causing packf to run out of file
661             descriptors if you attempted to pack a large folder.
662
663 Mon May 29 7:48:15 2000 Shantonu Sen <ssen@mit.edu>
664
665         * Moved the date parsing routines from zotnet/tws to sbr/ (and
666         tws.h to h/). Updated all source files to reflect to new location
667         of tws.h.
668
669         * Rewrote dparsetime (in dtimep.lex -> dtimep.c) to replace the
670         old zotnet/tws/dtimep.c, dtimep.lex, lexstring.c, lexedit.c, and
671         dtimep.c-lexed. It should now work with flex (although untested
672         with lex), and requires no sed-ing. For now, I have the lexed
673         version in the distribution, so that end-users don't need to worry
674         about running it through flex/lex. I have not added back support
675         for guessing the time zone when it's not specified.
676         
677 Sun May 28 17:44:15 CEST 2000 Ruud de Rooij <ruud@ruud.org>
678
679         * Added autoconf check for getutent().
680
681         * Changed uip/rcvtty.c and uip/slocal.c to use getutent() and
682         friends.  Since I can only check on Linux, please check if
683         this works on other systems.
684
685 Sun May 28 14:58:49 CEST 2000 Ruud de Rooij <ruud@ruud.org>
686
687         * Applied patch from Peter Maydell to uip/scansbr.c for more
688         checks for write failures.
689
690         * Unlink temporary file properly in uip/rcvtty.c.
691
692         * Moved viamail from bindir to libdir.
693
694         * Changed sendfiles into sendfiles.in, so that path to viamail
695         is patched in.
696
697         * Added gzip support to sendfiles.
698
699         * Added References header to replcomps and replgroupcomps.
700
701 Sun May 28 14:39:31 CEST 2000 Ruud de Rooij <ruud@ruud.org>
702
703         * Fixed m_getfld bug which caused segmentation faults when
704         incorporating messages which ended in multiple linefeeds crossing
705         a buffer boundary.
706
707 Fri May 26 13:21:59 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
708
709         * msh has been unable to show MIME messages ever since 1.0.  Alec
710         Wolman <wolman@cs.washington.edu> tracked down the problem to the
711         -show flag being passed to mhshow.  mhshow is equivalent to the
712         old mhn -show, so we don't need the -show anymore.  Removed it.
713
714 Fri May 12 02:51:21 2000 Shantonu Sen <ssen@mit.edu>
715
716         * zotnet/bboards is not longer built by default. Goal is to move
717         the assorted functions in zotnet into sbr or some more logical
718         place.
719
720         * Moved zotnet/mf to sbr, and changed mf.h references accordingly,
721         as well as Makefiles.
722         
723 Thu May 11 02:21:34 2000 Shantonu Sen <ssen@mit.edu>
724
725         * Simplified sbr/Makefile.in so that both SRCS and OBJS aren't
726         seperately and redundantly defined, but so that OBJS is a
727         pattern-substituted version of SRCS with suffix .c -> .o. This
728         should make maintainability easier.
729
730         * Added section to MACHINES indicating what platforms nmh is known
731         to compile and work on, just to give users peace of mind, or
732         something. This is by no means complete or exhaustive, so add
733         whatever you know works.
734         
735 Tue May 09 20:38:04 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
736
737         * Alphabetized Shantonu's $pop_kinds output on configure's "pop is
738         enabled" line.  If POP3 is the only kind of POP enabled, say so,
739         rather than just saying "yes" (which is ambiguous).
740
741         * Fixed four warnings in Shantonu's new getpass.c.  Needed to
742         #include <stdlib.h> for calloc(), <unistd.h> for ttyname(), and
743         "h/mh.h" for adios().  Also changed ch from char to int to get rid
744         of "comparison is always 1 due to limited range of data type" on EOF.
745
746         * Added steps to README.developers saying to change the version
747         number to X.Y.Z+dev.  Did a little rearranging and changed the FTP
748         dir from /home/ftp to /var/ftp to reflect Doug's new machine.
749
750         * Changed configure.in to use gcc -Wall even without
751         --enable-debug, to prevent developers compiling optimized from
752         introducing warnings, and to give end-users a warm, fuzzy feeling
753         as they (hopefully) see no warnings come out (except perhaps on
754         the lex output file) even with -Wall.
755
756         * Renamed getpass() to nmh_getpass() since the prototype for
757         getpass() varies from OS to OS, and we want to _always_ use our
758         version of the function.  Fixed all the callers to use
759         nmh_getpass() and added it to prototypes.h.  Semi-arbitrarily
760         upped MAX_PASSWORD_LEN from 128 to 256.  buf was being calloc()'d
761         and the memory leaked -- should have just been declared as static
762         char array.  Prepended "Portions of this code are" to the
763         copyright message, as this version has been changed significantly
764         from the BSD version.
765
766         * Added "nmh-local functions to use in preference to OS versions"
767         section to README.developers (currently just says to use
768         nmh_getpass() instead of system getpass()).
769
770         * Prepended "Portions of this code are" to the copyright message
771         in ruserpass.c also.
772
773         * Added mts.conf.5 page per Neil W Rickert <rickert+nmh@cs.niu.edu>'s
774         report:
775         
776             This happens on solaris:
777
778                      % man mts.conf
779                      windex entry incorrect:  mts.conf(5) not found.
780                      No manual entry for mts.conf.
781
782             It is fixed by
783
784                      % echo ".so man5/mh-tailor.5" > mts.conf.5
785
786             done in the man5 directory.  We need to add 'mts.conf.5' as a
787             reference sourcing mh-tailor.5.
788         
789 Mon May 08 23:51:55 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
790
791         * Doug informed me that the way I had restored the "lost" version
792         histories was wrong, because `cvs checkout's of old versions of
793         nmh wouldn't work properly.  It occurs to me that this could be
794         fixed by simply deleting those tags in the new-location *,v files,
795         but oh well.  I'm putting everything back to the way Doug
796         originally had it.  To get the old version history for a file that
797         used to be in the top directory, you'll need to "blindly" do a
798         `cvs log' there (even though you won't have a local copy of the
799         file in that directory).  `cvs diff' will no longer be able to
800         diff pre-move versions vs. post-move versions -- you'll have to do
801         a lot of manual gyrations with `cvs checkout' and then use `diff'.
802
803         * I had alphabetized the --configure options in the --help output
804         awhile back, but Shantonu added --enable-apop just under
805         --enable-pop.  Put it in alphabetical order and clarified what
806         --enable-apop does vs. --enable-pop and --with-krb4.  Also changed
807         --with-mts help line from "mail transport agent" to "mail
808         transport agent/service" so the 's' in "mts" doesn't seem to come
809         out of nowhere.
810
811         * Added two steps to "releasing nmh" in README.developers.  After
812         making the tarball, it's a good idea to diff the tree vs. the CVS
813         tree to make sure no files got left out, and then to chown the
814         files so that they're owned by root, preventing a Trojaning attack
815         by a malicious remote user with a UID matching yours.
816
817         * Changed DIFFERENCES to say that RPOP is not currently supported
818         rather than implying it by saying that APOP, KPOP, and POP[3] are.
819
820 Sun May 07 18:16:43 2000 Shantonu Sen <ssen@mit.edu>
821
822         * Imported NetBSD version of getpass() and made extensive
823         revisions for compatibility with programs that pipe the password
824         to stdin, such as exmh.
825
826         * Removed tests for system ruserpass() which sometimes gave
827         phantom positive results. Also, bext to use internal functions if
828         we ever want to change .netrc format to something else, or access
829         other files.
830
831 Sat May 06 08:28:09 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
832
833         * Restored lost version histories for those moved files by doing a
834         manual `mv' in the CVSROOT on mhost.  CVS badly needs a `cvs mv'
835         command so that you can move files (without having physical access
836         to the CVSROOT) without losing versioning.  Put MACHINES back at
837         the top level as it needs to be read before building.  Fixed DIST
838         variable in {.,docs}/Makefile.in to reflect that and to add
839         missing entry for "INSTALL" file.
840
841 Sat May 06 13:13:07 2000 Doug Morris <doug@mhost.com>
842
843         * Re-cleaned up nmh documentation (by moving things to docs
844         subdir) and modified Makefile & configure.in to handle the change.
845
846 Mon Apr 17 21:28:40 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
847
848         * Scott Blachowicz pointed out that the configure --help output
849         for --enable-masquerade was misleading.  Clarified.
850         
851 Mon Apr 17 19:01:00 2000 Shantonu Sen <ssen@mit.edu>
852
853         * APOP support can be compiled in to inc and msgchk using
854         --enable-apop.
855
856         * To access an APOP host, specify -apop on the command line
857         along with any -host or -user option.
858
859 Fri Apr 14 23:10:44 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
860
861         * Upped the version number to 1.0.4+dev until the next nmh release.
862
863         * Added a "releasing nmh" section to README.developers, while the
864         process was fresh in my mind.
865         
866 Fri Apr 14 18:21:34 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
867
868         * Added new files README.developers, ChangeLog_MH-3_to_MH-6.6, and
869         ChangeLog_MH-6.7.0_to_MH-6.8.4.html to DIST target in Makefile.in.
870         
871         * Released nmh-1.0.4.
872
873 Tue Apr 11 21:37:03 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
874
875         * Applied Brian Campbell <bacam@tardis.ed.ac.uk>'s mhn.defaults.sh
876         patch:
877
878             It appears that there shouldn't be quotes around the %s in the
879             iso-8859-1 charset entry; xterm passes the remaining arguments
880             to the program, quoting them means that xterm thinks they're
881             part of the program's name.
882
883         This %s isn't the same as the "Insert content subtype" one from
884         mhshow-show-* -- it doesn't come from MIME headers and is safe not
885         to quote.
886
887 Sun Apr 09 13:03:59 2000 Doug Morris <doug@mhost.com>
888
889         * added check in fmt_compile() to handle a single-character
890         format string. fmt_compile() depends on having an array of
891         format characters with an empty item at the end. A
892         single-character format would cause programs using this
893         function to segfault because the algorithm used to decide on
894         the length of the array mistakenly created a single-item array
895         when the format string was one character. This eventually
896         caused problems when the program attempted to test item+1
897         in the array.
898
899 Thu Apr 06 21:53:50 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
900
901         * Richard Coleman threw out a lot of old MH-specific files in nmh.
902         Much of the stuff, indeed, is not worth saving, but there are
903         nuggets that are very worthwhile, and should probably be added
904         back in.  Most important, IMHO, are the MH change logs, as they
905         can help answer questions like "Why is this code like this?" or
906         "How long has this been broken?" or "What was this ever used for?"
907
908         I've added a new file to the nmh tree called
909         ChangeLog_MH-3_to_MH-6.6.  It's cobbled together from the
910         mh-6.8.4/papers/mh*/MHCHANGES files.  I've re-ordered the entries
911         to go from newest at the top to oldest at the bottom to match the
912         ChangeLog convention.  Unfortunately there are no change logs for
913         versions of MH prior to 3 in the MH tar files available at
914         <ftp://ftp.ics.uci.edu/pub/mh>.  Also, it appears to me that there
915         are MH-6.6 changes that aren't documented in the logs.
916
917         I've also added ChangeLog_MH-6.7.0_to_MH-6.8.4.html.  This is
918         based on mh-6.8.4/papers/changes/mh-changes.ms.  The nroff format
919         and its "catman"-type output are a pain to deal with, but I was
920         loath to throw away the formatting, so I converted the file to
921         HTML.  The only actual markup in the body are the "<B>" and "<U>"
922         tags, and "&lt;" and "&gt;" instead of '<' and '>', so it's quite
923         doable to view the file in plain ASCII mode as well.  Note that
924         some of the changes this file documents as having been made in
925         MH-6.8.4 may not be present in nmh -- Richard started with 6.8.3
926         and later put in certain 6.8.4 stuff.
927         
928 Wed Apr 05 21:09:28 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
929
930         * Applied Eric Schnoebelen <eric@cirr.com>'s mhshowsbr.c patch
931         fixing apparent bugs in Dan Winship's new security quoting code:
932         
933             Since upgrading, I've been getting the following errors
934             while attempting to process some MIME messages:
935
936                 (1) Syntax error: Unterminated quoted string
937                     exit 2
938         
939             and:
940
941                 (2) line 1/10 (END)Segmentation fault (core dumped)
942
943             (2) appears to be due to the testing of an unset pointer in
944             mhshowsbr.c:show_multi_aux().  (1) appears to be caused by
945             mis-quoting a filename being handed to the shell in
946             mhshowsbr.c:show_content_aux().
947
948             Resolving the pointer reference issue in
949             mhshowsbr.c:show_multi_aux() turned up a similar mis-quoting
950             problem in the routine.
951
952 Tue Mar 28 16:17:39 2000 Doug Morris <doug@mhost.com>
953
954         * Applied Todd.Miller@courtesan.com's patch to dropsbr.c to
955         prevent core dumping on packf. Here's the note from his message:
956
957             Since sizeof(buffer) == sizeof(tmpbuffer) packf will dump
958             core on a file w/o a From line with a line >= BUFSIZ.
959             I noticed this because I had a junk file in my mail
960             spool somehow.
961
962 Fri Mar 17 11:59:33 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
963
964         * wesley.craig@umich.edu did not document his previous KPOP patch,
965         so I did so, and asked him to check what I wrote.  Unfortunately
966         he didn't notice my misunderstanding of his patch.  I wrote that
967         if you #define POPSERVICE "kpop", inc and msgchk will use KPOP
968         exclusively, but if you leave it as "pop3", you can use Wesley's
969         new -kpop switch on a given invocation.  Instead, however, -kpop
970         turned out to be necessary on every invocation, and a KPOP user
971         complained.  Applied Wesley's new patch, which makes things work
972         like I thought his original patch did.  After that, did one more
973         clarifying pass to the documentation in inc.man and msgchk.man.
974
975 Wed Mar 15 18:45:45 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
976
977         * When I fixed the long-standing makedir() bugs in January, I had
978         the code call strtoul(..., 0), which I believed to be safe as all
979         modes specified as ASCII constants in the nmh code started with a
980         leading zero (signifying octal), which I did as it would work if
981         internal constants were ever changed to hex.  Unfortunately I was
982         unaware of the "Folder-Protect:" .mh_profile entry, which
983         mh-profile.man documents as an octal-only constant, with no
984         leading zero required.  I've changed the strtoul() call to an
985         atooi() call and removed the misleading leading zeroes on the
986         ASCII octal constants in the code and man pages.  Also changed the
987         "Folder-Protect:" example in the man page to something more
988         interesting than a duplication of the default.
989
990         * When I added my --enable-masquerade option, you'll note that I
991         didn't make it --enable-nmh-masquerade.  I find the --enable-nmh-*
992         options too wordy and I'm not sure why Richard went that route.
993         I've renamed them to just --enable-*, but the old versions will
994         still work as well (they just aren't advertised).
995
996         * Added a line to the "nmh configuration" output saying whether
997         POP is enabled.
998
999         * Added a new README.developers file.  From the file:
1000
1001             This file is intended to provide a few tips for anyone doing
1002             development on nmh.  Developers who learn things "the hard
1003             way" about the nmh codebase (as opposed to local info best
1004             encoded in a comment) are encouraged to share their wisdom
1005             here.
1006
1007         Currently the topics are "autoconf files" and "directory structure".
1008
1009 Tue Mar 14 12:41:48 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1010
1011         * Applied, after some finessing,
1012         Simon Burge <simonb@thistledown.com.au>'s --with-smtpservers patch:
1013
1014             Here's a patch that allows you to add
1015
1016                     --with-smtpservers=<some.host.name>
1017
1018             to the ./configure command line to set the "servers: " line in
1019             etc/mts.conf.  Around here, we use "mailhost" so that all
1020             machines in the current domain just talk to a central machine
1021             and nothing else runs an MTA.  Now, I can use
1022
1023                     --with-smtpservers=mailhost
1024
1025             instead of having to remember to fix this by hand (and often
1026             forgetting to do so!).
1027
1028         * Inspired by Simon's patch, added an --enable-masquerade option
1029         to configure.  It will set the "masquerade:" line of mts.conf.
1030         You may specify a subset of the three types of masquerading, like
1031         --enable-masquerade="draft_from mmailid", or leave off explicit
1032         arguments to enable all three types.
1033
1034         * Alphabetized the --enable and --with options in configure.in and
1035         INSTALL and added documentation of the two new options to the latter.
1036
1037         * Added new dependency for mts.conf: Makefile.  If this isn't
1038         done, then when you reconfigure nmh with new values for
1039         --enable-masquerade or --with-smtpservers, you'll fail to get an
1040         updated copy of mts.conf.
1041
1042         * Applied Simon Burge <simonb@thistledown.com.au>'s dtimep.lex patch:
1043
1044             It seems that some MUA's didn't handle y2k very well - ELM
1045             seems to be one of them, and Ultrix's DXmail (based on MH!).
1046             I've got a few emails this month that look like:
1047
1048                     575   Jan 00  Xxxxxx Xxxx       3603  ...
1049             and
1050                      22+  Jan 00  Xxx Xxxxx         1771  ...
1051
1052             The first has "15 Jan 100" as the date and the second has 
1053             "19 Jan 00" as the date.  The following works around this so 
1054             that scan, show, sortm, etc work ok.
1055
1056         I put Simon's patch under the control of a new #define called
1057         FIX_NON_Y2K_COMPLIANT_MUA_DATES.  There's some commentary in
1058         acconfig.h about when you might not want to #define it.
1059
1060         * Created new dtimep.c-lexed with Simon's change using dtimep.lex
1061         lexed on Solaris 2.6.  Added missing dependency in
1062         zotnet/tws/Makefile.in for dtimep.c: dtimep.c-lexed.
1063
1064         * Added scan.MMDDYY and scan.YYYYMMDD format files.
1065
1066 Mon Mar 13 21:32:00 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1067
1068         * Applied Sullivan N. Beck <sbeck@cise.ufl.edu>'s mhshow-suffix patch:
1069
1070             With the patch below, you can add lines like:
1071
1072                 mhshow-suffix-application/msword: .doc
1073                 mhshow-suffix-application/PostScript: .ps
1074
1075             to the mhn.defaults file to append the given suffix to a
1076             scratch file.  This allows applications which require a
1077             certain suffix to run properly.
1078
1079         * Removed -force_html from lynx entry in mhn.defaults.sh (I
1080         believe older versions of lynx lack that option) and added
1081         "mhshow-suffix-text/html: .html".
1082                 
1083         * Modified username_extension masquerading to only use the
1084         extended address on generated [Resent-]From: lines and SMTP
1085         envelope From:.  With Neil's original implementation, nmh's global
1086         idea of the username was changed, which would result in inc lying
1087         and saying you had no new mail because it was looking for a
1088         mailbox called, for instance, "dan-nmh" (where username was "dan"
1089         and $USERNAME_EXTENSION was "-nmh").
1090                 
1091         * Applied Simon Burge <simonb@thistledown.com.au>'s dtime.c patch:
1092         
1093             There's a wrap-around problem that affects the implementation
1094             of Zeller's congruence in dtime.c.  This causes the day-of-week
1095             calculations to fail for dates after Feb 29, 2000 (probably up
1096             until some year far in the future).
1097
1098 Mon Mar 06 12:20:20 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1099
1100         * Applied Neil W Rickert <rickert+nmh@cs.niu.edu>'s msh.c patch:
1101
1102             I finally tracked down the problem in msh that was causing
1103             errors whenever I tried to examine a 'mmdf' style mailbox.
1104
1105             It turns out that not enough memory was being allocated with
1106             calloc(), causing memory pointers to be overwritten and
1107             corrupted.
1108                 
1109 Fri Mar 03 16:07:33 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1110
1111         * Changed the new "plussed_user" option to mts.conf's
1112         "masquerade:" to "username_extension" after getting feedback from
1113         qmail users, who use '-' as a separator rather than '+'.  Removed
1114         checking of $USERPLUS variable.  Now check $USERNAME_EXTENSION,
1115         which needs to include the appropriate separator for your MTA
1116         ('-', '+', or whatever) as its first character.
1117                 
1118 Thu Mar 02 23:04:30 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1119
1120         * Added a new "boolean" type to mh.h and TRUE and FALSE constants.
1121                 
1122         * Added a note to DIFFERENCES stating that it's out-of-date
1123         (Richard was the last one to update it) and that we should
1124         consider only documenting incompatibilities with MH there.
1125
1126         * Implemented (and documented) a third kind of username
1127         masquerading: "plussed user" masquerading.  This one was suggested
1128         by Neil Rickert <rickert+nmh@cs.niu.edu>.  It's based on sendmail's
1129         "plussed user" feature, where mail sent to <user>+<string> will be
1130         delivered to <user>.  When it's enabled, it's controlled by the
1131         $USERPLUS environment variable.  How is it enabled?  Well, that
1132         leads me to:
1133
1134         * Renamed the "mmailid:" setting in mts.conf to "masquerade:", and
1135         changed it so that rather than being a boolean, it can be set to
1136         any combination of the three values "draft_from", "mmailid", and
1137         "plussed_user".  Thus it is now possible to enable the three types
1138         of masquerading individually.
1139
1140         * Fixed a bug with "mmailid" masquerading (dating back to MH?)
1141         where if it was turned on, ','s would no longer be considered
1142         GECOS field delimiters.
1143         
1144 Wed Mar 01 23:30:50 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1145
1146         * Changed the GECOS-field '&' translation behavior to be
1147         controlled by the BSD42 #define rather than GCOS_HACK, since it's
1148         apparently always appropriate on OSes where BSD42 is #defined, and
1149         never appropriate on any other OSes.  Thanks to Kimmo Suominen for
1150         responding to my "What is this code here for?" comment in mts.c
1151         and explaining the feature.
1152         
1153 Mon Feb 28 21:50:29 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1154
1155         * Upped the version number to 1.0.3+dev (ideally this should be
1156         done by whoever makes a release tar file, immediately after doing
1157         so).
1158         
1159         * Applied Paul Fox <pgf-spam@foxharp.boston.ma.us>'s scansbr.c
1160         patch, posted to comp.mail.mh, which he says prevents loss of mail
1161         when inc'ing into a full filesystem.
1162
1163         * Changed "echo > stamp-h.in" in Makefile.in to "date > stamp-h.in"
1164         so that stamp-h.in will be different each time configure.in and
1165         related files are changed, making it easier to check it in (which
1166         is necessary to prevent unnecessary autoconf calls).
1167
1168         * My declaration of initgroups() in slocal.c to eliminate the "no
1169         prototype" warning wasn't portable (FreeBSD 3.[23] choked).  Now
1170         use AC_EGREP_HEADER to see where initgroups() is declared, if
1171         anywhere.
1172
1173 Sun Feb 20 12:17:15 2000 Ruud de Rooij <ruud@ruud.org>
1174
1175         * Fix security hole in mhshowsbr.c which allowed untrusted shell
1176           code to be executed.
1177         
1178         * Released nmh 1.0.3.
1179
1180 Thu Feb 10 10:54:36 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1181
1182         * Oops.  %-escapes on mhstore lines in mhn.defaults.sh should not
1183         be surrounded by single quotes, as a shell is not spawned when
1184         just saving files, and the filenames will end up with literal
1185         quotes embedded in them.
1186
1187 Fri Feb 04 12:29:12 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1188
1189         * Whoever originally added the -help switch to all the commands
1190         got too cute and had the option itself print out as "-(help)" in
1191         the -help output.  One theory is that they were making reference
1192         to the fact that clearly you know about the -help option since
1193         you're currently looking at its output.  I think it's a bad idea
1194         to overload the meaning of the parentheses, however -- they're
1195         supposed to indicate what abbreviated prefix of the switch you're
1196         allowed to specify.
1197
1198         The other theory is that because you can say something like
1199         "mhstore -" and get "mhstore: - ambiguous.  It matches" followed
1200         by the same list of switches you get with -help, they were saying
1201         you can "sorta" abbreviate "-help" as "-".  You don't get the
1202         "Usage:" string, though, so it's not really the same thing.
1203
1204 Thu Feb 03 17:52:01 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1205
1206         * Applied wesley.craig@umich.edu's KPOP patches.  According to him:
1207
1208               The following patch fixes a problem with requesting a
1209               service key for a machine that has multiple 'A' records.  It
1210               also makes "-kpop" a command line option, for users who
1211               would like to use both "kpop" and "pop".
1212
1213         Did no testing of the new features, as I don't have access to a
1214         KPOP server.
1215
1216         * Modified inc.man and msgchk.man to document Wesley's new -kpop.
1217
1218         * Modified INSTALL and config.h.in to reflect the new -kpop feature.
1219
1220 Fri Jan 28 17:39:24 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1221
1222         * All %-escapes in mhn.defaults that actually expand to something
1223         should be surrounded by single quotes.  Added quotes to the ones
1224         in mhn.defaults.sh that were missing them.
1225
1226         * Added check for lynx to write mhshow-show-text/html line in
1227         mhn.defaults.sh.
1228
1229 Thu Jan 27 12:22:25 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1230
1231         * makedir() had multiple bugs dating back to MH.  An octal
1232         constant was apparently being interpreted as decimal, resulting in
1233         directories with no user read or execute permissions, making
1234         nested directory creation fail.  And there wasn't even an
1235         _attempt_ to set desired permissions (e.g. from "Folder-Protect:"
1236         in .mh_profile) on the outer directories of a nested directory.
1237
1238         * A second `make install' would always fail because the check for
1239         whether mh_profile.5 existed was written incorrectly.
1240         
1241 Wed Jan 26 02:22:00 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1242
1243         * Added documentation on both types of masquerading to post's man
1244         page.
1245
1246 Tue Jan 25 22:58:12 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1247
1248         * Doug's portability fix of my setgid inc autodetection had a
1249         caching bug -- if you re-ran configure, uip/Makefile would be
1250         corrupted, and installation would bomb out on OSes where inc needs
1251         to be setgid.
1252
1253         * Implemented a new kind of email address masquerading.  Usually,
1254         when a user writes a custom "From:" header in a draft, nmh uses it
1255         rather than generating one.  However, the user's true address is
1256         used in the SMTP envelope "From:" and is revealed in the "Sender:"
1257         header.  Now, when mmailid is set to non-zero, the envelope
1258         "From:" uses the address specified in the draft "From:" header,
1259         and there is no "Sender:" header.  This is useful when sending on
1260         behalf of a remote POP3 account or when remote mail robots
1261         incorrectly use the envelope "From:" in preference to the body
1262         "From:".  This processing has only been implemented for post, not
1263         for the undocumented spost (which was already missing some "From:"
1264         processing that post has).
1265
1266 Mon Jan 24 22:26:06 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
1267
1268         * Got rid of the rest of the gcc -Wall warnings that I didn't have
1269         time for on 1999-07-15 (and, it would seem, some new ones people
1270         introduced since then).  The primary ones were the warnings that
1271         default prototypes were being used for [v]snprintf() and
1272         str[n]casecmp().  As of right now, there are _no_ compilation
1273         warnings except on dtimep.c-lexed (at least under AIX 4.1.5 and
1274         Solaris 2.6).
1275
1276 Sun Jan 2 23:42:18 2000 Ruud de Rooij <ruud@ruud.org>
1277
1278         * Move mhtest from bindir to libdir.
1279
1280         * Move sendfiles from libdir to bindir.
1281
1282         * Updated sendfiles manpage to reflect this change.
1283
1284         * Added documentation for -build and -file switches to repl and 
1285           forw manpages (patch from Peter Maydell).
1286
1287         * Fixed interaction between specifying -cc in profile and -group on 
1288           command-line.
1289
1290 Tue Nov 1 13:48:10 1999 Dan Harkless <dan-nmh@dilvish.speed.net>
1291
1292         * Changed the version number from 1.0.3 to 1.0.2+dev.  There was
1293         not unanimous support for my proposed even/odd release/developer
1294         version number dichotomy.  1.0.2+dev implies release 1.0.2 plus
1295         some development.
1296
1297 Fri Oct 29 13:42:51 1999 Dan Harkless <dan-nmh@dilvish.speed.net>
1298
1299         * Upped the version number to 1.0.3.  If we don't do this, then
1300         when people report bugs against 1.0.2, we won't know "which" 1.0.2
1301         they're talking about (since the development source is publically
1302         available via CVS).  I think the Linux kernel version numbers are
1303         a good model, so the next time we roll a tarball, it should be
1304         version 1.0.4 (or higher -- anyhow, an even-numbered version).
1305
1306 Fri Oct 29 06:41:08 1999 Doug Morris <doug@mhost.com>
1307
1308         * Released nmh-1.0.2.
1309
1310 Tue Oct 26 22:57:00 1999 Doug Morris <doug@mhost.com>
1311         
1312         * Added check for whether "libtool" is in fact gnu libtool. If
1313         it is, it is not used. This is the wrong behavior. If vendor
1314         XYZ later on decides to create yet another libtool, we'll be
1315         caught again. This works for now.
1316
1317         * Minor updates to MACHINES refering to Mac OS X.
1318
1319 Thu Oct 21 20:45:37 1999 Doug Morris <doug@mhost.com>
1320
1321         * Added check for "libtool" (a ranlib type tool for Mac OS X)
1322         and modified Makefiles so that nmh will build under Mac OS X.
1323
1324 Sun Oct 17 08:28:56 1999 Ruud de Rooij <ruud@ruud.org>
1325
1326         * Changed repl defaults to partly revert to MH behaviour,
1327           "-cc all" is now only implied with -group.
1328
1329         * The replcomps template includes cc: header again (as in MH).
1330
1331         * Updated repl man page to reflect these changes.
1332
1333 Sat Oct 16 02:57:47 1999 Doug Morris <doug@mhost.com>
1334
1335         * Tweaked configure to handle Solaris and SunOS after the BIND
1336         changes. Both need more cleanup.
1337
1338 Sat Oct 16 00:17:36 1999 Doug Morris <doug@mhost.com>
1339
1340         * Removed BIND define and replaced it with a check for
1341         gethostbyname (to determine if the host is DNS aware) and a
1342         check for sethostent. This appears to be the right thing to
1343         do, but there is no explanation of the reasoning behind the
1344         BIND define in the code and it appears to have been used for
1345         multiple purposes. 
1346
1347 Wed Oct 13 15:53:53 1999 Doug Morris <doug@mhost.com>
1348
1349         * Updated manpages Makefile to link mh-profile.5 to
1350         mh_profile.5 after installation. Suggestion from Richard Cohen
1351         <richard@jubjub.demon.co.uk>.
1352
1353         * Modified configure.in to check for _IO_write_ptr and libio.h
1354         to determine whether to define LINUX_STDIO instead of using 
1355         config.guess.
1356
1357 Mon Oct 4 15:22:46 1999 Dan Harkless <dan-nmh@dilvish.speed.net>
1358
1359         * Added '-L' to the calls of 'ls' in configure.in -- I have seen
1360         multiple machines in the past where the mail spool was a symlink
1361         to a directory on another device with more free space.
1362
1363 Fri Oct 1 22:36:56 1999 Dan Harkless <dan-nmh@dilvish.speed.net>
1364
1365         * Fixed a portability problem in Doug's fix of a portability
1366         problem in my MAILGROUP autoconf support ('ls -l' vs. 'ls -lg'). 
1367
1368 Sat Sep 25 18:40:43 1999 Ruud de Rooij <ruud@ruud.org>
1369
1370         * Added config.sub and config.guess to the list of files to be
1371         distributed.
1372
1373         * Fixed bug in sbr/fmt_scan.c where an extra newline would be
1374         added if a list of addresses was split over several header lines.
1375
1376         * In mts/smtp/smtp.c, undefine strlen and strcpy if they are
1377         macros, regardless of platform.
1378
1379         * Allow q to quit mhshow, and n to skip to next part.  Patch from
1380         Kimmo Suominen <kim@tac.nyc.ny.us>.
1381
1382         * Modified mhstore to recognize attachments created by sendfiles
1383         with x-conversions=gzip.
1384
1385 Mon Sep 13 21:20:10 1999 Doug Morris <doug@mhost.com>
1386
1387         * added explicit cast to long from time_t for tclock in
1388         post.c.
1389
1390         * Commented out #ifdefs for <sys/ioctl.h> in termsbr.c since
1391         it's needed for ioctl() anyway. This prevents a warning about
1392         implicit definition of ioctl().
1393
1394         * Moved guesses performed by AC_CANONICAL_SYSTEM back into the
1395         "User Configuration" section of config.h (moved @TOP@ in
1396         acconfig.h) so they're easier to find, should someone actually
1397         want to mess with them.
1398
1399 Sun Sep 12 15:50:34 1999 Doug Morris <doug@mhost.com>
1400
1401         * updated Makefile.in so it recognized COMPLETION-TCSH and
1402         COMPLETION-ZSH (only used in make nmhdist). 
1403
1404         * added prototype for ruserpas to <h/prototypes.h>. Fixes
1405         warnings in mhparse.c and mhbuildsbr.c.
1406
1407         * added include checks for <time.h> and <sys/time.h> to
1408         prevent warnings in fmt_compile.c, fmt_scan.c, lock_file.c,
1409         sendsbr.c, mhbuildsbr.c, mhcachesbr.c, picksbr.c, and post.c.
1410
1411         * added include for <zotnet/mts/mts.h> to ali.c, scan.c, ap.c,
1412         rcvdist.c, rcvstore.c, rcvtty.c, and spost.c to remove
1413         warnings about implicit definition of mts_init().
1414
1415         * added <grps.h> to slocal.c to prevent warnings about
1416         function initgroups.
1417
1418         * added <h/signals.h> to prevent warning about missing SIGNAL
1419         function.
1420
1421         * added function prototypes to smtp.c, whatnowproc.c,
1422         mhbuildsbr.c, mhparse.c, mshcmds.c, show.c, whatnow.c, mhl.c
1423         to fix warnings.
1424
1425         * explicitly declared mbx_style in mshcmds.c and lused in
1426         fmtdump.c as type static int instead of just static to
1427         prevent warnings.
1428         
1429         * various code cleanups to prevent ambiguous statements
1430         (brackets for if/thens and parens for complicated if
1431         statements).
1432
1433
1434 Sun Sep 12 09:19:27 1999 Doug Morris <doug@mhost.com>
1435
1436         * commented out _cleanup() in mf.c because it's the only
1437         location in all of the source code where it exists. It was
1438         preventing compilation on at least linux.
1439
1440         * Added check for <db1/ndbm.h> which is the new location where
1441         linux systems appear to be stuffing this header file.
1442
1443 Thu Sep 09 23:15:49 1999 Doug Morris <doug@mhost.com>
1444
1445         * fixed varous mkstmep bugs introduced in 1.0.1 by me. Whups!
1446
1447         * added mh_profile SEGV patch from Richard Cohen
1448         <richard@jubjub.demon.co.uk> that prevents crashing when
1449         mh_profile doesn't end in a newline. A similar patch was
1450         previously sent in by Andrew Bettison <andrewb@zip.com.au>.
1451
1452         * fixed bug in associated with MAILGROUP #define (group "mail"
1453         is not universal) -- hard to believe, but true.
1454
1455 Tue Sep 7 16:47:03 1999 Dan Harkless <dan-nmh@dilvish.speed.net>
1456
1457         * Renamed ZSH.COMPLETION to COMPLETION-ZSH and added COMPLETION-TCSH.
1458
1459 Tue Aug 17 16:06:29 1999 Dan Harkless <dan-nmh@dilvish.speed.net>
1460
1461         * Automated #define of MAILGROUP and installation of inc as setgid mail
1462         when the mail spool directory isn't world-writable.
1463
1464 Thu Jul 15 18:37:07 1999 Dan Harkless <dan-nmh@dilvish.speed.net>
1465
1466         * slocal -debug used to leave a file in /tmp for each message
1467         processed.  Very bad for folks with slocal -debug in their .forward!
1468
1469         * Got rid of a ton of compilation warnings.  Most were "junk"
1470         warnings due to the use of gcc -Wall (without -Wno-parentheses),
1471         but a few represented real bugs.  There remain many warnings to be
1472         tackled that are due to missing function prototypes (e.g. snprintf()).
1473
1474         * Default rcvdistcomps no longer puts a copy of all outgoing
1475         messages in outbox.  Added an rcvdistcomps.outbox that does.
1476
1477 Sat Jun 09 12:22:47 1999 Doug Morris <doug@mhost.com>
1478
1479         * Updated configure to check for mkstemp (available on OpenBSD) and 
1480         substitute it for mktemp if available. 
1481
1482 Thu May 13 16:40:19 1999  Doug Morris <doug@mhost.com>
1483
1484         * Added config.sub and config.guess and updated acconfig.h and
1485         configure.in to automatically detect system type and set the
1486         proper #defines.
1487
1488 Wed May 12 23:41:33 1999  Dan Winship  <danw@mit.edu>
1489
1490         * Released nmh-1.0.1.
1491
1492 Fri May  7 17:18:28 1999  Dan Winship  <danw@mit.edu>
1493
1494         * Fixed flist to properly deal with relative folder names.
1495         Problem noted by Jerry Peek <jpeek@jpeek.com>.
1496
1497         * Fixed --with-krb4 to work with original Kerberos 4 libraries as
1498         well as the Kerberos 5 compat libraries. Based on a patch from
1499         Assar Westerlund <assar@sics.se>.
1500
1501         * Added a check in configure.in to test if modf is in libc and
1502         link with libm if not. This is needed by at least Digital UNIX. 
1503         Problem pointed out by Kevin Oberman <oberman@es.net>.
1504
1505         * Fix a bug from the "mhn -show" to "mhshow" renaming that
1506         made the "list" command in whatnow not work for some users.
1507         From Ruud de Rooij <r.c.m.derooij@twi.tudelft.nl>.
1508
1509         * Replaced "extern int errno" with "#include <errno.h>" in a
1510         number of files. Suggested by Stephen Wilson Bailey
1511         <swb@nconnect.net>.
1512
1513         * Fixed a problem in how "packf -mbox" translated "Return-Path:"
1514         lines. From Kimmo Suominen <kim@tac.nyc.ny.us>.
1515
1516         * Fixed a segmentation fault in inc. Patch originally from Ruud de
1517         Rooij <r.c.m.derooij@twi.tudelft.nl>.
1518
1519         * Allow display of 8bit encoded messages. From Kimmo Suominen
1520         <kim@tac.nyc.ny.us>.
1521
1522         * Fixed repl to not add line breaks in the middle of long
1523         addresses when building a reply. From Ruud de Rooij
1524         <r.c.m.derooij@twi.tudelft.nl>.
1525
1526         * Added -library switch to spost so it can parse user aliases like
1527         post does. From Ruud de Rooij <r.c.m.derooij@twi.tudelft.nl>.
1528
1529         * Changed configure.in's check for sigsetjmp to properly deal
1530         with systems like Linux where it is a macro. From
1531         <elleron@servtech.com>.
1532
1533         * Fixed a bug in whatnow that could cause it to sometimes exit
1534         without prompting the user. Based on a patch by Richard Geiger
1535         <rmg@netapp.com>.
1536
1537         * Added code to deal with SIGPIPE in mhl so it doesn't print
1538         "Broken pipe" if you quit out of the moreproc.
1539
1540         * Documentation: Added a note to MACHINES about Irix make. Added a
1541         pointer to the online copy of the MH book in INSTALL. Added
1542         some additional information to the whatnow and packf man pages,
1543         suggested by Jerry Peek <jpeek@jpeek.com>.
1544
1545         * Updated INSTALL, FAQ, etc to not refer to Richard as the
1546         maintainer or math.gatech.edu as the home any more.
1547
1548 1999-02-06  Richard Coleman  <coleman@math.gatech.edu>
1549
1550         * Released nmh-1.0.
1551
1552         * Merged mbx_open and mbx_Xopen in dropsbr.c.  Fixed
1553           mbx_open so that the mode of zero length maildrops
1554           would not be changed.
1555
1556         * Replaced the substitute version of snprintf() with the
1557           one from the Apache web server.
1558
1559         * Changed to default mode for creating new messages to 0600
1560           (this should have been done a long time ago).
1561
1562         * Changed "flist" to handle searching for multiple sequences
1563           for each folder.  Also flist will now correctly split
1564           Unseen-Sequence if it consists of multiple sequences.
1565
1566         * Added new switches `-unlink' and `-nounlink' to "refile".
1567
1568         * Added new switches `-unlink' and `-nounlink' to "rmm".
1569
1570         * More cleanups of slocal output.  Changed adorn() to
1571           send to stdout, instead of stderr (to match rest of
1572           verbose printing).
1573
1574         * Merged mbx_create() into mbx_open, so that creating and
1575           opening a nonexistent maildrop is done atomically.  This
1576           removes a bad race condition.
1577
1578         * Fixed bug that caused slocal to be unable to save to MMDF
1579           style drop file.
1580
1581         * Added new wrapper function usr_folder() to slocal.c to
1582           handle adding message to folder (currently, it still uses
1583           usr_pipe() to call rcvstore).
1584
1585         * seq_list() checks for empty folder before scanning for
1586           sequence information.
1587
1588         * num_digits() in flist.c and folder.c now returns correct
1589           value for 0.  Also added sanity check.
1590
1591         * folder_delmsgs() now correctly decrements internal message
1592           count.
1593
1594         * Don't attempt to read sequence information if folder
1595           is empty.
1596
1597         * Split seq_read into seq_public and seq_private.
1598
1599         * Small change to sigmsg.awk, since newer versions of gawk
1600           interpret 034 as octal.
1601
1602         * In flist, don't scan for sequence information in empty folder.
1603
1604         * Updated mhn.defaults.sh to output profile entries for mhshow,
1605           mhstore, and mhbuild.
1606
1607         * Changed configuration parameter "mhn-access-ftp" to
1608           "nmh-access-ftp".  Updated man pages
1609
1610         * Moved the code in InitMultipart to reverse the order of the
1611           parts in a multipart, into its own function "reverse_parts()".
1612
1613         * Changed code in mhbuildsbr.c to store unencoded content
1614           in the c_cefile structure when building.
1615
1616         * Changed code in mhoutsbr.c to look for unencoded content
1617           in the c_cefile structure when outputing message.
1618
1619         * Changed configuration parameter "mhn-cache" and
1620           "mhn-private-cache", to "nmh-cache" and "nmh-private-cache",
1621           since it is used in mhstore, mhlist, and mhshow.  Updated man pages
1622
1623         * Change configuration parameter "mhn-storage" to
1624           "nmh-storage", since it is now used in mhstore, mhlist,
1625           and mhshow.  Updated man pages
1626
1627         * Add autoconf support for KPOP (kerberized pop).
1628
1629         * Add autoconf support for Hesiod.
1630
1631         * Split routines to output a message given a Content structure
1632           (output_message, output_content, write7Bit, etc..) to a new
1633           file "mhoutsbr.c".
1634
1635         * Split output_content(), into output_content() and build_headers().
1636
1637         * Changed copy_some_headers() in mhstoresbr.c, to use the linked
1638           list of header fields, rather than reopening the message.
1639
1640         * Added free_header() to mhfree.c to free structures containing
1641           header field information.
1642
1643         * Changed get_content() to use the linked list of header fields
1644           when parsing the various MIME headers (Content-XXX).
1645
1646         * Changed get_content() to store linked list of header field
1647           values when parsing a content.
1648
1649         * Changed mhbuild, mhn, mhlist, mhshow, mhstore, to use the
1650           routines in mhcachesbr.c to handle the content cache.
1651
1652         * Split various funtions (find_cache, find_cache_aux, find_cache_aux2,
1653           cache_content) into new file mhcachesbr.c.
1654
1655         * More calls to sprintf/strcpy (primarily in mhparse.c
1656           and mhbuildsbr.c) converted to snprintf/strncpy.
1657
1658         * When a message is displayed with `mhshow', it is now
1659           removed from the "unseen" sequence.
1660
1661         * Change the default "showmimeproc" to "mhshow".
1662
1663         * Split "mhn -show" off into separate command "mhshow".
1664
1665         * Split "mhn -store" off into separate command "mhstore".
1666
1667         * Split "mhn -list" off into separate command "mhlist".
1668
1669         * Add sanity checks to context_find(), context_replace(),
1670           and context_del(), to abort if context file hasn't been
1671           read.
1672
1673         * Add calls to context_read(), to the beginning of all nmh
1674           commands (instead of being called indirectly by context_find).
1675
1676         * Changes the "substitute" version of vsnprintf/snprintf for
1677           operating systems without native versions, to just call the
1678           native vsprintf(), and ignore the buffer length.   This is
1679           faster, but less secure than the previous version that used
1680           temporary files.  This should only be a problem for systems
1681           which do not have a native snprintf(), and require `inc' to
1682           be setuid/setgid.
1683
1684         * Lots more calls to sprintf/strcpy converted to snprintf/strncpy.
1685
1686         * Changes client() routine to take additional parameter, which is
1687           the buffer length of the parameter "response".  Then added
1688           buffer length checks for this parameter.
1689
1690         * Changed getws() to get_fields(), since that is apparently the
1691           name of a wide character version of gets() on some archetitures.
1692
1693         * Lots of sprintf/strcpy calls converted to snprintf/strncpy.
1694
1695         * Change the code in most of the commands that take multiple
1696           message names/sequences/ranges on the command, such that
1697           the msgs array is expanded dynamically.  This removes most
1698           of the limits on the length of command lines.
1699
1700         * Add additional parameter to copyip(), to specify the
1701           maximum number of strings that can be copied (security
1702           fix).
1703
1704         * Create new function getarguments(), to massage the argument
1705           vector before parsing it (add any arguments from your
1706           profile to the beginning of the argument vector).  This
1707           also removed the general limit on the number of command line
1708           arguments.
1709
1710 1998-07-04  Richard Coleman  <coleman@math.gatech.edu>
1711
1712         * Released nmh-0.27.
1713
1714         * Added a new command "delete", that is available during
1715           a "whatnow" session.  It is equivalent to "quit -delete".
1716
1717         * Added another parameter to editfile (in whatnowsbr.c),
1718           that controls whether editfile should remember the last
1719           program that was exec'ed.  This way the whatnow command
1720           "mime", will not be re-executed if "edit" is later given
1721           with no arguments.
1722
1723         * Changed whatnowsbr.c, so that whatnow doesn't abort if
1724           mhbuild returns an error.
1725
1726         * Added parameter to sendsbr(), so you may specify whether to
1727           rename the draft file.
1728
1729         * Pass delay time to splitmsg() as a parameter, rather than
1730           use a global variable.
1731
1732         * Moved code to rename draft file after sending message from
1733           splitmsg and sendaux, to sendsbr.
1734
1735         * Removed all the code in viamail to split messages and then
1736           mail them.  Replaced this with the standard sendsbr.c routines.
1737
1738         * Changed sendsbr(), so that when splitting messages into
1739           messages of type "message/partial", the header fields that
1740           are copied are more compliant with RFC-2046.
1741
1742         * Fixed mhbuild to track temporary files better.  They are
1743           now correctly removed when mhbuild aborts.
1744
1745         * Created a new man page for "sendfiles".  The information
1746           about "mhn -viamail" in the "mhn" man page was moved to
1747           this new page.
1748
1749         * Changed the name of the "viamail" shell script to
1750           "sendfiles".  Modified "sendfiles" to use the new
1751           viamail program.
1752
1753         * Moved the functionality for "mhn -viamail" out of mhn,
1754           and into a separate executable called "viamail".
1755
1756         * When storing MIME contents to a folder using mhn -store,
1757           they are now accumulated in a temporary file, and then added
1758           to the folder using folder_addmsg().
1759
1760         * Moved code to save content to a folder from store_content
1761           to new function output_content_folder.
1762
1763         * Moved code to save content to file from store_content to
1764           new function output_content_file.
1765
1766         * Moved code to parse storage format string from store_content
1767           to new function parse_format_string.
1768
1769         * Fix copy_some_headers() in mhstoresbr.c, so that the
1770           correct header fields in the first enclosing message/partial
1771           will be copied (according to RFC2046), when using mhn -store
1772           to reassemble messages of type message/partial.
1773
1774         * Fixed bug to openFTP() in mhparse.c, that caused the
1775           tmp file to not be removed, when transferring a
1776           message/external file from ftp.
1777
1778         * Moved the code in mhparse.c to process -auto switch (scan
1779           contents for the attribute "name"), to a new function
1780           "get_storeproc" in mhstoresbr.c.
1781
1782         * Moved routines to free data structures related to MIME
1783           content from mhparse.c and mhbuildsbr.c, to new file
1784           mhfree.c.
1785
1786         * Moved code to show/display MIME content into new
1787           file mhshowsbr.c.
1788
1789         * Moved code to store MIME content from into
1790           new file mhstoresbr.c
1791
1792         * Moved code to parse MIME content into new
1793           file mhparse.c.
1794
1795         * Moved code to list information about MIME content
1796           into new file mhlistsbr.c.
1797
1798         * Move part_ok(), type_ok(), content_error(), flush_errors(),
1799           and set_endian() to new file mhmisc.c.
1800
1801         * Start to isolate the code to show, list, and store MIME
1802           messages.  One side effect is that only one flag (-show,
1803           -list, or -store) can be used at a time now.
1804
1805         * mhn -store -auto wasn't storing file in correct directory.
1806
1807         * Removed a few dead variables from sbr/ruserpass.c
1808
1809         * move code for creating tmp files, and renaming the
1810           the composition draft in mhbuild, from build_mime()
1811           to main().
1812
1813         * remove left-over code in mhbuild.c, mhbuildsbr.c, for
1814           the -[no]auto switch (which isn't used in mhbuild).
1815
1816         * split mhn.c into mhn.c and mhnsbr.c (name later changed
1817           to mhparse.c).
1818
1819         * split mhbuild.c into mhbuild.c and mhbuildsbr.c.
1820
1821 1998-05-25  Richard Coleman  <coleman@math.gatech.edu>
1822
1823         * Released nmh-0.26.
1824
1825         * Added (unlisted) options [no]dashstuffing to send, post,
1826           and whatnow to determine whether to do RFC934 quoting
1827           (dashstuffing) for encapsulated BCC messages.  The default
1828           is still the same (dashstuffing).
1829
1830         * Changed the undocumented feature "nodashmunging" in forw
1831           and mhl, into the documented feature "nodashstuffing".  The
1832           default for forw, is still "dashstuffing" for backward
1833           compatibility, although I don't believe that bursting
1834           RFC934 digests is very common anymore.
1835
1836         * Added an option to define REALLYDUMB in the default config.h.
1837           But it is not on by default.
1838
1839         * moved creation of config file mts.conf from zotnet/mts
1840           to etc.  This simplified the Makefile in zotnet/mts.
1841
1842         * simplified directory support/general to etc.
1843
1844         * removed unneeded directory support/bboards.
1845
1846         * split getusername() into getusername() and getuserinfo().
1847
1848         * Changed getusr() routine to getusername().
1849
1850         * Slight cleanup in folder_pack.c on code that records the new
1851           number of the "cur" message when packing.
1852
1853 1998-05-08  Richard Coleman  <coleman@math.gatech.edu>
1854
1855         * Released nmh-0.25.
1856
1857         * Change install process, so that hard linking the correct mts
1858           library to libmts.a, is not necessary.  The final link process
1859           uses the original name of the library.
1860
1861         * Fixed bug in flist.c and folder.c, so that symbolic links which
1862           point to directories, will not decrement the number of directory
1863           links remaining.
1864
1865         * Split the function list_content (in mhn.c and mhbuild.c) into
1866           list_content and list_debug.
1867
1868         * Don't pack (folder -pack) an empty folder.
1869
1870         * Exit gracefully in flist.c, if no sequence is specified,
1871           and no "Unseen-Sequence" is given in nmh profile.
1872
1873 1998-02-27  Richard Coleman  <coleman@math.gatech.edu>
1874
1875         * Released nmh-0.24.
1876
1877         * Small clarification to the man page for `ali'.
1878
1879         * Fix bug in inc.c so that if both flags `-file' and `-truncate'
1880           are given, that order doesn't matter.
1881
1882         * Fix bug in seq_list.c when realloc'ing for
1883           large sequence line.
1884
1885 1998-02-23  Richard Coleman  <coleman@math.gatech.edu>
1886
1887         * Released nmh-0.23.
1888
1889         * Add new section on "Transfer Encodings" to man page for mhbuild.
1890
1891         * In mhbuild.c, split compose_content into compose_content
1892           (parse and execute composition string), and scan_content (scan
1893           content, decided transfer encoding, check for clash with boundary
1894           string).  I did a good amount of rearranging of this code.
1895
1896         * Moved definitions for data structures for parsing MIME
1897           messages from mhn.c and mhbuild.c to a new include
1898           file h/mhnsbr.h.
1899
1900         * Small amount of rearranging in sendsbr.c
1901
1902         * Small changes to MAIL.FILTERING file.
1903
1904         * Add the file MAIL.FILTERING to nmh distribution.
1905
1906         * Add line to packf so that if message begins with
1907           "X-Envelope-From:" field, it is converted to "From ".
1908
1909         * Fix packf to add "From " line to beginning of message,
1910           even if Return-Path doesn't exist.
1911
1912         * Add note to MACHINES file that on Linux, configure
1913           doesn't find the functions sigsetjmp/siglongjmp.
1914
1915         * Fix configuration for machines that don't have (or find)
1916           sigsetjmp/siglongjmp.
1917
1918 1998-02-11  Richard Coleman  <coleman@math.gatech.edu>
1919
1920         * Released nmh-0.22.
1921
1922         * Add a configure check for sigsetjmp.  Add some conditional
1923           #define's in h/signals.h in case it's not found.
1924
1925         * Added additional notes about -auto switch in mhn man page.
1926
1927         * Added note about MM_CHARSET environment variable to
1928           mh-profile(5) man page.
1929
1930         * Fix signal problem in mhn.c (change setjmp/longjmp to
1931           sigsetjmp/siglongjmp).
1932
1933 1998-02-09  Richard Coleman  <coleman@math.gatech.edu>
1934
1935         * Released nmh-0.22-pre1.
1936
1937         * Changed the first line in mhl.format from
1938           " -- using template mhl.format -- " to a blank line.
1939
1940         * Added note about automimeproc to mh-profile man page.
1941
1942         * Reorganize the main entry point for parsing a MIME message
1943           or file in mhn.  Add new function parse_file() as new main
1944           entry point for parsing MIME files.
1945
1946         * Add note to mhn man page, that "mhn -file -" will accept the
1947           source message on the standard input.
1948
1949         * Changed a sanity check in folder_realloc that was too strict.
1950
1951         * -norfc934mode is now the default for mhbuild,
1952           rather than -rfc934mode.
1953
1954         * Fix mhbuild, so that Content-Description and RFC-822 comments
1955           from #forw directive will be correctly included if there is
1956           only one message.
1957
1958         * Change mhn to correctly default parts of multipart/digest to
1959           message/rfc822 (leftover code from rfc934mode was removed).
1960
1961         * Restore HP specific code to zotnet/tws/lexstring.c.  Apparently
1962           it is still needed.
1963
1964 1998-02-06  Richard Coleman  <coleman@math.gatech.edu>
1965
1966         * Released nmh-0.21.
1967
1968         * If the file given to mhbuild is "-", then accept the draft on
1969           standard input, and output the MIME message to standard output.
1970
1971         * Cleaned up code in mhbuild.c that decides what transfer
1972           encoding to use.
1973
1974         * Cleaned up code in mhbuild.c that decides what character set
1975           to use for text contents.
1976
1977         * Removed old hpux specific code from zotnet/tws/lexstring.c
1978
1979 1998-02-02  Richard Coleman  <coleman@math.gatech.edu>
1980
1981         * Released nmh-0.21-pre2.
1982
1983         * Added the "decode" variable to mhl.format and mhl.header.
1984
1985         * Added new variable "decode" to mhlsbr.c to decode text in
1986           header fields as per RFC-2047.
1987
1988         * Make sure that when decoding RFC-2047 header fields, that any
1989           spaces at the ends of the encoded text are not ignored, but the
1990           spaces between encoded word are.
1991
1992         * Removed #ifdef's for MIME.  MIME support is always compiled in.
1993
1994         * scan/inc will now decode both Subject and From lines as
1995           RFC-2047 encoded header fields.
1996
1997         * Added new function write_charset_8bit() to sbr.  It returns
1998           the character set to use for 8bit text in composition draft.
1999           Changed mhbuild to use this function.
2000
2001         * Split mhn man page into man pages for mhn and mhbuild.
2002
2003         * mhn -show will only now only use default method for content
2004           of type plain, if it is NOT a part of a multipart/alternative.
2005
2006         * Split mhn -build into mhbuild.  Did some code cleanup.
2007
2008         * Added support for %(decode) to fmtdump.c.
2009
2010         * check_charset() now accepts US-ASCII as a subset of any
2011           ISO-8859-X character set.
2012
2013         * Changed the default "showproc" to mhl, instead of the
2014           pager more.
2015
2016         * When reading file into mhn composition file, only need read
2017           permissions, not write permissions.
2018
2019         * Added own version of strcasecmp to distribution, since
2020           nmh calls it frequently with NULL pointers (ughh).
2021
2022         * Replaced uleq.c with strcasecmp.  Removed uleq.c from
2023           distribution.
2024
2025 1998-01-22  Richard Coleman  <coleman@math.gatech.edu>
2026
2027         * Released nmh-0.21-pre1.
2028
2029         * If a message is missing charset parameter to text/plain, show
2030           will assume US-ASCII, rather than just calling showmimeproc.
2031
2032         * Change show.c and mshcmds.c to use check_charset to see if text
2033           message contains valid character set.
2034
2035         * Added new scan format file "scan.nomime" to support/general
2036           that doesn't do any RFC-2047 decoding.
2037
2038         * Modified all the scan format files in support/general to do
2039           RFC-2047 decoding of Subject field.
2040
2041         * Did more work on sbr/fmt_rfc2047.c, so that it will correctly
2042           ignore whitespace between two valid encoded words, but not
2043           between an encoded word and normal text.
2044
2045         * Created new file sbr/check_charset.c.  Moved code from
2046           fmt_rfc2047.c to check for valid character set to this file.
2047
2048         * Added format escape %(decode) to decode contents of "str" register
2049           as a RFC-2047 header field.
2050
2051         * The command install-mh now recognizes the switches -version
2052           and -help.
2053
2054         * Added a new argument to print_help.c to decide whether to
2055           print profile entries (needed for install-mh to prevent weird
2056           loops).
2057
2058         * Changed folder_read.c and folder_realloc.c so that mp->lowoff
2059           is initialize to max (mp->lowmsg, 1) rather than always 1.
2060
2061         * Changed macros for sequence/attribute manipulation so that
2062           message status array doesn't need to always start at 1.
2063
2064         * Small cleanups in folder_realloc().
2065
2066 1998-01-09  Richard Coleman  <coleman@math.gatech.edu>
2067
2068         * Released nmh-0.20.
2069
2070         * Added configure option --with-pager=PAGER.
2071
2072         * Added configure option --with-editor=EDITOR.
2073
2074         * Changed the default format file for mhl (mhl.format) to
2075           also ignore (not display) the header fields Content-Type,
2076           Content-Transfer-Encoding, and Content-ID
2077
2078         * Fixed core dump in addrsbr.c when using %(proper) format function
2079           and the To: line was missing.
2080
2081         * Added the file ZSH.COMPLETION to the distribution.
2082
2083 1998-01-04  Richard Coleman  <coleman@math.gatech.edu>
2084
2085         * Released nmh-0.20-pre2.
2086
2087         * Added new switch -snoop to both `msgchk' and `inc', so you can
2088           watch the POP transaction.
2089
2090         * Changed "replgroupcomps" to check for Mail-Followup-To header
2091           first, and use it if available.
2092
2093         * Changed "replcomps" to check for Mail-Reply-To header
2094           first, and use it if available.
2095
2096 1998-01-03  Richard Coleman  <coleman@math.gatech.edu>
2097
2098         * Released nmh-0.20-pre1.
2099
2100         * Changed seq_list.c to dynamically enlarge the buffer for
2101           collecting the message ranges in a long sequence line.
2102           This should remove the last hard limit on the size of a
2103           sequence line.
2104
2105         * Changed seq_read.c so that can read long sequence lines.
2106           It will use multiple calls to m_getfld() when m_getfld()
2107           returns the state FLDPLUS.
2108
2109         * Changed brkstring.c to dynamically add more space for pointers
2110           if necessary.  This is needed when splitting up large sequence
2111           lines.
2112
2113         * Did some small cleanups in seq_save.c.
2114
2115         * Added new switches `-[no]unseen' to rcvstore, to control
2116           whether new messages are added to Unseen-Sequence.
2117
2118         * Moved locking routines (zotnet/mts/lock.c) to sbr/lock_file.c
2119
2120         * Changed the internal UNSEEN flag to SELECT_UNSEEN which is
2121           more appropriate.  Changed the MHPATH flag to ALLOW_NEW.
2122
2123         * Changed "replcomps" to not include CC and TO lines so that
2124           that reply message is only directed at the author of the
2125           message to which you are replying.
2126
2127         * Added new switch `-group' to command repl, which causes repl
2128           to use new forms file "replgroupcomps".  This is intended for
2129           making group replies.
2130
2131         * Removed #ifdef for ATHENA.
2132
2133 1997-12-28  Richard Coleman  <coleman@math.gatech.edu>
2134
2135         * Released nmh-0.19.
2136
2137         * Fix repl,forw so that switch `-form file' will not abort
2138           as ambiguious (silly mistake on my part).
2139
2140         * Cleaned up the mhn man page.  Added info about a few escapes
2141           for the formatting/display strings that were not documented
2142           (%%, %t).  Moved the BNF grammar for the mime composition file,
2143           to the end of the man page.
2144
2145         * Added the options -[no]format to the command repl.  The
2146           switch `-format' will filter the message to which you are
2147           replying with the standard message filter "mhl.reply", which
2148           is now included in the distribution.  The `-noformat' option
2149           will negate the use of -format or -filter and not include
2150           the message to which you are replying in the draft.
2151
2152         * Did some cleaning and reorganization on many of the man
2153           pages.
2154
2155         * Added debugging switch `-debug' to mhparam, which displays
2156           the values of all `procs' (and some other misc configuration
2157           info) that nmh keeps in global variables.
2158
2159         * When using `refile -preserve', if a conflict occurs, then use
2160           the next available number above the message number you wish
2161           to preserve.
2162
2163         * In forw.c, split the code for creating MIME style forwarding
2164           out of copy_draft, and into copy_mime_draft.
2165
2166         * Move routines in mark.c to print sequences, into new
2167           file sbr/seq_print.c
2168
2169         * flist will now update the current folder.
2170
2171         * Added the switches -[no]fast to flist, to replace
2172           -[no]total.  The previous switches are still accepted
2173           but now undocumented.
2174
2175         * More reorganization in flist of the code for
2176           traversing folders.
2177
2178         * The command "flist +foo -all" will now scan the folder
2179           "foo" and all its 1st level children.
2180
2181         * Add missing include file <h/mh.h> to sbr/snprintf.c
2182
2183         * Fix alarm bug in rcvtty, so that when it calls external
2184           process, the alarm is never longer than 30 minutes.
2185
2186 1997-12-17  Richard Coleman  <coleman@math.gatech.edu>
2187
2188         * Released nmh-0.18.
2189
2190         * Fixed bug in mark, so that "mark -list -seq foo" will
2191           correctly indicate if "foo" is a private sequence.  I found
2192           this bug mentioned in Jerry Peek's book.
2193
2194         * Simplified the code in seq_setcur(), since seq_addmsg() now
2195           retains the public/private status of sequences.
2196
2197         * Changed sequence handling so that if the switches -public
2198           or -nopublic, are not specified for the commands mark, pick,
2199           or rcvstore, then existing sequences will retain their
2200           previous public/private status.
2201
2202         * mhparam now handles the mh-sequences profile entry
2203           correctly.
2204
2205         * flist -all will now also check readonly folders (for
2206           private sequences).
2207
2208         * Improve the leaf optimization for folder command.
2209           It will now track the number of directories in a folder,
2210           and stop stat'ing files once it has hit all the subfolders.
2211
2212         * Renamed m_getfolder to getfolder.  Changed getfolder to
2213           take option to determine whether it should get current
2214           folder, or just default folder (Inbox).  Changed rcvstore,
2215           inc, and rmf to use the new getfolder.
2216
2217         * flist now indicates if a sequence is private.
2218
2219         * Change WUNTRACED to 0, in pidwait.c, so that commands will
2220           wait for stopped processes.
2221
2222         * conflict will dynamically allocate space for group names,
2223           so it can now handle system with more than 100 groups.
2224
2225 1997-12-09  Richard Coleman  <coleman@math.gatech.edu>
2226
2227         * Released nmh-0.18-pre4.
2228
2229         * Check if we have enough message status space, before we
2230           call folder_realloc() in burst, mhpath, and m_draft().
2231
2232         * mhn will now correctly identify a formatting string of "-"
2233           for the option -store, and send content to stdout.
2234
2235         * Change the way that memory for message status is
2236           allocated.  It is dynamcially allocated separately from
2237           the folder/message structure.  This required changing
2238           folder_read.c, folder_realloc.c, folder_free.c.
2239
2240         * Removed all the MTR code (experimental code for message
2241           status allocation).
2242
2243         * Renamed m_readfolder.c to folder_read.c and simplified
2244           the code.
2245
2246         * Renamed m_freefolder.c to folder_free.c.
2247
2248         * Add function trim() to slocal.c to pretty print
2249           the debugging output.
2250
2251         * Changed the name of m_packfolder() to folder_pack().
2252           Changed the name of m_remsg() to folder_realloc().
2253
2254 Wed Dec  3 23:33:38 1997  Richard Coleman  <coleman@math.gatech.edu>
2255
2256         * Released nmh-0.18-pre3.
2257
2258         * Changed installation to add `flists' which is hard linked
2259           to `flist'.  This is a equivalent to `flist -all'.
2260
2261         * For flist, -showzero is on by default.
2262
2263         * Major changes to flist.  Default is now for flist to search
2264           current folder.  The switch `-all' is now used to specify
2265           searching all top level folders.  The new switch `-showzero'
2266           is used to print out folders that don't contain any messages
2267           in the given sequence.
2268
2269         * Split BuildFolderList in flist.c into 2 functions
2270           (BuildFolderList, BuildFolderListR).  Changed these functions
2271           so that flist now does better leaf optimization, and will stop
2272           stat'ing directory entries when it knows it has hit all the
2273           subdirectories of a given directory.
2274
2275         * Reorganized code in folder.c, so that all relevant folders
2276           are scanned first and information recorded.  Then all the
2277           folder summaries at printed out at one time.
2278
2279         * Made the options of folder(s) more orthogonal.  Now
2280           "folder -all -noheader -nototal" will do the right thing.
2281
2282         * Added `-noall' switch to folder, for completeness.
2283
2284         * Changed the default mode for creation of new folders
2285           to 0700 (was 0711).
2286
2287         * Slightly changed the format for flist.  It now indicates
2288           if a folder is current.  Also the width of the various
2289           fields are now calculated at runtime.
2290
2291         * Changed the format for folder(s).  Folder names
2292           are now left justified.  The width of the various fields
2293           are calculated at runtime.
2294
2295 Sun Nov 30 19:14:53 1997  Richard Coleman  <coleman@math.gatech.edu>
2296
2297         * Released nmh-0.18-pre2.
2298
2299         * Add paragraph to man page for install-mh and to INSTALL file
2300           about checking for global mh.profile.
2301
2302         * Renamed m_find() to context_find().
2303           Renamed m_replace() to context_replace().
2304           Renamed m_delete() to context_del().
2305           Renamed m_update() to context_save().
2306           Renamed m_getdefs() to context_read().
2307           Renamed m_foil() to context_foil().
2308
2309         * Change rcvstore to use routine folder_addmsg(), instead of
2310           adding message to folder itself.
2311
2312         * Changed refile, so that if the switch -preserve is used,
2313           and a conflict occurs for a particular folder, then folder_addmsg()
2314           will just use next highest available number for that folder,
2315           instead of exiting.
2316
2317         * Make folder_addmsg() more robust.  It will make repeated
2318           attempts to link file into folder if link returns with
2319           the error EEXIST.
2320
2321         * Fix bug, so that that if forking sendmail, HELO will be sent
2322           unless clientname: option is defined but empty (so now it
2323           is the same as the direct smtp code).
2324
2325         * Changed sprintb to snprintb (now we pass the buffer length
2326           to new routine).  Changed code to use new function.
2327
2328         * Added snprintf to sbr. Added configure check to build it
2329           if you don't have a native version (but haven't changed much
2330           code to use it yet).
2331
2332 Thu Nov 13 18:42:18 1997  Richard Coleman  <coleman@math.gatech.edu>
2333
2334         * Released nmh-0.18-pre1.
2335
2336         * Fixed alarm bug in slocal, so that alarm is never
2337           called with a value larger than 30 mintues.
2338
2339         * Fixed race condition in rmm and refile, so that
2340           context is updated before external rmmproc is called.
2341
2342         * Removed all the OVERHEAD code.
2343
2344         * Move code to add message to folder from refile.c
2345           to folder_addmsg.c
2346
2347 Fri Jul 25 19:39:29 1997  Richard Coleman  <coleman@math.gatech.edu>
2348
2349         * Did some rearranging of the internals of inc.c.
2350
2351         * Make -inplace the default for anno, forw, dist, and repl.
2352
2353         * Changed --enable-smtp to --with-mts={smtp,sendmail}
2354
2355         * Created new directory mts/sendmail for direct sendmail
2356           interface (although it currently still uses SMTP).
2357
2358         * Removed all the TMA (trusted mail agent) code
2359
2360         * Removed all the TTYD (terminal access daemon) code
2361
2362         * Removed all the MF (uucp filtering) code.
2363
2364         * Removed all the code for BERK.
2365
2366         * Removed all the code for stand-alone delivery (MHMTS).
2367
2368         * Split the file mts/sendmail/smail.c into sendmail.c and
2369           smtp.c.  Changed the name of the directory to mts/smtp.
2370
2371         * Changed autoconf to use @sysconfdir@ for location of
2372           configuration files.
2373
2374         * Changed #define in mhn.c from FTP to BUILTIN_FTP.
2375
2376 Mon Jul 21 03:22:34 1997  Richard Coleman  <coleman@math.gatech.edu>
2377
2378         * Released nmh-0.17.
2379
2380         * MAKEDEFS weren't passed down to recursive makes correctly.
2381
2382         * slocal.c now checks for UTMP_FILE and _PATH_UTMP instead
2383           of hard-coding "/etc/utmp".
2384
2385         * rcvtty.c check for _PATH_UTMP if UTMP_FILE is not
2386           defined.
2387
2388         * Remove configure checks for ulong and ushort.  Changed
2389           code to just use unsigned {short, long}.
2390
2391         * Change addmsg function in refile.c to return new
2392           number of refiled message.
2393
2394         * Added check in get_returnpath for empty unixbuf.
2395
2396         * Cleanup of sbr/pidstatus to use more POSIX macros
2397           for return value of wait().
2398
2399         * Change configure to also check /bin for "more".
2400
2401 Sat Jul 12 00:02:23 1997  Richard Coleman  <coleman@math.gatech.edu>
2402
2403         * Released nmh-0.16.
2404
2405 Mon Jun 23 20:13:24 1997  Richard Coleman  <coleman@math.gatech.edu>
2406
2407         * Added automimeproc, which should replace automhnproc.
2408
2409         * multipart messages will no longer abort for messages
2410           of type 8bit or binary (although we still can't really
2411           deal with binary messages, yet).
2412
2413         * Fix double free of c_storage.  From John MacMillan.
2414
2415         * mhn now treats unknown subtypes of "text" as text/plain.
2416
2417         * mhn changed so that specifying mhn-show-multipart, or
2418           mhn-show-multipart/{mixed, alternate, etc...) will override
2419           the use of the internal method for displaying these types.
2420           Previously mhn would always use the internal method for subtypes
2421           mixed, alternate, digest, and parallel (even if an alternate
2422           method was specified in mhn.defaults).
2423
2424         * mhn show treats unknown subtypes of multipart, as type
2425           multipart/mixed (as specified RFC2046).
2426
2427         * mhn checks for the parameter "name" rather than "x-name".
2428           From MH-6.8.4 patch.
2429
2430         * Fix double free of ctinfo in user_content when using
2431           #forw with single message.  From John MacMillan (and
2432           MH-6.8.4 patch).
2433
2434         * Changed -mhnproc switch for show, to -showmimeproc.
2435
2436         * Changed profile entry "mhnproc" to "showmimeproc".
2437
2438         * Added "mime" option to "whatnow", which calls the program
2439           "buildmimeproc" (default is mhn -build) to process MIME
2440            composition files.
2441
2442         * Added -build switch to mhn, to process MIME composition
2443           files.
2444
2445         * Did some reorganizing of mhn.c.
2446
2447         * Changed casting in mts/sendmail/smail.c from (char) to
2448           (signed char) so SMTP reply codes work correctly for machines
2449           which used unsigned chars by default.
2450
2451 Sat Jun 21 01:21:47 1997  Richard Coleman  <coleman@math.gatech.edu>
2452
2453         * Released nmh-0.15.
2454
2455         * Added new form "scan.unseen" to distribution.  It marks messages
2456           which are in any sequence in Unseen-Sequence.
2457
2458         * Do some rearranging of date/time code in zotnet/tws/dtime.c
2459
2460         * Fix sign extension bugs in fmt_scan.c.
2461
2462         * Fix m_atoi.c so that strings ending in non-digit characters
2463           return 0.
2464
2465         * Split code in burst.c so that finding delimiters of digested
2466           messages and bursting a message into multiple messages are
2467           two separate functions (find_delim and burst).
2468
2469         * Add workaround fo AC_PATH_PROG in configure.in, so
2470           that BSD4.4 machines can find sendmail, vi, more.
2471
2472         * Added "-width" option to rcvtty.
2473
2474         * Change a few variable names in zotnet/mts/client.c since
2475           they conflict with defines on AIX.
2476
2477         * Makefile in zotnet/tws assumes lexing of dtimep.lex was
2478           unsuccessful if resulting file is less than 500 lines long
2479           (rather than 10, which was previous value), since AIX
2480           sed gives mangled file of about 200 lines.
2481
2482         * Extract code in rcvstore.c to link message into folder,
2483           and put in own subroutine.
2484
2485         * Extract code in refile.c to link message into folder,
2486           and put in own subroutine.
2487
2488         * Moved code to remove messages from folder into own
2489           routine "folder_delmsgs" in sbr.  Changed rmm.c and
2490           refile.c to use new routine.
2491
2492 Fri May 16 06:09:31 1997  Richard Coleman  <coleman@math.gatech.edu>
2493
2494         * Renamed m_seqok to seq_nameok.
2495
2496         * Changed m_setunseen, msh, mshcmds, flist, and scan to use
2497           seq_getnum.
2498
2499         * Changed m_seqflag to return the number of a sequence rather
2500           than its bit flag.  Changed its name to seq_getnum and renamed
2501           file to sbr/seq_getnum.c.
2502
2503         * Removed function m_seqnew and file sbr/m_seqnew.c since it is
2504           no longer used.
2505
2506         * Added zero switch to m_seqadd function to zero out bits before
2507           adding message to sequence.
2508
2509         * Renamed function m_setvis to m_setunseen, and renamed
2510           corresponding file in sbr.
2511
2512         * Renamed function m_setseq to m_setprev, and renamed corresponding
2513           file in sbr.
2514
2515         * Changed mark.c and pick.c to use m_seqaddsel and m_seqdelsel.
2516
2517         * Added new function m_seqdelsel to m_seqdel.c, which deletes
2518           all selected messages from a sequence.
2519
2520         * Added new function m_seqaddsel to m_seqadd.c, which adds all
2521           selected messages to a sequence.
2522
2523         * Split sbr/m_seqnew.c into m_seqadd.c, m_seqdel.c, m_seqnew.c,
2524           and m_seqok.c.
2525
2526 Thu May 15 00:53:17 1997  Richard Coleman  <coleman@math.gatech.edu>
2527
2528         * Renamed function pack_folder to m_packfolder, and moved it
2529           from uip/folder.c into its own file sbr/m_packfolder.c
2530
2531 Wed May 14 23:38:00 1997  Richard Coleman  <coleman@math.gatech.edu>
2532
2533         * Changed function m_gmsg to m_readfolder.  Renamed file
2534           sbr/m_gmsg.c to sbr/m_readfolder.c.
2535
2536 Mon May  5 19:57:11 1997  Richard Coleman  <coleman@math.gatech.edu>
2537
2538         * Expanded rcvtty man page, and added small patch from
2539           MH-6.8.4 distribution.
2540
2541 Fri May  2 15:24:34 1997  Richard Coleman  <coleman@math.gatech.edu>
2542
2543         * Released nmh-0.14.
2544
2545         * Comment out configure test and code for tgetent to allocate its
2546           own termcap buffer when passed a NULL argument.
2547
2548 Sat Apr 26 03:46:38 1997  Richard Coleman  <coleman@math.gatech.edu>
2549
2550         * Added new options `-checkmime', `-nocheckmime', and `-mhnproc'
2551           to show.  Restructured code to handle options to various
2552           `procs' better.  Deprecated `-noshowproc' option and NOMHNPROC
2553           environment variable.
2554
2555         * Added new man page `mh-draft' which documents the
2556           draft folder facility in nmh.
2557
2558         * Renamed fmtsbr.h to fmt_scan.h.  Renamed fmtcompile.h
2559           to fmt_compile.h.
2560
2561         * split fmtsbr.c into fmt_scan.c and fmt_new.c.  Renamed
2562           fmtcompile.c to fmt_compile.c, and formataddr.c to
2563           fmt_addr.c.
2564
2565         * `send -help' wasn't showing the -(no)mime and -split
2566           options.
2567
2568 Fri Apr 25 02:50:36 1997  Richard Coleman  <coleman@math.gatech.edu>
2569
2570         * Released nmh-0.13.
2571
2572         * Changed mhpath so it doesn't abort if a message sequence
2573           such as "mhpath all" expands to more than 1000 messages.
2574           Also mhpath now dynamically reallocated space for message
2575           names (The number of command line arguments is still limited
2576           to MAXARGS).
2577
2578         * Did some general restructuring of the code in folder.c
2579           that checks for folder information, and prints it.
2580
2581 Thu Apr 24 01:04:37 1997  Richard Coleman  <coleman@math.gatech.edu>
2582
2583         * Changed `folder' to reallocate space for folder names if
2584           necessary.  So `folders' can now handle more than 300 folders.
2585
2586 Tue Apr 22 14:01:26 1997  Richard Coleman  <coleman@math.gatech.edu>
2587
2588         * Change configure to use a compile check to see if the tm struct
2589           has tm_gmtoff, rather than using egrep.
2590
2591 Mon Apr 21 02:19:17 1997  Richard Coleman  <coleman@math.gatech.edu>
2592
2593         * Released nmh-0.12.
2594
2595         * Had set_exists and unset_exists macros backwards.
2596
2597         * Released nmh-0.11.
2598
2599 Thu Apr 10 02:39:53 1997  Richard Coleman  <coleman@math.gatech.edu>
2600
2601         * Added documentation to mh-profile.man about the various
2602           `procs' (mhlproc, showproc, lproc, etc...).
2603
2604         * Replace the bit twiddling for SELECTED, UNSEEN, and
2605           mp->attrstats with macros.
2606
2607         * If system doesn't have SIGEMT (like Linux), then use SIGTERM
2608           in msh.c instead.
2609
2610         * Change fstat to stat in m_gmsg.c since Linux wants
2611           to hide dd->dd_fd.
2612
2613         * Merge Linux patch sent in by Michel Oosterhof (original
2614           patch from bsa@kf8nh.wariat.org).
2615
2616         * Document an undocumented MH feature.  mhn -form mhl.null
2617           will suppress the display of the message header.
2618
2619         * mhparam will now return "mhparam etcdir".
2620
2621         * Add catproc to /config/config.c and use that in show.c
2622           and mshcmds.c, rather than hard coding in /bin/cat.
2623
2624         * Add mhnproc to the list of `procs' in mh-profile.man.
2625
2626         * Add configure test for lorder and tsort commands.
2627
2628         * Commented out the padding in the `msgs` struct in h/mh.h
2629
2630         * Change m_gmsg.c to allocate elements to the `info' array by
2631           500 elements at a time (rather than MAXFOLDERS / 5).
2632
2633         * Add note to man page for mhmail that zero length messages are
2634           not sent.  Need to use -body "" to send empty messages.
2635
2636         * zotnet/mts/mts.c : compare character with '\0', not NULL.
2637
2638         * sbr/getcpy.c : assign '\0' to character, not NULL.
2639
2640         * add m_fmsg to most programs in uip so that they explicitly free
2641           folder/message structure when done with folder.
2642
2643         * uip/slocal.c : cleanup processing of sender.  Make sure it is
2644           defined even if message is missing "From " line.
2645
2646 Mon Mar 31 03:37:35 1997  Richard Coleman  <coleman@math.gatech.edu>
2647
2648         * Released nmh-0.10.
2649
2650 Sun Mar 30 21:46:17 1997  Richard Coleman  <coleman@math.gatech.edu>
2651
2652         * Add configure check for <locale.h>.  Turn on LOCALE support
2653           by default.
2654
2655 Thu Mar 20 03:21:24 1997  Richard Coleman  <coleman@math.gatech.edu>
2656
2657         * Reversed previous decision to retain "From " lines in slocal.
2658           The "From " line is now removed from all messages.
2659
2660         * inc now saves the date from the "From " envelope in the
2661           Delivery-Date header for all messages.
2662
2663         * sbr/m_getfld.c: Clean up processing of Return-Path and
2664           Delivery-Date from the "From " envelope.
2665
2666 Mon Mar 17 19:03:36 1997  Richard Coleman  <coleman@math.gatech.edu>
2667
2668         * client.c: cast iaddr to int before comparing return value
2669           of inet_addr with NOTOK.
2670
2671 Tue Mar 11 04:38:10 1997  Richard Coleman  <coleman@math.gatech.edu>
2672
2673         * Grep test for signal names was failing on some OS'es because
2674           of missing tabs in regex.
2675
2676 Sat Mar  8 01:58:22 1997  Richard Coleman  <coleman@math.gatech.edu>
2677
2678         * Released nmh-0.09.
2679
2680         * Move config files and format files to *.old before installing.
2681
2682         * Add configure check for killpg.
2683
2684         * msh.c: include <termios.h> instead of <termio.h> and
2685           <sys/ioctl.h>.
2686
2687         * prompter.c: don't include <sys/ioctl.h> anymore.
2688
2689 Thu Mar  6 04:03:24 1997  Richard Coleman  <coleman@math.gatech.edu>
2690
2691         * Added `-mime' and `-nomime' options to `repl'.
2692           From MH-6.8.4 diff.
2693
2694 Tue Mar  4 03:10:37 1997  Richard Coleman  <coleman@math.gatech.edu>
2695
2696         * ruserpass.c : removed conflicting prototypes.
2697
2698         * rcvtty.c : Fixed rcvtty to obey terminal permissions granted
2699           by `mesg' command.  Previously only worked on BSD machines.
2700
2701 Mon Mar  3 00:18:59 1997  Richard Coleman  <coleman@math.gatech.edu>
2702
2703         * rcvtty.c : Changed to use #define UTMP_FILE (if exists) rather
2704           than hard coded "/etc/utmp".
2705
2706         * Released nmh-0.08.
2707
2708         * Changed slocal to lock .maildelivery (or file given by -maildelivery)
2709           when accessing ndbm/db file for duplicate suppression, instead of
2710           locking database itself.
2711
2712 Thu Feb 27 05:28:09 1997  Richard Coleman  <coleman@math.gatech.edu>
2713
2714         * Added slocal action `mmdf' to deliver to a file in mmdf format.
2715
2716         * Changed the slocal actions `file' and `>' to always deliver in
2717           mbox (uucp) format rather than be determined by RPATHS config
2718           option.
2719
2720         * Changed the slocal action `mbox' to deliver in mbox (uucp) format
2721           rather than mmdf format.
2722
2723         * slocal now adds Delivery-Date field to all messages (previously it
2724           only added it to messages when delivering them to a file). The
2725           "From " line is now retained on all messages if compiling with
2726           RPATHS, rather than being discarded.
2727
2728         * rcvpack no longer adds the Delivery-Date field to messages.
2729
2730 Sun Feb 23 22:03:54 1997  Richard Coleman  <coleman@math.gatech.edu>
2731
2732         * Removed the script packmbox, since it's functionality has been
2733           added to packf.
2734
2735         * Changed packf so that it uses mbox (uucp) format by default
2736           rather than mmdf format.  Added options -mbox and -mmdf to
2737           packf so you can choose the preferred format.
2738
2739         * Changed rcvpack so that it uses mbox (uucp) format by default
2740           rather than mmdf format.  Added options -mbox and -mmdf to
2741           rcvpack so you can choose the preferred format.
2742
2743 Tue Feb 18 00:01:05 1997  Richard Coleman  <coleman@math.gatech.edu>
2744
2745         * Changed nmh to use dot locking by default (although you
2746           can still easily change this in config.h).
2747
2748         * Simplified locking code.  Removed code allowing setting of
2749           locking type in mts.conf.  Now the locking type and locking
2750           directory (if any) can only be set at compile time.
2751
2752 Fri Feb 14 02:49:18 1997  Richard Coleman  <coleman@math.gatech.edu>
2753
2754         * Prefer getting timezone information from tm->gmtoff rather
2755           than tzset and external timezone variable.
2756
2757 Thu Feb 13 00:35:45 1997  Richard Coleman  <coleman@math.gatech.edu>
2758
2759         * Fixed typo in ruserpass.c in the variable toktabs.
2760
2761         * When ruserpass was added to LIBOBJS, it was missing
2762           the suffix.
2763
2764         * Released nmh-0.07.
2765
2766 Tue Feb 11 01:29:47 1997  Richard Coleman  <coleman@math.gatech.edu>
2767
2768         * Add check to configure, so that if ruserpass, or _ruserpass
2769           is not found, build version of ruserpass in sbr.
2770
2771         * Added define's to discard.c, m_getfld.c, and scansbr.c so
2772           the code that manipulates internals of stdio, will build
2773           on SCO 5.x.
2774
2775         * Added #define to control whether to compile the simple
2776           built-in FTP client in mhn.
2777
2778         * Added configure check for ushort and ulong.  Change code
2779           to use ushort/ulong rather than u_short/u_long.
2780
2781         * A couple of small cleanups in locking code.
2782
2783         * Added configure check for gmtoff element in struct tm.
2784
2785         * Added configure check for tzset.
2786
2787 Fri Feb  7 03:01:57 1997  Richard Coleman  <coleman@math.gatech.edu>
2788
2789         * Released nmh-0.06.
2790
2791         * Removed code for machines that don't have socket
2792           interface (how could they get mail anyway?).
2793
2794         * Removed code for BSD41 machines.  I don't think there are
2795           many such machines around anymore.
2796
2797         * Add configure check for function uname, and prefer it
2798           over gethostname.  General cleanup of zotnet/mts/mts.c.
2799
2800         * Change all `lseek' calls to use POSIX symbolic constants
2801           SEEK_SET, SEEK_CUR, SEEK_END.
2802
2803 Thu Feb  6 01:16:30 1997  Richard Coleman  <coleman@math.gatech.edu>
2804
2805         * Check lex generated file in zotnet/tws and use
2806           pre-generated version if necessary.
2807
2808         * Released nmh-0.05.
2809
2810         * Change to use reliable signals on all platforms that have
2811           sigaction.  Change so that interrupted system calls are
2812           restarted for all signals except SIGALRM.  This fixes alarm
2813           handling code in smail.c for BSD based systems.
2814
2815         * Added lorder and tsort commands so that created libs can
2816           be linked in one pass.
2817
2818 Tue Feb  4 01:33:00 1997  Richard Coleman  <coleman@math.gatech.edu>
2819
2820         * Changed pidwait so that while it is waiting for a child,
2821           it should block signals rather than ignore them.
2822
2823 Mon Feb  3 21:05:30 1997  Richard Coleman  <coleman@math.gatech.edu>
2824
2825         * Add checks to configure for dbm_open and -lndbm.
2826
2827 Thu Jan 30 05:15:42 1997  Richard Coleman  <coleman@math.gatech.edu>
2828
2829         * folder -pop and folder -push were freeing some memory too
2830           quickly, which caused the entry popped from the stack to not
2831           become the current folder.
2832
2833 Wed Jan 29 01:28:02 1997  Richard Coleman  <coleman@math.gatech.edu>
2834
2835         * Released nmh-0.04.
2836
2837         * Define ospeed and PC in termsbr.c is OS doesn't have
2838           it.
2839
2840 Sun Jan 26 20:25:10 1997  Richard Coleman  <coleman@math.gatech.edu>
2841
2842         * editfile will create a symbolic link to the altmsg if it
2843           can't make a link, on any machine supporting lstat.  Formerly
2844           this would happen only on BSD42 based machines.
2845
2846 Sat Jan 25 22:54:26 1997  Richard Coleman  <coleman@math.gatech.edu>
2847
2848         * traverse (in popsbr.c) wasn't calling va_start before using
2849           variable argument list.  Fixes core dump in inc when using POP.
2850
2851 Fri Jan 24 03:27:59 1997  Richard Coleman  <coleman@math.gatech.edu>
2852
2853         * The variable pass in remotemail needed to be set to
2854           NULL.  (From MH-6.8.4 diff).  Fixes core dump of msgchk when
2855           using POP.
2856
2857         * inc and msgchk were using -rpop by default when configured
2858           with POP support.  Default is now -norpop.
2859
2860 Thu Jan 23 02:01:17 1997  Richard Coleman  <coleman@math.gatech.edu>
2861
2862         * By default, post will now give the SMTP HELO command with
2863           the local hostname.  If you specify a hostname with the
2864           clientname: option in mts.conf file, post will give the
2865           HELO command with that name instead.  If the argument to the
2866           clientname: option is empty, no HELO command is given.
2867           (From the MH-6.8.4 diff)
2868
2869 Wed Jan 22 01:55:45 1997  Richard Coleman  <coleman@math.gatech.edu>
2870
2871         * When using `-help' for a command, it will also print its
2872           profile compents from .mh_profile. (From MH-6.8.4 diff)
2873
2874         * "slocal -file" will now correctly takes its input from
2875           a file (currently need to specify full path).
2876
2877 Sun Jan 19 20:37:21 1997  Richard Coleman  <coleman@math.gatech.edu>
2878
2879         * "slocal -debug" will now issue a warning if a non-blank
2880           line in the .maildelivery file has less than 5 fields.
2881
2882 Sat Jan 18 02:26:41 1997  Richard Coleman  <coleman@math.gatech.edu>
2883
2884         * Changed slocal so that code for duplicate suppression
2885           (MH config was MSGID) is always built. Added the options
2886           -[no]suppressdup to slocal to turn this on/off.
2887
2888 Thu Jan 16 00:26:34 1997  Richard Coleman  <coleman@math.gatech.edu>
2889
2890         * Released nmh-0.03.
2891
2892         * Fixed problem where mark would core dump if no
2893           .mh_sequence file existed.
2894
2895         * Fixed problem where slocal would core dump if -debug
2896           option was given, and certain headers were missing.
2897
2898         * Added patch to slocal to add `folder' (+) action, which
2899           is shorthand for piping message to rcvstore.  Updated
2900           man page.
2901
2902 Wed Jan 15 21:30:17 1997  Richard Coleman  <coleman@math.gatech.edu>
2903
2904         * Changed flist option -unseen to -[no]all.  Cleaned up
2905           flist man page.
2906
2907 Fri Jan 10 20:36:33 1997  Richard Coleman  <coleman@math.gatech.edu>
2908
2909         * Fixed flist.  Changed the profile component `Folder-Order'
2910           to `Flist-Order.  Added option `-sequence' to flist, so
2911           you can specify the name of the sequence to search for.
2912
2913 Thu Jan  9 00:20:48 1997  Richard Coleman  <coleman@math.gatech.edu>
2914
2915         * A few minor portability cleanups.  Changed to use PATH_MAX
2916           rather than MAXPATHLEN.  Don't assume ospeed variable exists
2917           in termsbr.c.  Removed some conflicting prototypes.
2918
2919 Wed Jan  8 11:05:02 1997  Richard Coleman  <coleman@math.gatech.edu>
2920
2921         * Add configure test to check if tgetent will accept NULL
2922           and allocate its own buffer.  Borrowed from zsh.
2923
2924         * Changed libpath to etcpath.
2925
2926 Mon Jan  6 04:15:35 1997  Richard Coleman  <coleman@math.gatech.edu>
2927
2928         * Cleaned up source code and Makefiles, so that if your `make'
2929           supports the VPATH option, you can build nmh in a different
2930           directory from where the source code is located.
2931
2932 Fri Jan  3 05:05:18 1997  Richard Coleman  <coleman@math.gatech.edu>
2933
2934         * Released nmh-0.02.
2935
2936 Wed Jan  1 17:41:52 1997  Richard Coleman  <coleman@math.gatech.edu>
2937
2938         * Split mhook man page into man pages for rcvdist, rcvpack,
2939           and rcvtty.
2940
2941 Tue Dec 31 03:07:48 1996  Richard Coleman  <coleman@math.gatech.edu>
2942
2943         * Changed code to use strerror, rather than using sys_errlist
2944           and sys_nerr directly.
2945
2946 Mon Dec 30 02:15:25 1996  Richard Coleman  <coleman@math.gatech.edu>
2947
2948         * -compat switch from install-mh removed.
2949
2950         * Changed the default POP port from "pop" to "pop3".
2951
2952 Sat Dec 28 13:25:05 1996  Richard Coleman  <coleman@math.gatech.edu>
2953
2954         * Changed mhn_defaults to mhn.defaults.  Changed create_mhn_defaults
2955           (again) to mhn.defaults.sh.  Changed find_program (again) to
2956           mhn.find.sh.  mhn.defaults.sh now takes the search path
2957           as an argument.  Default search path is now specified in Makefile
2958           rather than in script.
2959
2960 Fri Dec 27 16:34:01 1996  Richard Coleman  <coleman@math.gatech.edu>
2961
2962         * Changed mtstailor file to mts.conf.  Updated man pages.
2963
2964         * Changed si_value to si_val in mhn.c, since it conflicts with
2965           macro defined on Solaris.
2966
2967 Thu Dec 26 02:50:15 1996  Richard Coleman  <coleman@math.gatech.edu>
2968
2969         * Added --enable-nmh-mhe (and --disable-nmh-mhe) to enable/disable
2970           support for Emacs front-end mhe.  It is on by default.
2971
2972         * Added the following configure options: --enable-nmh-pop to
2973           enable client side pop support, --enable-nmh-smtp to enable
2974           SMTP support.  Client-side pop support now compiles.  Man
2975           pages for inc, msgchk, mh-chart now correctly added pop
2976           options if enabled.
2977
2978 Tue Dec 24 14:33:20 1996  Richard Coleman  <coleman@math.gatech.edu>
2979
2980         * Added configure test for bug in C libraries where linker
2981           can't find ruserpass, but can find _ruserpass.
2982
2983         * Fixed configure test so that termcap variable ospeed is
2984           correctly found.
2985
2986 Mon Dec 23 19:40:17 1996  Richard Coleman  <coleman@math.gatech.edu>
2987
2988         * Source files converted to ANSI C.
2989         
2990         * md5 now compiled separately rather than being included
2991           in mhn.c.  Changed md5 to use memset and memcpy.
2992
2993 Fri Dec 20 02:29:37 1996  Richard Coleman  <coleman@math.gatech.edu>
2994
2995         * Collected the error routines adios, advise, admonish, and advertise
2996           into one file (error.c), and did some rearranging of the code.
2997
2998 Thu Dec 19 19:05:29 1996  Richard Coleman  <coleman@math.gatech.edu>
2999
3000         * Added awk script sigmsg.awk (originally written by
3001           Geoff Wing <mason@werple.apana.org.au> for zsh) to
3002           automatically generate signal messages for pidstatus.c.
3003           Added files sbr/signals.c, h/signals.h.  Code now uses
3004           sigprocmask to block signals (if available).  Code now uses
3005           signal blocking on non-BSD machines.
3006
3007 Wed Dec 18 01:55:17 1996  Richard Coleman  <coleman@math.gatech.edu>
3008
3009         * Add configure check for ATTVIBUG.  From Soren's mh autoconf work.
3010
3011         * Released nmh-0.01.
3012
3013         * Added configure code to check for type of signals functions
3014           you have (POSIX or BSD style signals).  Added function
3015           SIGPROCMASK to simulate sigprocmask on machines that don't
3016           have POSIX signals.
3017
3018 Fri Dec 13 19:40:48 1996  Richard Coleman  <coleman@math.gatech.edu>
3019
3020         * Added -version switch to all commands.  Also added to
3021           their man pages.
3022
3023 Mon Dec  9 16:36:54 1996  Richard Coleman  <coleman@math.gatech.edu>
3024
3025         * Renamed uip/trmsbr.c to termsbr.c and changed it to use
3026           POSIX termios.h style functions if present.
3027
3028 Tue Dec  3 16:18:39 1996  Richard Coleman  <coleman@math.gatech.edu>
3029
3030         * Changed support/general/bootmhn.sh to output new mhn_defaults
3031           file to standard output by default (makes it easier for testing).
3032           Changed name of script to create_mhn_defaults.  Changed bootmhn.findit
3033           script to find_program.
3034
3035 Sun Dec  1 10:00:00 1996  Richard Coleman  <coleman@math.gatech.edu>
3036
3037         * Added patch to uip/folder.c from exmh distribution to
3038           speed up -recurse option.
3039
3040         * Added flist command from exmh distribution.  It doesn't work
3041           yet, but it compiles :-)
3042
3043         * Changed default location for install to
3044           /usr/local/nmh/{bin,etc,lib,man}.  Split files so that format
3045           and configuration files go in nmh/etc, and support binaries go
3046           in nmh/lib.  Of course, all this can now be changed in the top
3047           level Makefile. 
3048
3049         * Started with mh-6.8.3 as based and converted to autoconf.
3050           Rewrote all the Makefiles.  Currently only works with sendmail/smtp.
3051           Pop support and plenty of other things, are now broken.