docs/master

changeset 76:2e61e0004a8f

Rework of existing text.
author markus schnalke <meillo@marmaro.de>
date Tue, 05 Jun 2012 19:00:15 +0200 (2012-06-05)
parents 0927d38589af
children 0947c24dd4c6
files ch03.roff
diffstat 1 files changed, 289 insertions(+), 210 deletions(-) [+]
line diff
     1.1 --- a/ch03.roff	Tue Jun 05 11:15:18 2012 +0200
     1.2 +++ b/ch03.roff	Tue Jun 05 19:00:15 2012 +0200
     1.3 @@ -12,21 +12,22 @@
     1.4  .P
     1.5  MH had been considered an all-in-one system for mail handling.
     1.6  The community around nmh has a similar understanding.
     1.7 -In fundamental difference, I believe that mmh should be a MUA but
     1.8 -nothing more. I believe that all-in-one mail systems are not the way
     1.9 -to go. There are excellent specialized MTAs, like Postfix;
    1.10 +In fundamental difference, should be a MUA only.
    1.11 +I believe that all-in-one mail systems are obsolete.
    1.12 +There are excellent specialized MTAs, like Postfix;
    1.13  there are specialized MDAs, like Procmail; there are specialized
    1.14  MRAs, like Fetchmail. I believe it's best to use them instead of
    1.15 -providing the same function ourselves. Doing something well requires to
    1.16 -focus on this particular aspect or a small set of aspects. The more
    1.17 +providing the same function ourselves. Doing something well, requires to
    1.18 +focus on a small set of aspects. The more
    1.19  it is possible to focus, the better the result in this particular
    1.20 -area will be. The limiting resource in Free Software community development
    1.21 -usually is human power. If the low development power is even parted
    1.22 -into multiple development areas, it will hardly be possible to 
    1.23 +area will be. Usually, the limiting resource in Free Software
    1.24 +community development is man power.
    1.25 +If the development power is even spread over a large
    1.26 +development area, it becomes more difficult to
    1.27  compete with the specialists in the various fields. This is even
    1.28  increased, given the small community \(en developers and users \(en
    1.29  that MH-based mail systems have. In consequence, I believe that the
    1.30 -available resources should be concentrated at the point where MH is
    1.31 +available resources should be focused to the point where MH is
    1.32  most unique. This is clearly the MUA part.
    1.33  .P
    1.34  The goal for mmh was to remove peripheral parts and stream-line
    1.35 @@ -38,100 +39,121 @@
    1.36  In contrast to nmh, which also provides mail submission and mail retrieval
    1.37  facilities, mmh is a MUA only.
    1.38  This general difference in the view on the character of nmh
    1.39 -strongly supported the development of mmh.
    1.40 +initiated the development of mmh.
    1.41  Removing the mail transfer facilities had been the first work task
    1.42 -for the mmh project.
    1.43 +in the mmh project.
    1.44  .P
    1.45  The MSA is called \fIMessage Transfer Service\fP (MTS) in nmh.
    1.46 -The facility establishes TCP/IP connections and speaks SMTP to submit
    1.47 +The facility established network connections and spoke SMTP to submit
    1.48  messages for relay to the outside world.
    1.49 -This part is implemented in the
    1.50 +This part was implemented by the
    1.51  .Pn post
    1.52  command.
    1.53 -Demanded by the changes in
    1.54 -emailing, this part of nmh required changes in the last years.
    1.55 -Encrypted connections needed to be supported, hence SASL was introduced
    1.56 +The changes in emailing
    1.57 +demanded changes in this part of nmh in the last years.
    1.58 +Encryption and authetication for network connections
    1.59 +needed to be supported, hence TLS and SASL were introduced
    1.60  into nmh. This added complexity to the nmh without improving it in
    1.61  its core functions. Also, keeping up with recent developments in
    1.62 -this field needs requires development power and specialists.
    1.63 -Mmh cuts this whole facility off and depends on an external MTA instead.
    1.64 +this field requires development power and specialists.
    1.65 +For mmh this whole facility was cut off.
    1.66 +.Ci f6aa95b724fd8c791164abe7ee5468bf5c34f226
    1.67 +.Ci fecd5d34f65597a4dfa16aeabea7d74b191532c3
    1.68 +.Ci 156d35f6425bea4c1ed3c4c79783dc613379c65b
    1.69 +Instead, mmh depends on an external MTA.
    1.70  The only outgoing interface available to mmh is the
    1.71  .Pn sendmail
    1.72  command.
    1.73  Almost any MTA provides a
    1.74  .Pn sendmail
    1.75  command.
    1.76 -It not, any program can be substituted if it reads the
    1.77 +If not, any program can be substituted if it reads the
    1.78  message from the standard input, extracts the recipient addresses
    1.79  from the message header and does not conflict
    1.80 -with sendmail-specific command line arguments.
    1.81 +with sendmail-specific command line options.
    1.82  .P
    1.83  To retrieve mail, the
    1.84  .Pn inc
    1.85 -command in nmh has the ability to establish TCP/IP connections
    1.86 -and speaks POP3 to retrieve mail from remote servers.
    1.87 -As with mail submission, here encrypted connections are required
    1.88 -today, thus SASL support was added.
    1.89 -As POP3 is superseded by IMAP more and more, support for message
    1.90 -retrieval through IMAP will become necessary to be added soon.
    1.91 -Mmh has no support for retrieving mail from remote locations.
    1.92 -It depends on an external tool to cover this task.
    1.93 -There are two ways for messages to enter mmh's mail storage:
    1.94 -Incorporate them with
    1.95 +command established network connections
    1.96 +and spoke POP3 to retrieve mail from remote servers.
    1.97 +As with mail submission, the network connections required encryption and
    1.98 +authentication, thus TLS and SASL was added.
    1.99 +As POP3 becomes more and more superseded by IMAP, support for message
   1.100 +retrieval through IMAP will become necessary to be added soon, too.
   1.101 +Mmh has dropped the support for retrieving mail from remote locations.
   1.102 +.Ci ab7b48411962d26439f92f35ed084d3d6275459c
   1.103 +Instead, it depends on an external tool to cover this task.
   1.104 +There exist two paths for messages to enter mmh's mail storage:
   1.105 +They can be incorporate with
   1.106  .Pn inc
   1.107 -from the system maildrop, or with
   1.108 +from the system maildrop, or
   1.109  .Pn rcvstore
   1.110 -from the standard input.
   1.111 -In consequence, mmh has not any longer networking code
   1.112 -and thus does no more need to do transfer encryption and authentication.
   1.113 -Two large functional units are removed.
   1.114 +reads them from the standard input.
   1.115  .P
   1.116  With the removal of the MSA and MRA, mmh converted from an all-in-one
   1.117  mail system to being only a MUA.
   1.118 -Following the Unix philosophy, it focuses on one job and to do that well.
   1.119 +Following the Unix philosophy, it focuses on one job and
   1.120 +tries to do that one well.
   1.121 +Not only the programs follow that tenet but also the project itself does so.
   1.122  Now, of course, mmh depends on third-party software.
   1.123  An external MTA/MSA is required to transfer mail to the outside world;
   1.124  an external MRA is required to retrieve mail from remote machines.
   1.125  There exist excellent implementations of such software,
   1.126 -which do this specific task likely much better than the internal
   1.127 -versions of nmh do it. Also, this provides the choice for the best
   1.128 -suiting one of the available implementation.
   1.129 +which do this specific task likely better than the internal
   1.130 +versions had done it. Also, the best suiting programs can be freely chosen.
   1.131  .P
   1.132  As it had already been possible to use an external MSA or MRA,
   1.133  why not keep the internal version for convenience?
   1.134 -If this would question the sense in having a fall-back pager in all
   1.135 -the command line tools, in case
   1.136 +The question whether there is sense in having a fall-back pager in all
   1.137 +the command line tools, for the cases when
   1.138  .Pn more
   1.139  or
   1.140  .Pn less
   1.141 -wouldn't be available, the answer is intuitively seen.
   1.142 -Now, an MSA or MRA is clearly more complex than a text pager, but
   1.143 -still the concept holds: If programs become complex, split them;
   1.144 -if projects become complex, split them.
   1.145 -Complexity is demanded by the problem to solve. Decades ago,
   1.146 -emailing had been small and simple.
   1.147 -(Remember,
   1.148 +aren't available, appears to be ridiculous.
   1.149 +Now, an MSA or MRA is clearly more complex than a text pager,
   1.150 +and not necessarily available but still the concept holds:
   1.151 +design the system orthogonally.
   1.152 +If it is conceptionally more elegant to have the MTA to be a separate tool
   1.153 +\(en as the RFCs propose this split, this is likely the case \(en
   1.154 +then separate.
   1.155 +.P
   1.156 +Further more, if programs become complex, they should be split;
   1.157 +and if projects become complex, they should be split, too.
   1.158 +Essential complexity is defined by the problem.
   1.159 +Decades ago, emailing had been small and simple.
   1.160 +(\c
   1.161  .Pn /bin/mail
   1.162 -had once covered anything there was to email and still had been small.)
   1.163 -As the complexity in emailing increased, MH remainded mostly unchanged.
   1.164 -Nontheless, in nmh the POP server, which the original MH had included,
   1.165 -was removed. Now is the time to take one step further and remove
   1.166 -the MSA and MRA.
   1.167 +had once covered anything there was to email and still had been small
   1.168 +and simple.)
   1.169 +Then the essential complexity of email increased.
   1.170 +Email tools needed to react.
   1.171 +In nmh, for instance, the POP server, which the original MH had included,
   1.172 +was removed.
   1.173 +Now is the time to go one step further and remove the MSA and MRA.
   1.174  Not only does it decrease the code amount of the project,
   1.175  but more important, it removes the whole field of message transfer
   1.176 -with all its implications from the project.
   1.177 +with all its implications for the project.
   1.178 +It removes the need to adjust to any changes concerning network transfer.
   1.179 +This independence is received by depending on an external program
   1.180 +that covers the field.
   1.181 +Today, this is a reasonable exchange.
   1.182  .P
   1.183 -If a project needs some kind of function, there's always the choice
   1.184 -between implementing the the function in the project directly or
   1.185 -depending on a library that provides the function or depending on
   1.186 +To add some kind of function, there's always the choice
   1.187 +among implementing the function in the project directly,
   1.188 +depending on a library that provides the function, or depending on
   1.189  a program that provides the function.
   1.190  Whereas adding the function directly to the project increases the
   1.191 -code size most, it makes the project most independent.
   1.192 -On the other end, interfacing external programs keeps the interface
   1.193 -smallest, but the depencency highest.
   1.194 -Using a library is in the middle.
   1.195 -Adding the function directly to the project is a bad choice for
   1.196 -any function of higher complexity, unless it's not available in other ways.
   1.197 +code size most and requires most maintenance and development work,
   1.198 +it makes the project most independent.
   1.199 +Using libraries or external programs require less
   1.200 +maintenance work.
   1.201 +Programs have the smallest interfaces, providing the most separation
   1.202 +but possibly limiting the information exchange.
   1.203 +External libraries are stronger connected than external programs but 
   1.204 +allow better information exchange.
   1.205 +Adding more code to a project does always increase maintenance work.
   1.206 +Implementing complex functions directly in the project will add
   1.207 +a lot of code. This should be avoided if possible.
   1.208  Hence, the dependencies only change in kind, not in their existence.
   1.209  In mmh, library dependencies on
   1.210  .Pn libsasl2
   1.211 @@ -145,11 +167,12 @@
   1.212  This made mmh's code base about 12\|% smaller.
   1.213  Reducing the projects code size by such an amount without actually
   1.214  losing function is a convincing argument.
   1.215 +Actually, as external MSAs and MRAs are likely better
   1.216 +than the project's internal version, the user even gains functionality.
   1.217  .P
   1.218 -Users of MH should have not problem to set up an external MSA and MRA.
   1.219 +Users of MH should not have problems to set up an external MSA and MRA.
   1.220  Also, the popular MSAs and MRAs have large communities and a lot
   1.221  of documentation available.
   1.222 -.P
   1.223  Choices for MSAs range from the full-featured
   1.224  .I Postfix
   1.225  over mid-size solutions like
   1.226 @@ -170,25 +193,32 @@
   1.227  
   1.228  .H2 "Removal of non-MUA Tools
   1.229  .P
   1.230 -Some of nmh's tools were removed from mmh because they didn't
   1.231 -match the main focus of adding to the MUA's task.
   1.232 +Some MH tools were removed because they didn't add to the MUA's job.
   1.233 +It is a design goal of mmh to remove the parts that are rarely used.
   1.234 +The project shall become more stream-lined and focused.
   1.235 +Rarely used and loosely related tools distract from the lean appearance.
   1.236 +They require maintenance work without adding to the core task.
   1.237 +In mmh the following tools are not available anymore:
   1.238  .BU
   1.239  .Pn conflict
   1.240  was removed because it is a mail system maintenance tool.
   1.241 +.Ci 8b235097cbd11d728c07b966cf131aa7133ce5a9
   1.242  Besides, it even checks
   1.243  .Fn /etc/passwd
   1.244  and
   1.245  .Fn /etc/group
   1.246  for consistency, which has nothing at all to do with emailing.
   1.247  The tool might be useful, but it should not be shipped with mmh.
   1.248 +.\" XXX historic reasons?
   1.249  .BU
   1.250  .Pn rcvtty
   1.251  was removed because its usecase of writing to the user's terminal
   1.252 -on receiving of mail is hardly wanted today. If users like to be
   1.253 -informed of new mail, then using the shell's
   1.254 +on receiving of mail is obsolete.
   1.255 +.Ci 14767c94b3827be7c867196467ed7aea5f6f49b0
   1.256 +If users like to be
   1.257 +informed of new mail, the shell's
   1.258  .Ev MAILPATH
   1.259 -variable or graphical notifications are likely more
   1.260 -appealing.
   1.261 +variable or graphical notifications are more appealing.
   1.262  Writing directly to a terminals is hardly ever wanted today.
   1.263  If though one wants to have it this way, the standard tool
   1.264  .Pn write
   1.265 @@ -198,100 +228,139 @@
   1.266  .DE
   1.267  .BU
   1.268  .Pn viamail
   1.269 -was removed when the new attachment system was introduced, because
   1.270 +was removed when the new attachment system was activated, because
   1.271  .Pn forw
   1.272 -could can now the task itself.
   1.273 +could then cover the task itself.
   1.274 +.Ci eda72d6a7a7c20ff123043fb7f19c509ea01f932
   1.275  The program
   1.276  .Pn sendfiles
   1.277  was rewritten as a shell script wrapper around
   1.278  .Pn forw .
   1.279 +.Ci 0e82199cf3c991a173e0ac8aa776efdb3ded61e6
   1.280  .BU
   1.281  .Pn msgchk
   1.282 -was removed, because it lost its usefulness when POP support was removed.
   1.283 +was removed, because it lost its use case when POP support was removed.
   1.284 +.Ci bb9360ead7eb7a3fedcce2eeedfc660014e41dbe
   1.285 +A call to
   1.286  .Pn msgchk
   1.287 -provides hardly more information than:
   1.288 +provided hardly more information than
   1.289  .DS
   1.290  ls -l /var/mail/meillo
   1.291  .DE
   1.292 -It does separate between old and new mail, but that's merely a detail
   1.293 -and can be done with
   1.294 -.Pn stat (1)
   1.295 +though it distinguished between old and new mail.
   1.296 +This detail information and can be retrieved with
   1.297 +.Pn stat (1),
   1.298  too.
   1.299  A very small shell script could be written to output the information
   1.300 -in a convenient way, if truly necessary.
   1.301 -As mmh's inc only incorporates mail from the user's local maildrop
   1.302 +in a similar way, if truly necessary.
   1.303 +As mmh's
   1.304 +.Pn inc
   1.305 +only incorporates mail from the user's local maildrop
   1.306  and thus no data transfers over slow networks are involved,
   1.307 -there's hardly need to check for new mail before incorporating it.
   1.308 +there's hardly any need to check for new mail before incorporating it.
   1.309  .BU
   1.310  .Pn msh
   1.311 -was removed because the tool was in conflict with the
   1.312 -philosophy of MH. It provided an interactive shell to access the
   1.313 -features of MH. One major feature of MH is being a tool chest.
   1.314 -.Pn msh
   1.315 -wouldn't be just another shell, tailored to the needs of mail
   1.316 -handling, but one large program to have the MH tools built in.
   1.317 -It's main use was for accessing Bulletin Boards, which have seized to
   1.318 +was removed because the tool was in conflict with the philosophy of MH.
   1.319 +.Ci 916690191222433a6923a4be54b0d8f6ac01bd02
   1.320 +It provided an interactive shell to access the features of MH,
   1.321 +but it wasn't just a shell, tailored to the needs of mail handling.
   1.322 +Instead it was one large program that had several MH tools built in.
   1.323 +This conflicts with the major feature of MH of being a tool chest.
   1.324 +.Pn msh 's
   1.325 +main use case had been accessing Bulletin Boards, which have seized to
   1.326  be popular.
   1.327  .P
   1.328  Removing
   1.329  .Pn msh ,
   1.330 -together with the truly obsolete code relicts
   1.331 +together with the truly archaic code relicts
   1.332  .Pn vmh
   1.333  and
   1.334  .Pn wmh ,
   1.335  saved more than 7\|000 lines of C code \(en
   1.336  about 15\|% of the project's original source code amount.
   1.337 -Having the same functionality in less code (with equal readability,
   1.338 -of course) is an advantage.
   1.339 +.P
   1.340 +Having less code (with equal readability, of course)
   1.341 +for the same functionality is an advantage.
   1.342  Less code means less bugs and less maintenance work.
   1.343 -If
   1.344 +As
   1.345  .Pn rcvtty
   1.346  and
   1.347  .Pn msgchk
   1.348  are rarely used and can be implemented in different ways,
   1.349  then why should one keep them?
   1.350 +Removing them stream-lines mmh.
   1.351  .Pn viamail 's
   1.352  use case is now partly obsolete and partly covered by
   1.353  .Pn forw ,
   1.354 -hence there's no reason to still have
   1.355 -.Pn viamail
   1.356 -around.
   1.357 +hence there's no reason to still maintain it.
   1.358  .Pn conflict
   1.359 -is not related with the mail client, and
   1.360 +is not related to the mail client, and
   1.361  .Pn msh
   1.362  conflicts with the basic concept of MH.
   1.363 -Both tools could still be useful, but not as part of mmh.
   1.364 +Theses two tools might still be useful, but they should not be part of mmh.
   1.365  .P
   1.366 -It is a design goal of mmh to remove those parts that are rarely used.
   1.367 -The project shall become more stream-lined.
   1.368 -Rarely used and loosely related tools distract from the lean appearance.
   1.369 -They require maintenance cost without adding to the core task.
   1.370 -Therefore they were removed.
   1.371 +Finally, there's
   1.372 +.Pn slocal .
   1.373 +.Pn slocal
   1.374 +is an MDA and thus not directly MUA-related.
   1.375 +Conceptionally, it should be removed.
   1.376 +But
   1.377 +.Pn slocal
   1.378 +provides rule-based processing of messages, like filing them into
   1.379 +different folders, which is otherwise not available in mmh.
   1.380 +Further more,
   1.381 +.Pn slocal
   1.382 +does neither pull dependencies nor a whole new technical area
   1.383 +into the project.
   1.384 +(See section XXX for the removing of the ndbm dependency.)
   1.385 +Still,
   1.386 +.Pn slocal
   1.387 +accounts for about 1\|000 lines of code that need to be maintained.
   1.388 +As
   1.389 +.Pn slocal
   1.390 +is almost self-standing, it should be split off into a separate project.
   1.391 +This would cut the strong connection between the MUA mmh and the MDA
   1.392 +.Pn slocal .
   1.393 +The MDA would become an alternative to
   1.394 +.I procmail ,
   1.395 +as it would no longer be the need to install a complete MH system, too.
   1.396 +Likewise, mmh users could decide to use
   1.397 +.I procmail
   1.398 +without having a second, unused MDA (\c
   1.399 +.Pn slocal )
   1.400 +installed.
   1.401 +That's conceptionally the best solution.
   1.402 +Yet,
   1.403 +.Pn slocal
   1.404 +is not removed,
   1.405 +but as its existence does not affect the rest of mmh,
   1.406 +it can be removed at any time.
   1.407  
   1.408  
   1.409 -.H2 "Merge of \f(CWshow\fP and \f(CWmhshow\fP
   1.410 +.H2 "\fLshow\fP and \fPmhshow\fP
   1.411  .P
   1.412  Since the very beginning \(en already in the first concept paper \(en
   1.413  .Pn show
   1.414  had been MH's message display program.
   1.415  .Pn show
   1.416 -found out which pathnames the relevant messages had and invoked
   1.417 +mapped message numbers and sequences to files and invoked
   1.418  .Pn mhl
   1.419 -then to have the content formated.
   1.420 -With the advent of MIME, this approach wasn't sufficient anymore.
   1.421 +to have the files formated.
   1.422 +For MIME, this approach wasn't sufficient anymore.
   1.423  MIME messages can consist of multiple parts, some of which aren't
   1.424  directly displayable, and text content might be encoded in
   1.425  foreign charsets.
   1.426  .Pn show 's
   1.427 -simple approach and
   1.428 +understanding of messages and
   1.429  .Pn mhl 's
   1.430  limited display facilities couldn't cope with the task any longer.
   1.431  .P
   1.432 -Instead of extending these tools, additional ones were written from scratch
   1.433 +Instead of extending these tools, additional tools were written from scratch
   1.434  and then added to the MH tool chest. Doing so is encouraged by the
   1.435  tool chest approach. The new tools could be added without interfering
   1.436 -with the existing ones. This is great. The ease of adding new tools
   1.437 -even made MH the first MUA to implement MIME.
   1.438 +with the existing ones. This is an advantage. The ease of adding new tools
   1.439 +made MH the first MUA to implement MIME.
   1.440 +.\" XXX ref
   1.441  .P
   1.442  First, the new MIME features were added in form of the single program
   1.443  .Pn mhn .
   1.444 @@ -307,9 +376,13 @@
   1.445  which replaced the
   1.446  .Cl "mhn \-show
   1.447  call.
   1.448 +It was capable to display a MIME message appropriately.
   1.449  .P
   1.450 -From then on, two message display tools were part of nmh.
   1.451 -Because it should not require user actions to invoke the right tool
   1.452 +From then on, two message display tools were part of nmh:
   1.453 +.Pn show
   1.454 +and
   1.455 +.Pn mhshow .
   1.456 +Because the user should not need to invoke the right tool
   1.457  whether the message uses MIME or not,
   1.458  .Pn show
   1.459  was extended to automatically hand the job over to
   1.460 @@ -317,10 +390,6 @@
   1.461  if displaying the message would be beyond
   1.462  .Pn show 's
   1.463  abilities.
   1.464 -For convenience,
   1.465 -.Pn show
   1.466 -would still display MIME messages if they contained only a single text
   1.467 -part.
   1.468  In consequence, the user would invoke
   1.469  .Pn show
   1.470  (possibly through
   1.471 @@ -335,16 +404,20 @@
   1.472  (There was also a switch for
   1.473  .Pn show
   1.474  to never invoke
   1.475 -.Pn mhshow .)
   1.476 +.Pn mhshow .
   1.477 +.Pn show
   1.478 +was able to display MIME messages if they contained only a single text
   1.479 +part.)
   1.480  .P
   1.481  Having two similar tools for essentially the same task is redundant.
   1.482 -Both programs needed to be developed syncronously as they were
   1.483 -used as a single tool by the user. Thus they needed to act in a
   1.484 -similar way to not distract the user.
   1.485 +The development of both programs needed to be in sync,
   1.486 +to ensure that the programs behaved in a similar way,
   1.487 +because they were used like a single tool.
   1.488 +Different behavior would have surprised the user.
   1.489  .P
   1.490  Today, non-MIME messages are rather seen to be a special case of
   1.491  MIME messages, than MIME messages are seen to be an extension to
   1.492 -original mail.
   1.493 +original email.
   1.494  As
   1.495  .Pn mhshow
   1.496  had already be able to display non-MIME messages, it was natural
   1.497 @@ -353,24 +426,28 @@
   1.498  in favor of using
   1.499  .Pn mhshow
   1.500  exclusively.
   1.501 +This decision followed the idea of orthogonal design.
   1.502 +For convenience,
   1.503 +.Pn mhshow
   1.504 +was then renamed to
   1.505 +.Pn show .
   1.506  .Ci 4c1efddfd499300c7e74263e57d8aa137e84c853
   1.507 -This decision follows the idea of orthogonal design.
   1.508  .P
   1.509 -To allow this replacement,
   1.510 +To prepare for this transition,
   1.511  .Pn mhshow
   1.512  was reworked to behave more like
   1.513  .Pn show
   1.514  first.
   1.515 -Section XXX describes this rework from a different perspective.
   1.516 +(Section XXX describes this rework from a different perspective.)
   1.517  Once the tools behaved similar, the replacing became a natural decision.
   1.518  In mmh,
   1.519  .Pn show
   1.520  is the one single message display program again, but it handles
   1.521  MIME messages as well as non-MIME messages.
   1.522 -There's only one program to maintain and users don't need to deal
   1.523 +Now, there's only one program to maintain, and users don't need to deal
   1.524  with the existance of two display programs.
   1.525  .P
   1.526 -Though, there's one reason why removing the old
   1.527 +There's one reason why removing the old
   1.528  .Pn show
   1.529  hurts: It had been such a simple program.
   1.530  Its lean elegance is missing to
   1.531 @@ -383,24 +460,22 @@
   1.532  
   1.533  .H2 "Removal of Configure Options
   1.534  .P
   1.535 -Choice is a double-edged sword.
   1.536 -It allows customization and thus better suiting solutions,
   1.537 -but that comes with costs.
   1.538 -First, there is the cost of code complexity to have choice.
   1.539 -Second, there is the cost of less tested setups, because there are
   1.540 +Customization is a double-edged sword.
   1.541 +It allows better suiting setups, but not for free.
   1.542 +There is the cost of code complexity to be able to customize.
   1.543 +There is the cost of less tested setups, because there are
   1.544  more possible setups and especially corner-cases.
   1.545 -Third, there is the cost of choice itself.
   1.546 -The code complexity affects the developers.
   1.547 +And, there is the cost of choice itself.
   1.548 +The code complexity directly affects the developers.
   1.549  Less tested code affects both, users and developers.
   1.550 -The problem of choice affects the users, for once simply by having to
   1.551 -choose but also by complexer interfaces that require more documentation.
   1.552 +The problem of choice affects the users, for once by having to
   1.553 +choose, but also by complexer interfaces that require more documentation.
   1.554  Whenever options add little advantages, they should be considered for
   1.555  removal.
   1.556 -.P
   1.557  I have reduced the number of project-specific configure options from 
   1.558  fifteen to three.
   1.559  
   1.560 -.U3 "Mail Transfer Facility Options
   1.561 +.U3 "Mail Transfer Facilities
   1.562  .P
   1.563  With the removal of the mail transfer facilities five option vanished:
   1.564  .IP \f(CW--with-mts=[smtp|sendmail]\fP
   1.565 @@ -417,8 +492,9 @@
   1.566  
   1.567  .U3 "Backup Prefix
   1.568  .P
   1.569 -The default backup prefix, i.e. the string that was prepended to message
   1.570 -filenames to tag them as deleted, had been the comma `\f(CW,\fP'.
   1.571 +The backup prefix is the string that was prepended to message
   1.572 +filenames to tag them as deleted.
   1.573 +By default it had been the comma character `\f(CW,\fP'.
   1.574  There was a configure option to change the default to the hash symbol
   1.575  `\f(CW#\fP':
   1.576  .CW --with-hash-backup .
   1.577 @@ -439,31 +515,31 @@
   1.578  .Pe backup-prefix ,
   1.579  which allows to specify an arbitrary string as backup prefix.
   1.580  .Ci 6c40d481d661d532dd527eaf34cebb6d3f8ed086
   1.581 -This did not remove the choice but moved it to a location where
   1.582 +Profile entries are the common method to change mmh's behavior.
   1.583 +This change did not remove the choice but moved it to a location where
   1.584  it suited better.
   1.585 -Profile entries are the common method to change mmh's behavior.
   1.586 -The name of the
   1.587 -.Fn .mh-sequences ,
   1.588 -for instance, is specified there, too.
   1.589 -Moving the specification of the backup prefix there, appears to be right.
   1.590 -Eventually, the new trash folder obsoleted the concept of the
   1.591 +.P
   1.592 +Eventually, however, the new trash folder obsoleted the concept of the
   1.593  backup prefix completely.
   1.594  (Well, there still are corner-cases to remove until the backup
   1.595  prefix can be layed to rest, eventually.)
   1.596  .\" FIXME: Do this work in the code!
   1.597 +
   1.598 +.U3 "Editor and Pager
   1.599  .P
   1.600  The two configure options
   1.601  .CW --with-editor=EDITOR
   1.602  .CW --with-pager=PAGER
   1.603  were used to specify the default editor and pager at configure time.
   1.604  Doing so at configure time made sense in the Eighties,
   1.605 -when the available editors and pagers varied more across different systems.
   1.606 -Today, the situation is much more homegenic.
   1.607 +when the set of available editors and pagers varied much across
   1.608 +different systems.
   1.609 +Today, the situation is more homegeneic.
   1.610  The programs
   1.611  .Pn vi
   1.612  and
   1.613  .Pn more
   1.614 -can be expected to be available anywhere on every Unix system,
   1.615 +can be expected to be available on every Unix system,
   1.616  as they are specified by POSIX since two decades.
   1.617  (The specifications for
   1.618  .Pn vi
   1.619 @@ -484,14 +560,13 @@
   1.620  .Pe editor
   1.621  and
   1.622  .Pe moreproc
   1.623 -profile entries, which allowed the user to change the default
   1.624 -by personal preference.
   1.625 +profile entries, which allowed the user to override the system defaults.
   1.626  Later, the concept was reworked to respect the standard environment
   1.627  variables
   1.628  .Ev VISUAL
   1.629  and
   1.630  .Ev PAGER
   1.631 -if they were set.
   1.632 +if they are set.
   1.633  Today, mmh determines the editor to use in the following order,
   1.634  taking the first available and non-empty item:
   1.635  .IP (1)
   1.636 @@ -510,7 +585,9 @@
   1.637  Command
   1.638  .Pn vi .
   1.639  .P
   1.640 -The pager to use is deteminded in the following order,
   1.641 +.Ci f85f4b7ae62e3d05a945dcd46ead51f0a2a89a9b
   1.642 +.P
   1.643 +The pager to use is deteminded in a similar order,
   1.644  also taking the first available and non-empty item:
   1.645  .IP (1)
   1.646  Environment variable
   1.647 @@ -527,18 +604,16 @@
   1.648  Command
   1.649  .Pn more .
   1.650  .P
   1.651 -.Ci f85f4b7ae62e3d05a945dcd46ead51f0a2a89a9b
   1.652  .Ci 0c4214ea2aec6497d0d67b436bbee9bc1d225f1e
   1.653  .P
   1.654 -The new behavior confirms better to the common behavior on Unix
   1.655 -systems, as
   1.656 +By respecting the
   1.657  .Ev VISUAL /\c
   1.658  .Ev EDITOR
   1.659  and
   1.660  .Ev PAGER
   1.661 -are respected.
   1.662 -Additionally, the new approach is more uniform and
   1.663 -without surprise for users.
   1.664 +environment variables,
   1.665 +the new behavior confirms better to the common style on Unix systems.
   1.666 +Additionally, the new approach is more uniform and clearer to users.
   1.667  
   1.668  .U3 "Locale
   1.669  .P
   1.670 @@ -548,7 +623,7 @@
   1.671  support.
   1.672  .Ci ccf4f175ef4c4e7522f9510a4a1149c15d810dd9
   1.673  
   1.674 -.U3 "\fLslocal\fP Supress Duplicates
   1.675 +.U3 "ndbm
   1.676  .P
   1.677  .Pn slocal
   1.678  is an MDA included in mmh.
   1.679 @@ -559,11 +634,13 @@
   1.680  yet it remains being part of mmh.
   1.681  This is likely to change in the future.
   1.682  Already,
   1.683 -.Pn slocal was stripped down.
   1.684 +.Pn slocal
   1.685 +was stripped down.
   1.686  It used to depend on
   1.687  .I ndbm ,
   1.688  a database library.
   1.689 -The database is used to store the message ids of all messages delivered.
   1.690 +The database is used to store the `\fLMessage-ID\fP's of all
   1.691 +messages delivered.
   1.692  This enables
   1.693  .Pn slocal
   1.694  to suppress delivering the same message to the same user twice.
   1.695 @@ -582,6 +659,7 @@
   1.696  .P
   1.697  By removing the suppress duplicates feature of
   1.698  .Pn slocal ,
   1.699 +.Ci ecd6d6a20cb7a1507e3a20d6c4cb3a1cf14c6bbf
   1.700  the dependency on
   1.701  .I ndbm
   1.702  was removed and 120 lines of complex autoconf could be saved.
   1.703 @@ -596,46 +674,46 @@
   1.704  .Sw --disable-mhe
   1.705  was removed when the mh-e support was reworked. 
   1.706  Mh-e is the Emacs front-end to MH.
   1.707 -It requires MH to act different in some minor ways.
   1.708 -The configure option could switch the extension off.
   1.709 -After removing support for old versions of mh-e,
   1.710 +It requires MH to provide minor additional functions.
   1.711 +The
   1.712 +.Sw --disable-mhe
   1.713 +configure option could switch these extensions off.
   1.714 +After removing the support for old versions of mh-e,
   1.715  only the
   1.716  .Sw -build
   1.717 -switches for
   1.718 +switches of
   1.719  .Pn forw
   1.720  and
   1.721  .Pn repl
   1.722 -are left to be mh-e-specific.
   1.723 -They are now always available because they add little code and complexity.
   1.724 -This change was first done in nmh and thereafter merged into mmh.
   1.725 -The interface changes in mmh require mh-e to be adjusted to use mmh
   1.726 -as the back-end. This requires minor changes to mh-e, though removing
   1.727 -the
   1.728 -.Sw -build
   1.729 -switches would require larger adjustments.
   1.730 -The
   1.731 +are left to be mh-e extensions.
   1.732 +They are now always built in because they add little code and complexity.
   1.733 +In consequence, the
   1.734  .Sw --disable-mhe
   1.735 -configure option was removed and the remaining support for mh-e is always
   1.736 -built in.
   1.737 +configure option was removed
   1.738  .Ci a7ce7b4a580d77b6c2c4d980812beb589aa4c643
   1.739  Removing the option removed a second code setup that would have
   1.740  needed to be tested.
   1.741 +This change was first done in nmh and thereafter merged into mmh.
   1.742 +.P
   1.743 +The interface changes in mmh require mh-e to be adjusted in order
   1.744 +to be able to use mmh as back-end.
   1.745 +This will require minor changes to mh-e, but removing the
   1.746 +.Sw -build
   1.747 +switches would require more rework.
   1.748  
   1.749  .U3 "Masquerading
   1.750  .P
   1.751  The configure option
   1.752  .Sw --enable-masquerade
   1.753 -could take up to three items: draft_from, mmailid, username_extension.
   1.754 +could take up to three arguments:
   1.755 +`draft_from', `mmailid', and `username_extension'.
   1.756  They activated different types of address masquerading.
   1.757  All of them were implemented in the SMTP-speaking
   1.758  .Pn post
   1.759 -command.
   1.760 -Mmh no longer speaks SMTP and the replacing
   1.761 -.Pn spost
   1.762 -command no longer does MTA jobs like this one.
   1.763 -Because address masquerading is an MTA's task and mmh does not cover
   1.764 -this field anymore, the funtion needs to be implemented in the
   1.765 -external MTA used.
   1.766 +command, which provided an MSA.
   1.767 +Address masquerading is an MTA's task and mmh does not cover
   1.768 +this field anymore.
   1.769 +Hence, true masquerading needs to be implemented in the external MTA.
   1.770  .P
   1.771  The
   1.772  .I mmailid
   1.773 @@ -645,7 +723,7 @@
   1.774  .I username
   1.775  to
   1.776  .I fakeusername
   1.777 -mapping, based on the value of the password file's GECOS field.
   1.778 +mapping, based on the password file's GECOS field.
   1.779  The man page
   1.780  .Mp mh-tailor(5)
   1.781  described the use case as being the following:
   1.782 @@ -658,21 +736,21 @@
   1.783  ``First [Middle] Last <First.Last>''
   1.784  .P
   1.785  As mmh sends outgoing mail via the local MTA only,
   1.786 -it is the best location to do such global rewrites.
   1.787 +the best location to do such global rewrites is there.
   1.788  Besides, the MTA is conceptionally the right location because it
   1.789  does the reverse mapping for incoming mail (aliasing), too.
   1.790 -The masquerading set up there is set up once for all
   1.791 +Further more, masquerading set up there is readily available for all
   1.792  mail software on the system.
   1.793 +Hence, mmailid masquerading was removed.
   1.794  .Ci 0836c8000ccb34b59410ef1c15b1b7feac70ce5f
   1.795  .P
   1.796  The
   1.797  .I username_extension
   1.798 -masquerading type did not replace the username but could append a suffix
   1.799 -to it.
   1.800 -The suffix needed to be specified by the
   1.801 +masquerading type did not replace the username but would append a suffix,
   1.802 +specified by the
   1.803  .Ev USERNAME_EXTENSION
   1.804 -environment variable.
   1.805 -It provided support for the
   1.806 +environment variable, to it.
   1.807 +This provided support for the
   1.808  .I user-extension
   1.809  feature of qmail and the similar
   1.810  .I "plussed user
   1.811 @@ -680,31 +758,32 @@
   1.812  The decision to remove this username_extension masquerading was
   1.813  motivated by the fact that
   1.814  .Pn spost
   1.815 -hadn't supported it.
   1.816 -.Ci 2abae0bfd0ad5bf898461e50aa4b466d641f23d9_username_extension
   1.817 -Mmh now provides a more general, though in this case less convenient,
   1.818 -kind of masquerading.
   1.819 +hadn't supported it already.
   1.820 +.Ci 2abae0bfd0ad5bf898461e50aa4b466d641f23d9
   1.821 +Username extensions are possible in mmh, but less convenient to use.
   1.822 +.\" XXX format file %(getenv USERNAME_EXTENSION)
   1.823  .P
   1.824  The
   1.825  .I draft_from
   1.826  masquerading type instructed
   1.827  .Pn post
   1.828  to use the value of the `From:' header as SMTP envelope sender.
   1.829 -This allowes to replace the sender address completely.
   1.830 +Sender addresses could be replaced completely.
   1.831  .Ci b14ea6073f77b4359aaf3fddd0e105989db9
   1.832 -Mmh now offers a kind of masquerading similar in effect, but
   1.833 +Mmh offers a kind of masquerading similar in effect, but
   1.834  with technical differences.
   1.835 -As mmh does not transfer messages itself, the local MTA has full control
   1.836 -over the sending address. Any masquerading mmh introduces may be reverted
   1.837 -by the MTA. In times of pedantic spam checking, an MTA will likely do so
   1.838 -to keep its own reputation up.
   1.839 -Nonetheless, the MUA can set the `From:' header and thus propose
   1.840 -a sender address to be used to the MTA.
   1.841 +As mmh does not transfer messages itself, the local MTA has final control
   1.842 +over the sender's address. Any masquerading mmh introduces may be reverted
   1.843 +by the MTA.
   1.844 +In times of pedantic spam checking, an MTA will take care to use
   1.845 +sensible envelope sender addresses to keep its own reputation up.
   1.846 +Nonetheless, the MUA can set the `From:' header and thereby propose
   1.847 +a sender address to the MTA.
   1.848  The MTA may then decide to take that one or generate the canonical sender
   1.849  address for use as envelope sender address.
   1.850  .P
   1.851  In mmh, the MTA will always extract the recipient and sender from the
   1.852 -headers (\c
   1.853 +message headers (\c
   1.854  .Pn sendmail 's
   1.855  .Sw -t
   1.856  switch).
   1.857 @@ -716,10 +795,10 @@
   1.858  Two configure options remain in mmh.
   1.859  One is the locking method to use:
   1.860  .Sw --with-locking=[dot|fcntl|flock|lockf] .
   1.861 -Removing all other methods except the portable dot locking and having
   1.862 -that as default is appealing, but requires deeper investigation into the
   1.863 -topic.
   1.864 -The other,
   1.865 +The idea of removing all methods except the portable dot locking
   1.866 +and having that one as the default is appealing, but this change
   1.867 +requires deeper technical investigation into the topic.
   1.868 +The other option,
   1.869  .Sw --enable-debug ,
   1.870  compiles the programs with debugging symbols and does not strip them.
   1.871  This option is likely to stay.