]> git.marmaro.de Git - mmh/commitdiff
Applied Simon Burge <simonb@thistledown.com.au>'s dtimep.lex patch:
authorDan Harkless <dan@harkless.org>
Tue, 14 Mar 2000 20:40:47 +0000 (20:40 +0000)
committerDan Harkless <dan@harkless.org>
Tue, 14 Mar 2000 20:40:47 +0000 (20:40 +0000)
  It seems that some MUA's didn't handle y2k very well - ELM seems to be one of
  them, and Ultrix's DXmail (based on MH!).  I've got a few emails this month
  that look like:

          575   Jan 00  Xxxxxx Xxxx       3603  ...
  and
           22+  Jan 00  Xxx Xxxxx         1771  ...

  The first has "15 Jan 100" as the date and the second has "19 Jan 00" as the
  date.  The following works around this so that scan, show, sortm, etc work ok.

Added scan.MMDDYY and scan.YYYYMMDD format files.

ChangeLog
acconfig.h
config.h.in
etc/Makefile.in
etc/scan.MMDDYY [new file with mode: 0644]
etc/scan.YYYYMMDD [new file with mode: 0644]
stamp-h.in
zotnet/tws/dtimep.lex

index f4dfb1a57899ddd265cb2c23298f3cbbe4e15c32..cde4c5eff5f80cdab3858b174e7e0fd74789651b 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,4 +1,4 @@
-Tue Mar 14 01:14:13 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
+Tue Mar 14 12:41:48 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
 
        * Applied, after some finessing,
        Simon Burge <simonb@thistledown.com.au>'s --with-smtpservers patch:
@@ -31,6 +31,22 @@ Tue Mar 14 01:14:13 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
        --enable-masquerade or --with-smtpservers, you'll fail to get an
        updated copy of mts.conf.
 
+       * Applied Simon Burge <simonb@thistledown.com.au>'s dtimep.lex patch:
+
+           It seems that some MUA's didn't handle y2k very well - ELM
+           seems to be one of them, and Ultrix's DXmail (based on MH!).
+           I've got a few emails this month that look like:
+
+                   575   Jan 00  Xxxxxx Xxxx       3603  ...
+           and
+                    22+  Jan 00  Xxx Xxxxx         1771  ...
+
+           The first has "15 Jan 100" as the date and the second has 
+           "19 Jan 00" as the date.  The following works around this so 
+           that scan, show, sortm, etc work ok.
+
+       * Added scan.MMDDYY and scan.YYYYMMDD format files.
+
 Mon Mar 13 21:32:00 2000 Dan Harkless <dan-nmh@dilvish.speed.net>
 
        * Applied Sullivan N. Beck <sbeck@cise.ufl.edu>'s mhshow-suffix patch:
index 15178d7e042df6319b26c24a45823379fd74eeee..1050be7892cf738ab8eb719efebd6e1363bb1ecf 100644 (file)
 /*
  * Define this if you do not want nmh to attach the local hostname
  * to local addresses.  You must also define DUMB.  You probably
- * dont' need this unless you are behind a firewall.
+ * don't need this unless you are behind a firewall.
  */
 /* #define REALLYDUMB  1 */
 
+/*
+ * Starting on January 1, 2000, some MUAs like ELM and Ultrix's DXmail started
+ * generated bad dates ("00" or "100" for the year).  If this #define is active,
+ * we use windowing to correct those dates to what we presume to be the intended
+ * values.  About the only time this could get us into trouble would be if a MUA
+ * was generating a year of "00" in 2001 or later, due to an unrelated bug.  In
+ * this case we would "correct" the year to 2000, which could result in
+ * inaccurate bug reports against the offending MUA.  A much more esoteric case
+ * in which you might not want to #define this would be if you were OCR'ing in
+ * old written correspondence and saving it in email format, and you had dates
+ * of 1899 or earlier.
+ */
+#define FIX_NON_Y2K_COMPLIANT_MUA_DATES 1
+
 /*
  * Directs inc/slocal to extract the envelope sender from "From "
  * line.  If inc/slocal is saving message to folder, then this
index b9b9ed169ceec10e51f39b559d1e6fdd3a8fa6be..89b10e891b840931498da836ea46cbc7d037b317 100644 (file)
 /*
  * Define this if you do not want nmh to attach the local hostname
  * to local addresses.  You must also define DUMB.  You probably
- * dont' need this unless you are behind a firewall.
+ * don't need this unless you are behind a firewall.
  */
 /* #define REALLYDUMB  1 */
 
+/*
+ * Starting on January 1, 2000, some MUAs like ELM and Ultrix's DXmail started
+ * generated bad dates ("00" or "100" for the year).  If this #define is active,
+ * we use windowing to correct those dates to what we presume to be the intended
+ * values.  About the only time this could get us into trouble would be if a MUA
+ * was generating a year of "00" in 2001 or later, due to an unrelated bug.  In
+ * this case we would "correct" the year to 2000, which could result in
+ * inaccurate bug reports against the offending MUA.  A much more esoteric case
+ * in which you might not want to #define this would be if you were OCR'ing in
+ * old written correspondence and saving it in email format, and you had dates
+ * of 1899 or earlier.
+ */
+#define FIX_NON_Y2K_COMPLIANT_MUA_DATES 1
+
 /*
  * Directs inc/slocal to extract the envelope sender from "From "
  * line.  If inc/slocal is saving message to folder, then this
index 42f38e63697e38bc2d2e3840dcf090ffbe7bcfac..2f78e34129489453dfce0b892124595f4a65f900 100644 (file)
@@ -38,10 +38,10 @@ SED = sed
 
 # format and components files
 DIST_FILES = mhl.body mhl.digest mhl.format mhl.forward mhl.headers \
-             mhl.reply scan.default scan.mailx scan.nomime scan.size scan.time \
-             scan.timely scan.unseen components digestcomps distcomps \
-             forwcomps rcvdistcomps rcvdistcomps.outbox replcomps \
-            replgroupcomps MailAliases
+             mhl.reply scan.MMDDYY scan.YYYYMMDD scan.default scan.mailx \
+            scan.nomime scan.size scan.time scan.timely scan.unseen components\
+            digestcomps distcomps forwcomps rcvdistcomps rcvdistcomps.outbox\
+            replcomps replgroupcomps MailAliases
 
 # format and configuration files to generate
 GEN_FILES = mhn.defaults mts.conf
diff --git a/etc/scan.MMDDYY b/etc/scan.MMDDYY
new file mode 100644 (file)
index 0000000..d79ad3c
--- /dev/null
@@ -0,0 +1,10 @@
+%; scan.MMDDYY
+%;
+%; Like scan.default, but the date is printed in MM/DD/YY format rather than
+%; MM/DD.  Allows one less column for the message number in order to make space.
+%;
+%3(msg)%<(cur)+%| %>%<{replied}-%?{encrypted}E%| %>\
+%02(mon{date})/%02(mday{date})/%(void(year{date}))%02(modulo 100)%<{date} %|*%>\
+%<(mymbox{from})%<{to}To:%14(decode(friendly{to}))%>%>\
+%<(zero)%17(decode(friendly{from}))%>  \
+%(decode{subject})%<{body}<<%{body}>>%>
diff --git a/etc/scan.YYYYMMDD b/etc/scan.YYYYMMDD
new file mode 100644 (file)
index 0000000..626ab74
--- /dev/null
@@ -0,0 +1,11 @@
+%; scan.YYYYMMDD
+%;
+%; Like scan.default, but the date is printed in YYYY-MM-DD format rather than
+%; MM/DD.  Allows one less column for the message number and leaves out the
+%; apparently little-used replied/encrypted column in order to make space.
+%;
+%3(msg)%<(cur)+%| %>\
+%4(year{date})-%02(mon{date})-%02(mday{date})%<{date} %|*%>\
+%<(mymbox{from})%<{to}To:%14(decode(friendly{to}))%>%>\
+%<(zero)%17(decode(friendly{from}))%>  \
+%(decode{subject})%<{body}<<%{body}>>%>
index ec0a3efafd6abbc5d3abc29409a1cee8f636dd9d..f790c365fb3bf43cdc2c85400f174f9e3d01825d 100644 (file)
@@ -1 +1 @@
-Tue Mar 14 00:50:37 PST 2000
+Tue Mar 14 12:00:13 PST 2000
index 467dc85d37d520e2858932942676d35a1452b3d2..ab2e4f5132ca506cb6cc027948ba8eab2eaf672c 100644 (file)
@@ -257,6 +257,16 @@ dparsetime (char *str)
                                        for (i = 0; isdigit(*cp); )
                                                i = i*10 + (*cp++ - '0');
                                        tw.tw_year = i;
+#ifdef FIX_NON_Y2K_COMPLIANT_MUA_DATES
+                                       /* handle broken mua's that don't add
+                                          1900, or just use the last two
+                                          digits.  Assume no email before
+                                          1972. */
+                                       if (tw.tw_year < 72)
+                                               tw.tw_year += 100;
+                                       if (tw.tw_year < 1900)
+                                               tw.tw_year += 1900;
+#endif /* FIX_NON_Y2K_COMPLIANT_MUA_DATES */
                                        }
 {D}"-"?{MONTH}({W}at)?{w}               {
                                         tw.tw_mday = CVT1OR2;