markus schnalke [Thu, 12 Apr 2012 13:18:12 +0000 (15:18 +0200)]
Don't treat application/octet-stream with type=tar special.
Don't auto-extract such parts with `mhstore -auto'. This makes -auto
less a security problem.
The auto-extract feature of mhshow that had been described in its man
page seems to not exist, anyway.
markus schnalke [Wed, 11 Apr 2012 15:23:59 +0000 (17:23 +0200)]
Remove caching of external MIME parts.
I.e. -rcache/-wcache switches and nmh-cache/nmh-private-cache profile entries.
External MIME parts are *very* rare nowadays, who cares about caching
them, anyway?
markus schnalke [Wed, 11 Apr 2012 13:41:05 +0000 (15:41 +0200)]
Removed RFC 1864 (Content-MD5) support. I.e. -check switches.
Transfer integrity should be cared for in the transfer protocols.
Data integrity is better covered with digital signatures.
markus schnalke [Wed, 11 Apr 2012 10:22:13 +0000 (12:22 +0200)]
Added docs/README.start-devel, which recommends who to start with nmh.
I've written this more than a year ago, in pre-mmh times, but my advices
are still the same.
markus schnalke [Tue, 10 Apr 2012 22:05:26 +0000 (00:05 +0200)]
Scanning an empty mbox file is no error.
Of course there won't be a delimiter, but mail drop files are frequently
empty, though existing.
This solution is more of a hack, but it works. Improvements welcome!
markus schnalke [Tue, 10 Apr 2012 21:24:07 +0000 (23:24 +0200)]
Removed -(no)push and -(no)forward flags from send, spost and whatnow.
We don't send directly (with SMTP) anymore. We only execute sendmail,
which, on modern systems, takes few time. Thus we do it directly
instead of having more complexity for the rare wish to run sendmail in
the background and also be unable to deal with possible errors directly.
markus schnalke [Fri, 30 Mar 2012 16:07:52 +0000 (18:07 +0200)]
Put structure into anno(1) and its man page.
The ``newly'' added features (-list, -delete, ...) were simply added
on top, but without rethinking and adjusting anno(1)'s structure. (I
agree, however, that it was the right decision to add these features
to anno(1) instead of writing another tool.) I've reworked anno now to
give it a clear structure. And I've reworked its man page to propagate
this structure.
markus schnalke [Thu, 29 Mar 2012 15:12:37 +0000 (17:12 +0200)]
Migrated man page post(8) to spost(8).
It would be nice to have it improved a bit more.
Spost is located in section 8 (maintenance commands) of the manual,
but it is located in the bindir, rather than the sbindir. This is
on purpose. The sections of the manual are mostly informational (today),
whereas directories are either in $PATH or not, and thus cause a
functional difference. Hence, I don't blindly link sbindir to section 8.
markus schnalke [Thu, 29 Mar 2012 13:08:49 +0000 (15:08 +0200)]
Trash folder replaces rmmproc. Rework of rmm(1) and refile(1).
Removed several switches from refile and changed its behavior.
(Although, rmm does not use backup prefixes anymore, other tools
still do.)
markus schnalke [Wed, 28 Mar 2012 19:16:08 +0000 (21:16 +0200)]
Fixed programming mistakes, detected by cppcheck.
Two memory leaks and a possibly not terminated string.
(There also is a false positive in sbr/path.c.)
(sbr/dtimep.c has warnings, but I believe lex is correct. ;-) )
markus schnalke [Tue, 27 Mar 2012 16:11:49 +0000 (18:11 +0200)]
Enhance fix of 0b81a300d9e7cf78b6bc11d8c870f57fa81fcdc4.
Ken Hornstein did the same fix for nmh. He showed me that I had missed
the second, similar, case. Thanks.
markus schnalke [Tue, 27 Mar 2012 13:31:14 +0000 (15:31 +0200)]
Add some more default MIME content suffixes.
Some of them originated from:
cat /etc/mime.types |
perl -ane 'if ($F[1] ne "") {print "mhshow-suffix-$F[0]:.$F[1]\n"}'
Pulled in from nmh. Thanks to Ken Hornstein, David Levine and Steve Rader.
markus schnalke [Tue, 27 Mar 2012 13:07:59 +0000 (15:07 +0200)]
Fixed two fd leaks in mhparse.c.
1) In openQuoted(), the decoded contents file was opened twice in
succession. The second open was added by a patch in March 2000.
2) openBase64(), openQuoted(), and open7Bit() could open the contents
file, but it never would be closed. Added code to each to close the
file if the function opened it.
[Bug #24004: (debbug 344182)]
markus schnalke [Tue, 27 Mar 2012 12:20:24 +0000 (14:20 +0200)]
Fixed `mhbuild -check': use the correct file.
mhbuild -check would always fail because it tried to build the digest
for the decoded contents file (cefile), which can be null. If it is, use
the contents file itself.
markus schnalke [Tue, 27 Mar 2012 10:33:35 +0000 (12:33 +0200)]
new: Improve the fix with the NULL-sentinel.
With multiple sequence arguments on the command line you might end up
with garbage in the sequence[] array (it needs the last argument to be
a NULL. So do two things: make the first two arguments NULL, and as we
add arguments to sequence[] make sure the list has a NULL on the end.
This is another problem discovered by the nmh test suite.
markus schnalke [Tue, 27 Mar 2012 10:12:06 +0000 (12:12 +0200)]
We have only numeric timezone support (e.g. +0200) from now on.
That's an mmh decision. Pulled in from nmh is the following part:
Removed use of tzset()/tzname in dtimezone(). They caused the returned
timezone string to be for the user's current timezone, but the function
is supposed to return the string representation of the timezone of its
argument.
markus schnalke [Tue, 27 Mar 2012 09:03:04 +0000 (11:03 +0200)]
FreeBSD needs the HAVE_STRUCT_TM_TM_GMTOFF test.
FreeBSD has a timezone() function, not a timezone global variable
(that's visible with our default configuration).
Undid most of 0e4bc6fa7fa8ad74a1c3e855411bdc0e63bc6a2e.
markus schnalke [Tue, 27 Mar 2012 07:46:59 +0000 (09:46 +0200)]
Proper field initialization.
gcc -Wmissing-field-initializers noticed several struct initializations
that didn't explicitly list all fields. They were of no consequence because
they were for static data, so they were initialized properly.
Also, changed the initialization of global.c_ovtxt from "" to NULL because
free_queue () freed it if non-NULL, though I think the "" was always
overwritten.
markus schnalke [Tue, 27 Mar 2012 07:10:44 +0000 (09:10 +0200)]
Completely remove the use of TIME_WITH_SYS_TIME.
Removed the autoconf test but never removed the code, and this caused
some problems on systems that needed some prototypes in <time.h>.
markus schnalke [Mon, 26 Mar 2012 22:22:33 +0000 (00:22 +0200)]
The result from the call to parse_mime() was ignored.
Detected by `gcc -Wempty-body'. It has been that way since the beginning
of history and was probably of no consequence, but fixed anyway.
markus schnalke [Mon, 26 Mar 2012 22:13:25 +0000 (00:13 +0200)]
Added Content-Description header with the filename of the attachment.
This seems to be common practice now and gives mhlist something useful
to display.
markus schnalke [Mon, 26 Mar 2012 21:53:15 +0000 (23:53 +0200)]
Remove RPATH code though. Discussions on nmh-workers have convinced me.
[2012-01-05] Lyndon Nerenberg:
> [2012-01-05] Ken Hornstein:
>> RPATHS - Construct Return-Path headers from "From " lines.
>> I say keep it, since it's been around forever (a fair
>> amount of code, actually).
> I'm going to argue for the removal of this code, as well. The
> Return-Path header should be inserted by the delivering MTA, and I
> can't think of any modern MTA that doesn't.