Mercurial > docs > master
annotate ch01.roff @ 28:6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
author | markus schnalke <meillo@marmaro.de> |
---|---|
date | Wed, 09 May 2012 11:39:56 +0200 |
parents | b687d151eed3 |
children | 6a9abf543297 |
rev | line source |
---|---|
0
dc2bfef4cda7
Initial commit: Basic structure, macros and fonts.
markus schnalke <meillo@marmaro.de>
parents:
diff
changeset
|
1 .H0 "Introduction |
dc2bfef4cda7
Initial commit: Basic structure, macros and fonts.
markus schnalke <meillo@marmaro.de>
parents:
diff
changeset
|
2 .P |
2
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
3 This chapter describes the background of the topics in this thesis. |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
4 General knowledge of electronic mail is assumed. |
8
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
5 It explains the situation at the start of the project. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
6 It tries to describe from what state the project lifted of and where |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
7 it headed to. This shall give an overview. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
8 |
0
dc2bfef4cda7
Initial commit: Basic structure, macros and fonts.
markus schnalke <meillo@marmaro.de>
parents:
diff
changeset
|
9 |
28
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
10 .H1 "MH \(en the Mail Handler |
0
dc2bfef4cda7
Initial commit: Basic structure, macros and fonts.
markus schnalke <meillo@marmaro.de>
parents:
diff
changeset
|
11 .P |
2
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
12 MH is an electronic mail system, originating in the RAND Corporation. |
27
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
13 Historically, it had been a all-in-one mail system, with both Mail Transfer |
2
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
14 Agent (MTA) and Mail User Agent (MUA). |
27
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
15 Later, when email setups changed, Mail Submission Agent (MSA) |
2
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
16 and Mail Retrieval Agent (MRA) facilities were added. |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
17 The MTA became less important, whereas the MUA became even more the |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
18 central part. |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
19 .P |
27
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
20 MH defines a mail handling concept. |
2
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
21 It had started as a design proposal, not as an implementation, and |
27
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
22 in spirit had remained this way. This is similar to Unix, which |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
23 rather is a style of system design than specific software product. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
24 .P |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
25 XXX Link to the Unix phil. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
26 .P |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
27 XXX comparision to monolithic mail systems. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
28 .P |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
29 XXX Differenciation of MUA and mail system. |
2
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
30 |
11
9a313c929a2a
style: Introduced .U2 for unnumbered .H2.
markus schnalke <meillo@marmaro.de>
parents:
9
diff
changeset
|
31 .U2 "History |
2
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
32 .P |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
33 MH is an electronic mail system, originating in the RAND Corporation. |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
34 In 1977, Norman Shapiro and Stockton Gaines had proposed the design |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
35 of a new mail handling system, called ``Mail Handler'' (MH) for RAND, |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
36 to superseed their ``Mail System'' (MS). |
27
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
37 Two years later, in 1979, Bruce Borden took the proposal and implemented a |
2
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
38 prototype of MH. It proved successful and replaced MS thereafter. |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
39 .P |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
40 A decade later, the University of California had started to use MH. |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
41 They also took over its development and pushed MH forward. |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
42 This had been the time when the Internet appeared, Berkeley implemented |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
43 the TCP stack, and Sendmail was born. MH had often contained the first |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
44 implementation of new RFCs. |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
45 .P |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
46 In the nineties, MH had been moved into the public domain, making it |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
47 attractive to Free Software developers. The Internet had started to become |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
48 mainstream and in 1997, Richard Coleman initiated the ``New Mail Handler'' |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
49 (nmh), a fork of MH. He intended to modernize MH, improve its MIME |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
50 capabilities, and this should be done openly within the Internet |
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
51 community. Today, nmh almost completely replaced the original MH. |
0
dc2bfef4cda7
Initial commit: Basic structure, macros and fonts.
markus schnalke <meillo@marmaro.de>
parents:
diff
changeset
|
52 |
11
9a313c929a2a
style: Introduced .U2 for unnumbered .H2.
markus schnalke <meillo@marmaro.de>
parents:
9
diff
changeset
|
53 .U2 "Concepts |
8
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
54 .P |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
55 MH is a toolchest, modelled after the Unix toolchest. It consists of a |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
56 bunch of tools, each covering one task of email handling. These programs |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
57 operate on a common mail storage. The specific format of the mail storage |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
58 also defines MH, like the file system structure defines Unix. It |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
59 consists of directories (mail folders) and files (mail messages). |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
60 Each file contains exactly one message in the format it had been |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
61 received (i.e. transfer format). MH tools carry a state (context), |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
62 consisting of current mail folder and current message. Messages can |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
63 have symbolic names, like the next or last message or for some |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
64 arbitrary group of messages. These names are called sequences. |
0
dc2bfef4cda7
Initial commit: Basic structure, macros and fonts.
markus schnalke <meillo@marmaro.de>
parents:
diff
changeset
|
65 .P |
8
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
66 New MH tools can be build out of existing ones easily. Default values to |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
67 commands are stored on a command name-basis, making it trivial to have |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
68 different versions of the same command with different defaults. Most |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
69 of the configuration is stored in the user's profile. Form templates, |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
70 e.g. for new messages or replies, are exchangeable and output is generally |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
71 adjustable with format files. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
72 .P |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
73 MH allows the user to automate almost everything and to modify amost |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
74 any behavior. The system is scriptable and extendable. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
75 |
27
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
76 .U2 "Available Versions |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
77 .P |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
78 Three versions of MH are available today: |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
79 .BU |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
80 .I "Original MH" . |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
81 In most cases it has been replaced by nmh, but some systems still |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
82 provide old MH. As nmh is old MH-compatible, there exist few reasons |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
83 not to upgrade to new. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
84 The development of old MH has stopped after the 6.8.4 release in |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
85 February 1996. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
86 .BU |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
87 .I nmh . |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
88 The most widespread version of MH was forked off version 6.8.3 in December |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
89 1996. It incorporated the \fILBL changes\fP. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
90 It provides backward-compatible to old MH by having new featues deactivated |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
91 by default. To use them, the user needs to activate them explicitely. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
92 Its development went slowly in the previous years, but had revived |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
93 in December 2011. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
94 .BU |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
95 .I mmh . |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
96 This version is the subject of this thesis. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
97 It is a descendent of nmh. It had started as a non-compatible experimental |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
98 version, but became de facto a fork. It tries to expand the same |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
99 principle concepts in a more modern way. |
8
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
100 |
27
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
101 .U2 "Example Session |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
102 .P |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
103 Example mail handling session with mmh, but mostly compatible with nmh |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
104 and old MH. The look'n'feel is common among them. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
105 |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
106 |
28
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
107 .H1 "nmh: Code and Community |
2
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
108 .P |
8
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
109 In order to understand the state, goals and dynamics of a project, |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
110 one needs to know its history. MH comes from a time before the |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
111 Internet, a time before networking became universal, a time when |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
112 emailing was small, short and simple. Then it grew, spread and |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
113 adopted to the changes. The core-concepts, however, remained the |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
114 same. During the XXX a small group of students at the University of |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
115 California, actively worked on MH. They added features and optimized, |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
116 like it is common for scientific work. This is still in pre-ANSI C |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
117 times. The source code contains many ancient parts. Code constructs |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
118 specific to BSD or hardware of that time are usual. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
119 .P |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
120 Nmh started eight years after the ANSI C standard had been |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
121 established. A more modern coding style entered the code base. Still |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
122 a part of the developers come from ``the old days''. The developer |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
123 base became more diverse and thus the code. Programming practices |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
124 from different decades merged into the project. Different coding |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
125 styles came together. It appears as if multiple peers added code |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
126 parts, resulting in a conclomeration rather than an homogenic |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
127 of-one-cast mail system. Still, the basic concepts hold it together. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
128 They were mostly untouched throughout the years. |
2
65e4327aa9f8
Added some introduction text.
markus schnalke <meillo@marmaro.de>
parents:
0
diff
changeset
|
129 .P |
8
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
130 Although, at the surface, nmh is a toolchest, meaning a collection |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
131 of completely modularized small programs, on the source code level, |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
132 it is much more interweaved. Parts of the basic functions are |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
133 collected in a MH standard library, which is good, but often |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
134 separate functions are compiled into programs, for effiency reasons. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
135 This lead to intricate innards. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
136 The advent of MIME rose the complexity of email by a magnitude. This |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
137 is visible in nmh. The MIME-related parts are the most complex ones. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
138 It's also visible that MIME support had been added on top of the |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
139 original MH later. The MH style made this easily possible, but it |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
140 also lead to duplicated functions (e.g. \fLshow\fP, \fLmhshow\fP) |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
141 and had not been thoroughly included into the concepts (e.g. the |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
142 user-visible access to whole messages and MIME parts are inherently |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
143 different). |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
144 .P |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
145 For compatibility's sake, it is a common understanding to have the |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
146 default settings to be compatible, requiring any new feature to be |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
147 explicitely enabled. This puts a burden on new users, because nmh |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
148 out-of-the-box keeps staying in the same ancient style, where users |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
149 usually want to have it practical for modern emailing. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
150 But of course, this depends on if nmh is seen to be a front-end or a |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
151 back-end. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
152 |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
153 |
27
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
154 .H1 "mmh |
28
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
155 .P |
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
156 I started to work on my experimental version, which I call |
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
157 \fImmh\fP (for \fImeillo's mail handler\fP), in Fall 2011. |
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
158 In December, when I announced that I would work on an experimental |
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
159 version, the activity in nmh suddenly rose. Suddently the community |
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
160 started to move. |
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
161 After long years of mostly idling, nmh became actively developed again. |
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
162 What a great result! |
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
163 Hence, while I was working on mmh, the community was working on nmh |
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
164 too. My own work went in parallel and mostly unrelated. |
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
165 .P |
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
166 Because of several circumstances, my experimental version is rather |
6c63083b4c19
Wrote text for the Preface; changed headings in Preface and Introduction.
markus schnalke <meillo@marmaro.de>
parents:
27
diff
changeset
|
167 a fork today, although this may change again in the future. |
27
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
168 |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
169 .U2 "Motivation |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
170 .P |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
171 XXX |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
172 |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
173 .U2 "Why it is worth it |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
174 .P |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
175 XXX |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
176 |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
177 .U2 "Target Field |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
178 .P |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
179 XXX Target field and scenarios |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
180 .P |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
181 The target user in mind likes Unix and its philosophy. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
182 He likes to use programs that are conceptionally appealing. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
183 He's familiar with the command line and enjoys its power. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
184 He is at least capable of shell scripting and wants to improve his |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
185 productivity by scripting the mail system. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
186 His computer and operating system are from post-ANSI C times. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
187 He likes to attach files, exchanges text containing non-ASCII |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
188 characters, signs or encrypts his messages. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
189 He does not use bulletin boards anymore, nor non-mbox style mail |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
190 drops, nor does he rely on compatibility to nmh. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
191 He already has and MTA/MSA and MRA running or is able to set them |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
192 up. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
193 He does not want to have to read a book in order to make his MUA |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
194 usable. |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
195 .P |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
196 XXX Limitations |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
197 |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
198 .U2 "The Vision |
8
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
199 .P |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
200 The general goals of the mmh project are the following: |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
201 .BU |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
202 I believe that mmh should be perfectly suited for modern emailing, |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
203 out-of-the-box. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
204 .BU |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
205 I care less about compatibility and more about conceptionally elegant |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
206 approaches. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
207 .BU |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
208 I care for general, clear, and simple concepts. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
209 .BU |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
210 I like to create an of-one-style email system. It should feel like |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
211 cast as one. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
212 .BU |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
213 I plan to remove any optimizations that rises obscurity, unless it |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
214 appears to be neccessary to make mmh usable at all. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
215 |
27
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
216 .U2 "Work to do |
8
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
217 .BU |
27
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
218 Remove the MTA and MRA facilities. Mmh shall concentrate on the MUA |
8
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
219 task. Mail shall enter mmh's mail storage via the system mail drop |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
220 and it shall leave mmh via the local \fLsendmail\fP command. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
221 .BU |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
222 Remove any further functions that are not related to mmh's main task. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
223 Bulletin board support is on example. Also remove support for ancient |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
224 technologies, like hardcopy terminals. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
225 .BU |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
226 Refactor the source code to meet modern style criteria. Use |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
227 standardized library functions when possible. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
228 .BU |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
229 Replace performance optimizations by clear and readable code. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
230 .BU |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
231 Reduce the feature set to the commonly used one, removing |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
232 corner-cases. Set sane default values. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
233 .BU |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
234 Add better attachment support. Add support for digital signatures and |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
235 encryption. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
236 .BU |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
237 Merge \fLshow\fP and \fLmhshow\fP into one single mail display program. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
238 Integrate MIME support deeper and more natural into MH. |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
239 .BU |
3ef5449c1175
Moved text; wrote more text; removed ch02.roff.
markus schnalke <meillo@marmaro.de>
parents:
3
diff
changeset
|
240 Provide a ready-to-use setup out-of-the-box. |
27
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
241 |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
242 |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
243 .H1 "Goals of this Thesis |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
244 |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
245 .U2 "Methods |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
246 .P |
b687d151eed3
Reorganized the content in the Intro and added placeholders for missing parts.
markus schnalke <meillo@marmaro.de>
parents:
11
diff
changeset
|
247 foo |