markus schnalke [Sat, 14 Apr 2012 16:06:04 +0000 (18:06 +0200)]
mhshow-show-*: Made %e escape the default, i.e. always serialize the output.
Never invoke several content display processes in parallel, but always
wait for the previous to finish before executing the next one. The idea
behind this is generating console output only, but not spawning any
graphical windows. All output of displaying one message should go to one
single pager invocation. Any other kinds of attachments are to be stored
and afterwards displayed manually. This is the way all the other MUAs do it
and it matches the modern understanding of emails: a message and attachments.
This is contrary to the original design of MIME, true.
Also, removed the %p alias for the %l escape.
markus schnalke [Sat, 14 Apr 2012 15:35:18 +0000 (17:35 +0200)]
No more mhshow-charset-* but instead automatic invocation of iconv(1).
Unless there is an mhshow-show-* rule, text/plain content types are
automatically piped through iconv(1) if their charset is foreign.
For mhshow-show-* rules, there's a new %c escape, which expands to the
foreign charset. The contents of the files, referenced by %f/%F are still
in foreign encoding. One might want to use `iconv -f %c %f | mycommand'
for custom mhshow-show-* rules.
We depend on iconv(1) now! But this may change to dependence on iconv(3),
soon.
This field is inconsistent and not at all finished, yet.
markus schnalke [Thu, 12 Apr 2012 21:05:47 +0000 (23:05 +0200)]
mhshow/mhstore: Removed support for retrieving message/external-body parts.
These tools won't download the contents automatically anymore. Instead,
they print the information needed to get the contents. If someone should
really receive one of those rare message/external-body messages, he can
do the job manually. We save nearly a thousand lines of code. That's worth
it!
(The profile entry `nmh-access-ftp' and sbr/ruserpass.c for reading
~/.netrc are gone now.)
markus schnalke [Thu, 12 Apr 2012 16:28:49 +0000 (18:28 +0200)]
mhbuild: Removed support for creating message/external-body parts.
Although I really like the concept, I remove the support because I haven't
seen any such message in my life. Less code through removing hardly used
features is more appealing to me than having support for such nice but
hardly used features. The world took a different road than the one MIME
proposed.
markus schnalke [Thu, 12 Apr 2012 15:30:56 +0000 (17:30 +0200)]
mhstore -auto: Never store into subdirs, but use basename of filename.
Now, the only remaining problem with -auto is overwriting of existing files.
But actually that's no problem of -auto, because the behavior is the same
with -noauto.
markus schnalke [Thu, 12 Apr 2012 14:12:43 +0000 (16:12 +0200)]
mhstore: Made -auto the default.
Now, that tar files are not extracted automatically anymore,
it's quite safe to have -auto, as nothing unexpected will happen.
Still, existing files will be overwritten, but that's the case
with -noauto too.
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.