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