summaryrefslogtreecommitdiff
path: root/doc/tech-notes/tech-notes.txt
blob: d5a5d01509f1e6936660d299f6fbac8668a42286 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
1339
1340
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
1460
1461
1462
1463
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475
1476
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
1489
1490
1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
1599
1600
1601
1602
1603
1604
1605
1606
1607
1608
1609
1610
1611
1612
1613
1614
1615
1616
1617
1618
1619
1620
1621
1622
1623
1624
1625
1626
1627
1628
1629
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658
1659
1660
1661
1662
1663
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
1675
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
1690
1691
1692
1693
1694
1695
1696
1697
1698
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715
1716
1717
1718
1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
1750
1751
1752
1753
1754
1755
1756
1757
1758
1759
1760
1761
1762
1763
1764
1765
1766
1767
1768
1769
1770
1771
1772
1773
1774
1775
1776
1777
1778
1779
1780
1781
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798
1799
1800
1801
1802
1803
1804
1805
1806
1807
1808
1809
1810
1811
1812
1813
1814
1815
1816
1817
1818
1819
1820
1821
1822
1823
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
1855
1856
1857
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
1903
1904
1905
1906
1907
1908
1909
1910
1911
1912
1913
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951
1952
1953
1954
1955
1956
1957
1958
1959
1960
1961
1962
1963
1964
1965
1966
1967
1968
1969
1970
1971
1972
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
2060
2061
2062
2063
2064
2065
2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
2078
2079
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101
2102
2103
2104
2105
2106
2107
2108
2109
2110
2111
2112
2113
2114
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
2125
2126
2127
2128
2129
2130
2131
2132
2133
2134
2135
2136
2137
2138
2139
2140
2141
2142
2143
2144
2145
2146
2147
2148
2149
2150
2151
2152
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
2163
2164
2165
2166
2167
2168
2169
2170
2171
2172
2173
2174
2175
2176
2177
2178
2179
2180
2181
2182
2183
2184
2185
2186
2187
2188
2189
2190
2191
2192
2193
2194
2195
2196
2197
2198
2199
2200
2201
2202
2203
2204
2205
2206
2207
2208
2209
2210
2211
2212
2213
2214
2215
2216
2217
2218
2219
2220
2221
2222
2223
2224
2225
2226
2227
2228
2229
2230
2231
2232
2233
2234
2235
2236
2237
2238
2239
2240
2241
2242
2243
2244
2245
2246
2247
2248
2249
2250
2251
2252
2253
2254
2255
2256
2257
2258
2259
2260
2261
2262
2263
2264
2265
2266
2267
2268
2269
2270
2271
2272
2273
2274
2275
2276
2277
2278
2279
2280
2281
2282
2283
2284
2285
2286
2287
2288
2289
2290
2291
2292
2293
2294
2295
2296
2297
2298
2299
2300
2301
2302
2303
2304
2305
2306
2307
2308
2309
2310
2311
2312
2313
2314
2315
2316
2317
2318
2319
2320
2321
2322
2323
2324
2325
2326
2327
2328
2329
2330
2331
2332
2333
2334
2335
2336
2337
2338
2339
2340
2341
2342
2343
2344
2345
2346
2347
2348
2349
2350
2351
2352
2353
2354
2355
2356
2357
2358
2359
2360
2361
2362
2363
2364
2365
2366
2367
2368
2369
2370
2371
2372
2373
2374
2375
2376
2377
2378
2379
2380
2381
2382
2383
2384
2385
2386
2387
2388
2389
2390
2391
2392
2393
2394
2395
2396
2397
2398
2399
2400
2401
2402
2403
2404
2405
2406
2407
2408
2409
2410
2411
2412
2413
2414
2415
2416
2417
2418
2419
2420
2421
2422
2423
2424
2425
2426
2427
2428
2429
2430
2431
2432
2433
2434
2435
2436
2437
2438
2439
2440
2441
2442
2443
2444
2445
2446
2447
2448
2449
2450
2451
2452
2453
2454
2455
2456
2457
2458
2459
2460
2461
2462
2463
2464
2465
2466
2467
2468
2469
2470
2471
2472
2473
2474
2475
2476
2477
2478
2479
2480
2481
2482
2483
2484
2485
2486
2487
2488
2489
2490
2491
2492
2493
2494
2495
2496
2497
2498
2499
2500
2501
2502
2503
2504
2505
2506
2507
2508
2509
2510
2511
2512
2513
2514
2515
2516
2517
2518
2519
2520
2521
2522
2523
2524
2525
2526
2527
2528
2529
2530
2531
2532
2533
2534
2535
2536
2537
2538
2539
2540
2541
2542
2543
2544
2545
2546
2547
2548
2549
2550
2551
2552
2553
2554
2555
2556
2557
2558
2559
2560
2561
2562
2563
2564
2565
2566
2567
2568
2569
2570
2571
2572
2573
2574
2575
2576
2577
2578
2579
2580
2581
2582
2583
2584
2585
2586
2587
2588
2589
2590
2591
2592
2593
2594
2595
2596
2597
2598
2599
2600
2601
2602
2603
2604
2605
2606
2607
2608
2609
2610
2611
2612
2613
2614
2615
2616
2617
2618
2619
2620
2621
2622
2623
2624
2625
2626
2627
2628
2629
2630
2631
2632
2633
2634
2635
2636
2637
2638
2639
2640
2641
2642
2643
2644
2645
2646
2647
2648
2649
2650
2651
2652
2653
2654
2655
2656
2657
2658
2659
2660
2661
2662
2663
2664
2665
2666
2667
2668
2669
2670
2671
2672
2673
2674
2675
2676
2677
2678
2679
2680
2681
2682
2683
2684
2685
2686
2687
2688
2689
2690
2691
2692
2693
2694
2695
2696
2697
2698
2699
2700
2701
2702
2703
2704
2705
2706
2707
2708
2709
2710
2711
2712
2713
2714
2715
2716
2717
2718
2719
2720
2721
2722
2723
2724
2725
2726
2727
2728
2729
2730
2731
2732
2733
2734
2735
2736
2737
2738
2739
2740
2741
2742
2743
2744
2745
2746
2747
2748
2749
2750
2751
2752
2753
2754
2755
2756
2757
2758
2759
2760
2761
2762
2763
2764
2765
2766
2767
2768
2769
2770
2771
2772
2773
2774
2775
2776
2777
2778
2779
2780
2781
2782
2783
2784
2785
2786
2787
2788
2789
2790
2791
2792
2793
2794
2795
2796
2797
2798
2799
2800
2801
2802
2803
2804
2805
2806
2807
2808
2809
2810
2811
2812
2813
2814
2815
2816
2817
2818
2819
2820
2821
2822
2823
2824
2825
2826
2827
2828
2829
2830
2831
2832
2833
2834
2835
2836
2837
2838
2839
2840
2841
2842
2843
2844
2845
2846
2847
2848
2849
2850
2851
2852
2853
2854
2855
2856
2857
2858
2859
2860
2861
2862
2863
2864
2865
2866
2867
2868
2869
2870
2871
2872
2873
2874
2875
2876
2877
2878
2879
2880
2881
2882
2883
2884
2885
2886
2887
2888
2889
2890
2891
2892
2893
2894
2895
2896
2897
2898
2899
2900
2901
2902
2903
2904
2905
2906
2907
2908
2909
2910
2911
2912
2913
2914
2915
2916
2917
2918
2919
2920
2921
2922
2923
2924
2925
2926
2927
2928
2929
2930
2931
2932
2933
2934
2935
2936
2937
2938
2939
2940
2941
2942
2943
2944
2945
2946
2947
2948
2949
2950
2951
2952
2953
2954
2955
2956
2957
2958
2959
2960
2961
2962
2963
2964
2965
2966
2967
2968
2969
2970
2971
2972
2973
2974
2975
2976
2977
2978
2979
2980
2981
2982
2983
2984
2985
2986
2987
2988
2989
2990
2991
2992
2993
2994
2995
2996
2997
2998
2999
3000
3001
3002
3003
3004
3005
3006
3007
3008
3009
3010
3011
3012
3013
3014
3015
3016
3017
3018
3019
3020
3021
3022
3023
3024
3025
3026
3027
3028
3029
3030
3031
3032
3033
3034
3035
3036
3037
3038
3039
3040
3041
3042
3043
3044
3045
3046
3047
3048
3049
3050
3051
3052
3053
3054
3055
3056
3057
3058
3059
3060
3061
3062
3063
3064
3065
3066
3067
3068
3069
3070
3071
3072
3073
3074
3075
3076
3077
3078
3079
3080
3081
3082
3083
3084
3085
3086
3087
3088
3089
3090
3091
3092
3093
3094
3095
3096
3097
3098
3099
3100
3101
3102
3103
3104
3105
3106
3107
3108
3109
3110
3111
3112
3113
3114
3115
3116
3117
3118
3119
3120
3121
3122
3123
3124
3125
3126
3127
3128
3129
3130
3131
3132
3133
3134
3135
3136
3137
3138
3139
3140
3141
3142
3143
3144
3145
3146
3147
3148
3149
3150
3151
3152
3153
3154
3155
3156
3157
3158
3159
3160
3161
3162
3163
3164
3165
3166
3167
3168
3169
3170
3171
3172
3173
3174
3175
3176
3177
3178
3179
3180
3181
3182
3183
3184
3185
3186
3187
3188
3189
3190
3191
3192
3193
3194
3195
3196
3197
3198
3199
3200
3201
3202
3203
3204
3205
3206
3207
3208
3209
3210
3211
3212
3213
3214
3215
3216
3217
3218
3219
3220
3221
3222
3223
3224
3225
3226
3227
3228
3229
3230
3231
3232
3233
3234
3235
3236
3237
3238
3239
3240
3241
3242
3243
3244
3245
3246
3247
3248
3249
3250
3251
3252
3253
3254
3255
3256
3257
3258
3259
3260
3261
3262
3263
3264
3265
3266
3267
3268
3269
3270
3271
3272
3273
3274
3275
3276
3277
3278
3279
3280
3281
3282
3283
3284
3285
3286
3287
3288
3289
3290
3291
3292
3293
3294
3295
3296
3297
3298
3299
3300
3301
3302
3303
3304
3305
3306
3307
3308
3309
3310
3311
3312
3313
3314
3315
3316
3317
3318
3319
3320
3321
3322
3323
3324
3325
3326
3327
3328
3329
3330
3331
3332
3333
3334
3335
3336
3337
3338
3339
3340
3341
3342
3343
3344
3345
3346
3347
3348
3349
3350
3351
3352
3353
3354
3355
3356
3357
3358
3359
3360
3361
3362
3363
3364
3365
3366
3367
3368
3369
3370
3371
3372
3373
3374
3375
3376
3377
3378
3379
3380
3381
3382
3383
3384
3385
3386
3387
3388
3389
3390
3391
3392
3393
3394
3395
3396
3397
3398
3399
3400
3401
3402
3403
3404
3405
3406
3407
3408
3409
3410
3411
3412
3413
3414
3415
3416
3417
3418
3419
3420
3421
3422
3423
3424
3425
3426
3427
3428
3429
3430
3431
3432
3433
3434
3435
3436
3437
3438
3439
3440
3441
3442
3443
3444
3445
3446
3447
3448
3449
3450
3451
3452
3453
3454
3455
3456
3457
3458
3459
3460
3461
3462
3463
3464
3465
3466
3467
3468
3469
3470
3471
3472
3473
3474
3475
3476
3477
3478
3479
3480
3481
3482
3483
3484
3485
3486
3487
3488
3489
3490
3491
3492
3493
3494
3495
3496
3497
3498
3499
3500
3501
3502
3503
3504
3505
3506
3507
3508
3509
3510
3511
3512
3513
3514
3515
3516
3517
3518
3519
3520
3521
3522
3523
3524
3525
3526
3527
3528
3529
3530
3531
3532
3533
3534
3535
3536
3537
3538
3539
3540
3541
3542
3543
3544
3545
3546
3547
3548
3549
3550
3551
3552
3553
3554
3555
3556
3557
3558
3559
3560
3561
3562
3563
3564
3565
3566
3567
3568
3569
3570
3571
3572
3573
3574
3575
3576
3577
3578
3579
3580
3581
3582
3583
3584
3585
3586
3587
3588
3589
3590
3591
3592
3593
3594
3595
3596
3597
3598
3599
3600
3601
3602
3603
3604
3605
3606
3607
3608
3609
3610
3611
3612
3613
3614
3615
3616
3617
3618
3619
3620
3621
3622
3623
3624
3625
3626
3627
3628
3629
3630
3631
3632
3633
3634
3635
3636
3637
3638
3639
3640
3641
3642
3643
3644
3645
3646
3647
3648
3649
3650
3651
3652
3653
3654
3655
3656
3657
3658
3659
3660
3661
3662
3663
3664
3665
3666
3667
3668
3669
3670
3671
3672
3673
3674
3675
3676
3677
3678
3679
3680
3681
3682
3683
3684
3685
3686
3687
3688
3689
3690
3691
3692
3693
3694
3695
3696
3697
3698
3699
3700
3701
3702
3703
3704
3705
3706
3707
3708
3709
3710
3711
3712
3713
3714
3715
3716
3717
3718
3719
3720
3721
3722
3723
3724
3725
3726
3727
3728
3729
3730
3731
3732
3733
3734
3735
3736
3737
3738
3739
3740
3741
3742
3743
3744
3745
3746
3747
3748
3749
3750
3751
3752
3753
3754
3755
3756
3757
3758
3759
3760
3761
3762
3763
3764
3765
3766
3767
3768
3769
3770
3771
3772
3773
3774
3775
3776
3777
3778
3779
3780
3781
3782
3783
3784
3785
3786
3787
3788
3789
3790
3791
3792
3793
3794
3795
3796
3797
3798
3799
3800
3801
3802
3803
3804
3805
3806
3807
3808
3809
3810
3811
3812
3813
3814
3815
3816
3817
3818
3819
3820
3821
3822
3823
3824
3825
3826
3827
3828
3829
3830
3831
3832
3833
3834
3835
3836
3837
3838
3839
3840
3841
3842
3843
3844
3845
3846
3847
3848
3849
3850
3851
3852
3853
3854
3855
3856
3857
3858
3859
3860
3861
3862
3863
3864
3865
3866
3867
3868
3869
3870
3871
3872
3873
3874
3875
3876
3877
3878
3879
3880
3881
3882
3883
3884
3885
3886
3887
3888
3889
3890
3891
3892
3893
3894
3895
3896
3897
3898
3899
3900
3901
3902
3903
3904
3905
3906
3907
3908
3909
3910
3911
3912
3913
3914
3915
3916
3917
3918
3919
3920
3921
3922
3923
3924
3925
3926
3927
3928
3929
3930
3931
3932
3933
3934
3935
3936
3937
3938
3939
3940
3941
3942
3943
3944
3945
3946
3947
3948
3949
3950
3951
3952
3953
3954
3955
3956
3957
3958
3959
3960
3961
3962
3963
3964
3965
3966
3967
3968
3969
3970
3971
3972
3973
3974
3975
3976
3977
3978
3979
3980
3981
3982
3983
3984
3985
3986
3987
3988
3989
3990
3991
3992
3993
3994
3995
3996
3997
3998
3999
4000
4001
4002
4003
4004
4005
4006
4007
4008
4009
4010
4011
4012
4013
4014
4015
4016
4017
4018
4019
4020
4021
4022
4023
4024
4025
4026
4027
4028
4029
4030
4031
4032
4033
4034
4035
4036
4037
4038
4039
4040
4041
4042
4043
4044
4045
4046
4047
4048
4049
4050
4051
4052
4053
4054
4055
4056
4057
4058
4059
4060
4061
4062
4063
4064
4065
4066
4067
4068
4069
4070
4071
4072
4073
4074
4075
4076
4077
4078
4079
4080
4081
4082
4083
4084
4085
4086
4087
4088
4089
4090
4091
4092
4093
4094
4095
4096
4097
4098
4099
4100
4101
4102
4103
4104
4105
4106
4107
4108
4109
4110
4111
4112
4113
4114
4115
4116
4117
4118
4119
4120
4121
4122
4123
4124
4125
4126
4127
4128
4129
4130
4131
4132
4133
4134
4135
4136
4137
4138
4139
4140
4141
4142
4143
4144
4145
4146
4147
4148
4149
4150
4151
4152
4153
4154
4155
4156
4157
4158
4159
4160
4161
4162
4163
4164
4165
4166
4167
4168
4169
4170
4171
4172
4173
4174
4175
4176
4177
4178
4179
4180
4181
4182
4183
4184
4185
4186
4187
4188
4189
4190
4191
4192
4193
4194
4195
4196
4197
4198
4199
4200
4201
4202
4203
4204
4205
4206
4207
4208
4209
4210
4211
4212
4213
4214
4215
4216
4217
4218
4219
4220
4221
4222
4223
4224
4225
4226
4227
4228
4229
4230
4231
4232
4233
4234
4235
4236
4237
4238
4239
4240
4241
4242
4243
4244
4245
4246
4247
4248
4249
4250
4251
4252
4253
4254
4255
4256
4257
4258
4259
4260
4261
4262
4263
4264
4265
4266
4267
4268
4269
4270
4271
4272
4273
4274
4275
4276
4277
4278
4279
4280
4281
4282
4283
4284
4285
4286
4287
4288
4289
4290
4291
4292
4293
4294
4295
4296
4297
4298
4299
4300
4301
4302
4303
4304
4305
4306
4307
4308
4309
4310
4311
4312
4313
4314
4315
4316
4317
4318
4319
4320
4321
4322
4323
4324
4325
4326
4327
4328
4329
4330
4331
4332
4333
4334
4335
4336
4337
4338
4339
4340
4341
4342
4343
4344
4345
4346
4347
4348
4349
4350
4351
4352
4353
4354
4355
4356
4357
4358
4359
4360
4361
4362
4363
4364
4365
4366
4367
4368
4369
4370
4371
4372
4373
4374
4375
4376
4377
4378
4379
4380
4381
4382
4383
4384
4385
4386
4387
4388
4389
4390
4391
4392
4393
4394
4395
4396
4397
4398
4399
4400
4401
4402
4403
4404
4405
4406
4407
4408
4409
4410
4411
4412
4413
4414
4415
4416
4417
4418
4419
4420
4421
4422
4423
4424
4425
4426
4427
4428
4429
4430
4431
4432
4433
4434
4435
4436
4437
4438
4439
4440
4441
4442
4443
4444
4445
4446
4447
4448
4449
4450
4451
4452
4453
4454
4455
4456
4457
4458
4459
4460
4461
4462
4463
4464
4465
4466
4467
4468
4469
4470
4471
4472
4473
4474
4475
4476
4477
4478
4479
4480
4481
4482
4483
4484
4485
4486
4487
4488
4489
4490
4491
4492
4493
4494
4495
4496
4497
4498
4499
4500
4501
4502
4503
4504
4505
4506
4507
4508
4509
4510
4511
4512
4513
4514
4515
4516
4517
4518
4519
4520
4521
4522
4523
4524
4525
4526
4527
4528
4529
4530
4531
4532
4533
4534
4535
4536
4537
4538
4539
4540
4541
4542
4543
4544
4545
4546
4547
4548
4549
4550
4551
4552
4553
4554
4555
4556
4557
4558
4559
4560
4561
4562
4563
4564
4565
4566
4567
4568
4569
4570
4571
4572
4573
4574
4575
4576
4577
4578
4579
4580
4581
4582
4583
4584
4585
4586
4587
4588
4589
4590
4591
4592
4593
4594
4595
4596
4597
4598
4599
4600
4601
4602
4603
4604
4605
4606
4607
4608
4609
4610
4611
4612
4613
4614
4615
4616
4617
4618
4619
4620
4621
4622
4623
4624
4625
4626
4627
4628
4629
4630
4631
4632
4633
4634
4635
4636
4637
4638
4639
4640
4641
4642
4643
4644
4645
4646
4647
4648
4649
4650
4651
4652
4653
4654
4655
4656
4657
4658
4659
4660
4661
4662
4663
4664
4665
4666
4667
4668
4669
4670
4671
4672
4673
4674
4675
4676
4677
4678
4679
4680
4681
4682
4683
4684
4685
4686
4687
4688
4689
4690
4691
4692
4693
4694
4695
4696
4697
4698
4699
4700
4701
4702
4703
4704
4705
4706
4707
4708
4709
4710
4711
4712
4713
4714
4715
4716
4717
4718
4719
4720
4721
4722
4723
4724
4725
4726
4727
4728
4729
4730
4731
4732
4733
4734
4735
4736
4737
4738
4739
4740
4741
4742
4743
4744
4745
4746
4747
4748
4749
4750
4751
4752
4753
4754
4755
4756
4757
4758
4759
4760
4761
4762
4763
4764
4765
4766
4767
4768
4769
4770
4771
4772
4773
4774
4775
4776
4777
4778
4779
4780
4781
4782
4783
4784
4785
4786
4787
4788
4789
4790
4791
4792
4793
4794
4795
4796
4797
4798
4799
4800
4801
4802
4803
4804
4805
4806
4807
4808
4809
4810
4811
4812
4813
4814
4815
4816
4817
4818
4819
4820
4821
4822
4823
4824
4825
4826
4827
4828
4829
4830
4831
4832
4833
4834
4835
4836
4837
4838
4839
4840
4841
4842
4843
4844
4845
4846
4847
4848
4849
4850
4851
4852
4853
4854
4855
4856
4857
4858
4859
4860
4861
4862
4863
4864
4865
4866
4867
4868
4869
4870
4871
4872
4873
4874
4875
4876
4877
4878
4879
4880
4881
4882
4883
4884
4885
4886
4887
4888
4889
4890
4891
4892
4893
4894
4895
4896
4897
4898
4899
4900
4901
4902
4903
4904
4905
4906
4907
4908
4909
4910
4911
4912
4913
4914
4915
4916
4917
4918
4919
4920
4921
4922
4923
4924
4925
4926
4927
4928
4929
4930
4931
4932
4933
4934
4935
4936
4937
4938
4939
4940
4941
4942
4943
4944
4945
4946
4947
4948
4949
4950
4951
4952
4953
4954
4955
4956
4957
4958
4959
4960
4961
4962
4963
4964
4965
4966
4967
4968
4969
4970
4971
4972
4973
4974
4975
4976
4977
4978
4979
4980
4981
4982
4983
4984
4985
4986
4987
4988
4989
4990
4991
4992
4993
4994
4995
4996
4997
4998
4999
5000
5001
5002
5003
5004
5005
5006
5007
5008
5009
5010
5011
5012
5013
5014
5015
5016
5017
5018
5019
5020
5021
5022
5023
5024
5025
5026
5027
5028
5029
5030
5031
5032
5033
5034
5035
5036
5037
5038
5039
5040
5041
5042
5043
5044
5045
5046
5047
5048
5049
5050
5051
5052
5053
5054
5055
5056
5057
5058
5059
5060
5061
5062
5063
5064
5065
5066
5067
5068
5069
5070
5071
5072
5073
5074
5075
5076
5077
5078
5079
5080
5081
5082
5083
5084
5085
5086
5087
5088
5089
5090
5091
5092
5093
5094
5095
5096
5097
5098
5099
5100
5101
5102
5103
5104
5105
5106
5107
5108
5109
5110
5111
5112
5113
5114
5115
5116
5117
5118
5119
5120
5121
5122
5123
5124
5125
5126
5127
5128
5129
5130
5131
5132
5133
5134
5135
5136
5137
5138
5139
5140
5141
5142
5143
5144
5145
5146
5147
5148
5149
5150
5151
5152
5153
5154
5155
5156
5157
5158
5159
5160
5161
5162
5163
5164
5165
5166
5167
5168
5169
5170
5171
5172
5173
5174
5175
5176
5177
5178
5179
5180
5181
5182
5183
5184
5185
5186
5187
5188
5189
5190
5191
5192
5193
5194
5195
5196
5197
5198
5199
5200
5201
5202
5203
5204
5205
5206
5207
5208
5209
5210
5211
5212
5213
5214
5215
5216
5217
5218
5219
5220
5221
5222
5223
5224
5225
5226
5227
5228
5229
5230
5231
5232
5233
5234
5235
5236
5237
5238
5239
5240
5241
5242
5243
5244
5245
5246
5247
5248
5249
5250
5251
5252
5253
5254
5255
5256
5257
5258
5259
5260
5261
5262
5263
5264
5265
5266
5267
5268
5269
5270
5271
5272
5273
5274
5275
5276
5277
5278
5279
5280
5281
5282
5283
5284
5285
5286
5287
5288
5289
5290
5291
5292
5293
5294
5295
5296
5297
5298
5299
5300
5301
5302
5303
5304
5305
5306
5307
5308
5309
5310
5311
5312
5313
5314
5315
5316
5317
5318
5319
5320
5321
5322
5323
5324
5325
5326
5327
5328
5329
5330
5331
5332
5333
5334
5335
5336
5337
5338
5339
5340
5341
5342
5343
5344
5345
5346
5347
5348
5349
5350
5351
5352
5353
5354
5355
5356
5357
5358
5359
5360
5361
5362
5363
5364
5365
5366
5367
5368
5369
5370
5371
5372
5373
5374
5375
5376
5377
5378
5379
5380
5381
5382
5383
5384
5385
5386
5387
5388
5389
5390
5391
5392
5393
5394
5395
5396
5397
5398
5399
5400
5401
5402
5403
5404
5405
5406
5407
5408
5409
5410
5411
5412
5413
5414
5415
5416
5417
5418
5419
5420
5421
5422
5423
5424
5425
5426
5427
5428
5429
5430
5431
5432
5433
5434
5435
5436
5437
5438
5439
5440
5441
5442
5443
5444
5445
5446
5447
5448
5449
5450
5451
5452
5453
5454
5455
5456
5457
5458
5459
5460
5461
5462
5463
5464
5465
5466
5467
5468
5469
5470
5471
5472
5473
5474
5475
5476
5477
5478
5479
5480
5481
5482
5483
5484
5485
5486
5487
5488
5489
5490
5491
5492
5493
5494
5495
5496
5497
5498
5499
5500
5501
5502
5503
5504
5505
5506
5507
5508
5509
5510
5511
5512
5513
5514
5515
5516
5517
5518
5519
5520
5521
5522
5523
5524
5525
5526
5527
5528
5529
5530
5531
5532
5533
5534
5535
5536
5537
5538
5539
5540
5541
5542
5543
5544
5545
5546
5547
5548
5549
5550
5551
5552
5553
5554
5555
5556
5557
5558
5559
5560
5561
5562
5563
5564
5565
5566
5567
5568
5569
5570
5571
5572
5573
5574
5575
5576
5577
5578
5579
5580
5581
5582
5583
5584
5585
5586
5587
5588
5589
5590
5591
5592
5593
5594
5595
5596
5597
5598
5599
5600
5601
5602
5603
5604
5605
5606
5607
5608
5609
5610
5611
5612
5613
5614
5615
5616
5617
5618
5619
5620
5621
5622
5623
5624
5625
5626
5627
5628
5629
5630
5631
5632
5633
5634
5635
5636
5637
5638
5639
5640
5641
5642
5643
5644
5645
5646
5647
5648
5649
5650
5651
5652
5653
5654
5655
5656
5657
5658
5659
5660
5661
5662
5663
5664
5665
5666
5667
5668
5669
5670
5671
5672
5673
5674
5675
5676
5677
5678
5679
5680
5681
5682
5683
5684
5685
5686
5687
5688
5689
5690
5691
5692
5693
5694
5695
5696
5697
5698
5699
5700
5701
5702
5703
5704
5705
5706
5707
5708
5709
5710
5711
5712
5713
5714
5715
5716
5717
5718
5719
5720
5721
5722
5723
5724
5725
5726
5727
5728
5729
5730
5731
5732
5733
5734
5735
5736
5737
5738
5739
5740
5741
5742
5743
5744
5745
5746
5747
5748
5749
5750
5751
5752
5753
5754
5755
5756
5757
5758
5759
5760
5761
5762
5763
5764
5765
5766
5767
5768
5769
5770
5771
5772
5773
5774
5775
5776
5777
5778
5779
5780
5781
5782
5783
5784
5785
5786
5787
5788
5789
5790
5791
5792
5793
5794
5795
5796
5797
5798
5799
5800
5801
5802
5803
5804
5805
5806
5807
5808
5809
5810
5811
5812
5813
5814
5815
5816
5817
5818
5819
5820
5821
5822
5823
5824
5825
5826
5827
5828
5829
5830
5831
5832
5833
5834
5835
5836
5837
5838
5839
5840
5841
5842
5843
5844
5845
5846
5847
5848
5849
5850
5851
5852
5853
5854
5855
5856
5857
5858
5859
5860
5861
5862
5863
5864
5865
5866
5867
5868
5869
5870
5871
5872
5873
5874
5875
5876
5877
5878
5879
5880
5881
5882
5883
5884
5885
5886
5887
5888
5889
5890
5891
5892
5893
5894
5895
5896
5897
5898
5899
5900
5901
5902
5903
5904
5905
5906
5907
5908
5909
5910
5911
5912
5913
5914
5915
5916
5917
5918
5919
5920
5921
5922
5923
5924
5925
5926
5927
5928
5929
5930
5931
5932
5933
5934
5935
5936
5937
5938
5939
5940
5941
5942
5943
5944
5945
5946
5947
5948
5949
5950
5951
5952
5953
5954
5955
5956
5957
5958
5959
5960
5961
5962
5963
5964
5965
5966
5967
5968
5969
5970
5971
5972
5973
5974
5975
5976
5977
5978
5979
5980
5981
5982
5983
5984
5985
5986
5987
5988
5989
5990
5991
5992
5993
5994
5995
5996
5997
5998
5999
6000
6001
6002
6003
6004
6005
6006
6007
6008
6009
6010
6011
6012
6013
6014
6015
6016
6017
6018
6019
6020
6021
6022
6023
6024
6025
6026
6027
6028
6029
6030
6031
6032
6033
6034
6035
6036
6037
6038
6039
6040
6041
6042
6043
6044
6045
6046
6047
6048
6049
6050
6051
6052
6053
6054
6055
6056
6057
6058
6059
6060
6061
6062
6063
6064
6065
6066
6067
6068
6069
6070
6071
6072
6073
6074
6075
6076
6077
6078
6079
6080
6081
6082
6083
6084
6085
6086
6087
6088
6089
6090
6091
6092
6093
6094
6095
6096
6097
6098
6099
6100
6101
6102
6103
6104
6105
6106
6107
6108
6109
6110
6111
6112
6113
6114
6115
6116
6117
6118
6119
6120
6121
6122
6123
6124
6125
6126
6127
6128
6129
6130
6131
6132
6133
6134
6135
6136
6137
6138
6139
6140
6141
6142
6143
6144
6145
6146
6147
6148
6149
6150
6151
6152
6153
6154
6155
6156
6157
6158
6159
6160
6161
6162
6163
6164
6165
6166
6167
6168
6169
6170
6171
6172
6173
6174
6175
6176
6177
6178
6179
6180
6181
6182
6183
6184
6185
6186
6187
6188
6189
6190
6191
6192
6193
6194
6195
6196
6197
6198
6199
6200
6201
6202
6203
6204
6205
6206
6207
6208
6209
6210
6211
6212
6213
6214
6215
6216
6217
6218
6219
6220
6221
6222
6223
6224
6225
6226
6227
6228
6229
6230
6231
6232
6233
6234
6235
6236
6237
6238
6239
6240
6241
6242
6243
6244
6245
6246
6247
6248
6249
6250
6251
6252
6253
6254
6255
6256
6257
6258
6259
6260
6261
6262
6263
6264
6265
6266
6267
6268
6269
6270
6271
6272
6273
6274
6275
6276
6277
6278
6279
6280
6281
6282
6283
6284
6285
6286
6287
6288
6289
6290
6291
6292
6293
6294
6295
6296
6297
6298
6299
6300
6301
6302
6303
6304
6305
6306
6307
6308
6309
6310
6311
6312
6313
6314
6315
6316
6317
6318
6319
6320
6321
6322
6323
6324
6325
6326
6327
6328
6329
6330
6331
6332
6333
6334
6335
6336
6337
6338
6339
6340
6341
6342
6343
6344
6345
6346
6347
6348
6349
6350
6351
6352
6353
6354
6355
6356
6357
6358
6359
6360
6361
6362
6363
6364
6365
6366
6367
6368
6369
6370
6371
6372
6373
6374
6375
6376
6377
6378
6379
6380
6381
6382
6383
6384
6385
6386
6387
6388
6389
6390
6391
6392
6393
6394
6395
6396
6397
6398
6399
6400
6401
6402
6403
6404
6405
6406
6407
6408
6409
6410
6411
6412
6413
6414
6415
6416
6417
6418
6419
6420
6421
6422
6423
6424
6425
6426
6427
6428
6429
6430
6431
6432
6433
6434
6435
6436
6437
6438
6439
6440
6441
6442
6443
6444
6445
6446
6447
6448
6449
6450
6451
6452
6453
6454
6455
6456
6457
6458
6459
6460
6461
6462
6463
6464
6465
6466
6467
6468
6469
6470
6471
6472
6473
6474
6475
6476
6477
6478
6479
6480
6481
6482
6483
6484
6485
6486
6487
6488
6489
6490
6491
6492
6493
6494
6495
6496
6497
6498
6499
6500
6501
6502
6503
6504
6505
6506
6507
6508
6509
6510
6511
6512
6513
6514
6515
6516
6517
6518
6519
6520
6521
6522
6523
6524
6525
6526
6527
6528
6529
6530
6531
6532
6533
6534
6535
6536
6537
6538
6539
6540
6541
6542
6543
6544
6545
6546
6547
6548
6549
6550
6551
6552
6553
6554
6555
6556
6557
6558
6559
6560
6561
6562
6563
6564
6565
6566
6567
6568
6569
6570
6571
6572
6573
6574
6575
6576
6577
6578
6579
6580
6581
6582
6583
6584
6585
6586
6587
6588
6589
6590
6591
6592
6593
6594
6595
6596
6597
6598
6599
6600
6601
6602
6603
6604
6605
6606
6607
6608
6609
6610
6611
6612
6613
6614
6615
6616
6617
6618
6619
6620
6621
6622
6623
6624
6625
6626
6627
6628
6629
6630
6631
6632
6633
6634
6635
6636
6637
6638
6639
6640
6641
6642
6643
6644
6645
6646
6647
6648
6649
6650
6651
6652
6653
6654
6655
6656
6657
6658
6659
6660
6661
6662
6663
6664
6665
6666
6667
6668
6669
6670
6671
6672
6673
6674
6675
6676
6677
6678
6679
6680
6681
6682
6683
6684
6685
6686
6687
6688
6689
6690
6691
6692
6693
6694
6695
6696
6697
6698
6699
6700
6701
6702
6703
6704
6705
6706
6707
6708
6709
6710
6711
6712
6713
6714
6715
6716
6717
6718
6719
6720
6721
6722
6723
6724
6725
6726
6727
6728
6729
6730
6731
6732
6733
6734
6735
6736
6737
6738
6739
6740
6741
6742
6743
6744
6745
6746
6747
6748
6749
6750
6751
6752
6753
6754
6755
6756
6757
6758
6759
6760
6761
6762
6763
6764
6765
6766
6767
6768
6769
6770
6771
6772
6773
6774
6775
6776
6777
6778
6779
6780
6781
6782
6783
6784
6785
6786
6787
6788
6789
6790
6791
6792
6793
6794
6795
6796
6797
6798
6799
6800
6801
6802
6803
6804
6805
6806
6807
6808
6809
6810
6811
6812
6813
6814
6815
6816
6817
6818
6819
6820
6821
6822
6823
6824
6825
6826
6827
6828
6829
6830
6831
6832
6833
6834
6835
6836
6837
6838
6839
6840
6841
6842
6843
6844
6845
6846
6847
6848
6849
6850
6851
6852
6853
6854
6855
6856
6857
6858
6859
6860
6861
6862
6863
6864
6865
6866
6867
6868
6869
6870
6871
6872
6873
6874
6875
6876
6877
6878
6879
6880
6881
6882
6883
6884
6885
6886
6887
6888
6889
6890
6891
6892
6893
6894
6895
6896
6897
6898
6899
6900
6901
6902
6903
6904
6905
6906
6907
6908
6909
6910
6911
6912
6913
6914
6915
6916
6917
6918
6919
6920
6921
6922
6923
6924
6925
6926
6927
6928
6929
6930
6931
6932
6933
6934
6935
6936
6937
6938
6939
6940
6941
6942
6943
6944
6945
6946
6947
6948
6949
6950
6951
6952
6953
6954
6955
6956
6957
6958
6959
6960
6961
6962
6963
6964
6965
6966
6967
6968
6969
6970
6971
6972
6973
6974
6975
6976
6977
6978
6979
6980
6981
6982
6983
6984
6985
6986
6987
6988
6989
6990
6991
6992
6993
6994
6995
6996
6997
6998
6999
7000
7001
7002
7003
7004
7005
7006
7007
7008
7009
7010
7011
7012
7013
7014
7015
7016
7017
7018
7019
7020
7021
7022
7023
7024
7025
7026
7027
7028
7029
7030
7031
7032
7033
7034
7035
7036
7037
7038
7039
7040
7041
7042
7043
7044
7045
7046
7047
7048
7049
7050
7051
7052
7053
7054
7055
7056
7057
7058
7059
7060
7061
7062
7063
7064
7065
7066
7067
7068
7069
7070
7071
7072
7073
7074
7075
7076
7077
7078
7079
7080
7081
7082
7083
7084
7085
7086
7087
7088
7089
7090
7091
7092
7093
7094
7095
7096
7097
7098
7099
7100
7101
7102
7103
7104
7105
7106
7107
7108
7109
7110
7111
7112
7113
7114
7115
7116
7117
7118
7119
7120
7121
7122
7123
7124
7125
7126
7127
7128
7129
7130
7131
7132
7133
7134
7135
7136
7137
7138
7139
7140
7141
7142
7143
7144
7145
7146
7147
7148
7149
7150
7151
7152
7153
7154
7155
7156
7157
7158
7159
7160
7161
7162
7163
7164
7165
7166
7167
7168
7169
7170
7171
7172
7173
7174
7175
7176
7177
7178
7179
7180
7181
7182
7183
7184
7185
7186
7187
7188
7189
7190
7191
7192
7193
7194
7195
7196
7197
7198
7199
7200
7201
7202
7203
7204
7205
7206
7207
7208
7209
7210
7211
7212
7213
7214
7215
7216
7217
7218
7219
7220
7221
7222
7223
7224
7225
7226
7227
7228
7229
7230
7231
7232
7233
7234
7235
7236
7237
7238
7239
7240
7241
7242
7243
7244
7245
7246
7247
7248
7249
7250
7251
7252
7253
7254
7255
7256
7257
7258
7259
7260
7261
7262
7263
7264
7265
7266
7267
7268
7269
7270
7271
7272
7273
7274
7275
7276
7277
7278
7279
7280
7281
7282
7283
7284
7285
7286
7287
7288
7289
7290
7291
7292
7293
7294
7295
7296
7297
7298
7299
7300
7301
7302
7303
7304
7305
7306
7307
7308
7309
7310
7311
7312
7313
7314
7315
7316
7317
7318
7319
7320
7321
7322
7323
7324
7325
7326
7327
7328
7329
7330
7331
7332
7333
7334
7335
7336
7337
7338
7339
7340
7341
7342
7343
7344
7345
7346
7347
7348
7349
7350
7351
7352
7353
7354
7355
7356
7357
7358
7359
7360
7361
7362
7363
7364
7365
7366
7367
7368
7369
7370
7371
7372
7373
7374
7375
7376
7377
7378
7379
7380
7381
7382
7383
7384
7385
7386
7387
7388
7389
7390
7391
7392
7393
7394
7395
7396
7397
7398
7399
7400
7401
7402
7403
7404
7405
7406
7407
7408
7409
7410
7411
7412
7413
7414
7415
7416
7417
7418
7419
7420
7421
7422
7423
7424
7425
7426
7427
7428
7429
7430
7431
7432
7433
7434
7435
7436
7437
7438
7439
7440
7441
7442
7443
7444
7445
7446
7447
7448
7449
7450
7451
7452
7453
7454
7455
7456
7457
7458
7459
7460
7461
7462
7463
7464
7465
7466
7467
7468
7469
7470
7471
7472
7473
7474
7475
7476
7477
7478
7479
7480
7481
7482
7483
7484
7485
7486
7487
7488
7489
7490
7491
7492
7493
7494
7495
7496
7497
7498
7499
7500
7501
7502
7503
7504
7505
7506
7507
7508
7509
7510
7511
7512
7513
7514
7515
7516
7517
7518
7519
7520
7521
7522
7523
7524
7525
7526
7527
7528
7529
7530
7531
7532
7533
7534
7535
7536
7537
7538
7539
7540
7541
7542
7543
7544
7545
7546
7547
7548
7549
7550
7551
7552
7553
7554
7555
7556
7557
7558
7559
7560
7561
7562
7563
7564
7565
7566
7567
7568
7569
7570
7571
7572
7573
7574
7575
7576
7577
7578
7579
7580
7581
7582
7583
7584
7585
7586
7587
7588
7589
7590
7591
7592
7593
7594
7595
7596
7597
7598
7599
7600
7601
7602
7603
7604
7605
7606
7607
7608
7609
7610
7611
7612
7613
7614
7615
7616
7617
7618
7619
7620
7621
7622
7623
7624
7625
7626
7627
7628
7629
7630
7631
7632
7633
7634
7635
7636
7637
7638
7639
7640
7641
7642
7643
7644
7645
7646
7647
7648
7649
7650
7651
7652
7653
7654
7655
7656
7657
7658
7659
7660
7661
7662
7663
7664
7665
7666
7667
7668
7669
7670
7671
7672
7673
7674
7675
7676
7677
7678
7679
7680
7681
7682
7683
7684
7685
7686
7687
7688
7689
7690
7691
7692
7693
7694
7695
7696
7697
7698
7699
7700
7701
7702
7703
7704
7705
7706
7707
7708
7709
7710
7711
7712
7713
7714
7715
7716
7717
7718
7719
7720
7721
7722
7723
7724
7725
7726
7727
7728
7729
7730
7731
7732
7733
7734
7735
7736
7737
7738
7739
7740
7741
7742
7743
7744
7745
7746
7747
7748
7749
7750
7751
7752
7753
7754
7755
7756
7757
7758
7759
7760
7761
7762
7763
7764
7765
7766
7767
7768
7769
7770
7771
7772
7773
7774
7775
7776
7777
7778
7779
7780
7781
7782
7783
7784
7785
7786
7787
7788
7789
7790
7791
7792
7793
7794
7795
7796
7797
7798
7799
7800
7801
7802
7803
7804
7805
7806
7807
7808
7809
7810
7811
7812
7813
7814
7815
7816
7817
7818
7819
7820
7821
7822
7823
7824
7825
7826
7827
7828
7829
7830
7831
7832
7833
7834
7835
7836
7837
7838
7839
7840
7841
7842
7843
7844
7845
7846
7847
7848
7849
7850
7851
7852
7853
7854
7855
7856
7857
7858
7859
7860
7861
7862
7863
7864
7865
7866
7867
7868
7869
7870
7871
7872
7873
7874
7875
7876
7877
7878
7879
7880
7881
7882
7883
7884
7885
7886
7887
7888
7889
7890
7891
7892
7893
7894
7895
7896
7897
7898
7899
7900
7901
7902
7903
7904
7905
7906
7907
7908
7909
7910
7911
7912
7913
7914
7915
7916
7917
7918
7919
7920
7921
7922
7923
7924
7925
7926
7927
7928
7929
7930
7931
7932
7933
7934
7935
7936
7937
7938
7939
7940
7941
7942
7943
7944
7945
7946
7947
7948
7949
7950
7951
7952
7953
7954
7955
7956
7957
7958
7959
7960
7961
7962
7963
7964
7965
7966
7967
7968
7969
7970
7971
7972
7973
7974
7975
7976
7977
7978
7979
7980
7981
7982
7983
7984
7985
7986
7987
7988
7989
7990
7991
7992
7993
7994
7995
7996
7997
7998
7999
8000
8001
8002
8003
8004
8005
8006
8007
8008
8009
8010
8011
8012
8013
8014
8015
8016
8017
8018
8019
8020
8021
8022
8023
8024
8025
8026
8027
8028
8029
8030
8031
8032
8033
8034
8035
8036
8037
8038
8039
8040
8041
8042
8043
8044
8045
8046
8047
8048
8049
8050
8051
8052
8053
8054
8055
8056
8057
8058
8059
8060
8061
8062
8063
8064
8065
8066
8067
8068
8069
8070
8071
8072
8073
8074
8075
8076
8077
8078
8079
8080
8081
8082
8083
8084
8085
8086
8087
8088
8089
8090
8091
8092
8093
8094
8095
8096
8097
8098
8099
8100
8101
8102
8103
8104
8105
8106
8107
8108
8109
8110
8111
8112
8113
8114
8115
8116
8117
8118
8119
8120
8121
8122
8123
8124
8125
8126
8127
8128
8129
8130
8131
8132
8133
8134
8135
8136
8137
8138
8139
8140
8141
8142
8143
8144
8145
8146
8147
8148
8149
8150
8151
8152
8153
8154
8155
8156
8157
8158
8159
8160
8161
8162
8163
8164
8165
8166
8167
8168
8169
8170
8171
8172
8173
8174
8175
8176
8177
8178
8179
8180
8181
8182
8183
8184
8185
8186
8187
8188
8189
8190
8191
8192
8193
8194
8195
8196
8197
8198
8199
8200
8201
8202
8203
8204
8205
8206
8207
8208
8209
8210
8211
8212
8213
8214
8215
8216
8217
8218
8219
8220
8221
8222
8223
8224
8225
8226
8227
8228
8229
8230
8231
8232
8233
8234
8235
8236
8237
8238
8239
8240
8241
8242
8243
8244
8245
8246
8247
8248
8249
8250
8251
8252
8253
8254
8255
8256
8257
8258
8259
8260
8261
8262
8263
8264
8265
8266
8267
8268
8269
8270
8271
8272
8273
8274
8275
8276
8277
8278
8279
8280
8281
8282
8283
8284
8285
8286
8287
8288
8289
8290
8291
8292
8293
8294
8295
8296
8297
8298
8299
8300
8301
8302
8303
8304
8305
8306
8307
8308
8309
8310
8311
8312
8313
8314
8315
8316
8317
8318
8319
8320
8321
8322
8323
8324
8325
8326
8327
8328
8329
8330
8331
8332
8333
8334
8335
8336
8337
8338
8339
8340
8341
8342
8343
8344
8345
8346
8347
8348
8349
8350
8351
8352
8353
8354
8355
8356
8357
8358
8359
8360
8361
8362
8363
8364
8365
8366
8367
8368
8369
8370
8371
8372
8373
8374
8375
8376
8377
8378
8379
8380
8381
8382
8383
8384
8385
8386
8387
8388
8389
8390
8391
8392
8393
8394
8395
8396
8397
8398
8399
8400
8401
8402
8403
8404
8405
8406
8407
8408
8409
8410
8411
8412
8413
8414
8415
8416
8417
8418
8419
8420
8421
8422
8423
8424
8425
8426
8427
8428
8429
8430
8431
8432
8433
8434
8435
8436
8437
8438
8439
8440
8441
8442
8443
8444
8445
8446
8447
8448
8449
8450
8451
8452
8453
8454
8455
8456
8457
8458
8459
8460
8461
8462
8463
8464
8465
8466
8467
8468
8469
8470
8471
8472
8473
8474
8475
8476
8477
8478
8479
8480
8481
8482
8483
8484
8485
8486
8487
8488
8489
8490
8491
8492
8493
8494
8495
8496
8497
8498
8499
8500
8501
8502
8503
8504
8505
8506
8507
8508
8509
8510
8511
8512
8513
8514
8515
8516
8517
8518
8519
8520
8521
8522
8523
8524
8525
8526
8527
8528
8529
8530
8531
8532
8533
8534
8535
8536
8537
8538
8539
8540
8541
8542
8543
8544
8545
8546
8547
8548
8549
8550
8551
8552
8553
8554
8555
8556
8557
8558
8559
8560
8561
8562
8563
8564
8565
8566
8567
8568
8569
8570
8571
8572
8573
8574
8575
8576
8577
8578
8579
8580
8581
8582
8583
8584
8585
8586
8587
8588
8589
8590
8591
8592
8593
8594
8595
8596
8597
8598
8599
8600
8601
8602
8603
8604
8605
8606
8607
8608
8609
8610
8611
8612
8613
8614
8615
8616
8617
8618
8619
8620
8621
8622
8623
8624
8625
8626
8627
8628
8629
8630
8631
8632
8633
8634
8635
8636
8637
8638
8639
8640
8641
8642
8643
8644
8645
8646
8647
8648
8649
8650
8651
8652
8653
8654
8655
8656
8657
8658
8659
8660
8661
8662
8663
8664
8665
8666
8667
8668
8669
8670
8671
8672
8673
8674
8675
8676
8677
8678
8679
8680
8681
8682
8683
8684
8685
8686
8687
8688
8689
8690
8691
8692
8693
8694
8695
8696
8697
8698
8699
8700
8701
8702
8703
8704
8705
8706
8707
8708
8709
8710
8711
8712
8713
8714
8715
8716
8717
8718
8719
8720
8721
8722
8723
8724
8725
8726
8727
8728
8729
8730
8731
8732
8733
8734
8735
8736
8737
8738
8739
8740
8741
8742
8743
8744
8745
8746
8747
8748
8749
8750
8751
8752
8753
8754
8755
8756
8757
8758
8759
8760
8761
8762
8763
8764
8765
8766
8767
8768
8769
8770
8771
8772
8773
8774
8775
8776
8777
8778
8779
8780
8781
8782
8783
8784
8785
8786
8787
8788
8789
8790
8791
8792
8793
8794
8795
8796
8797
8798
8799
8800
8801
8802
8803
8804
8805
8806
8807
8808
8809
8810
8811
8812
8813
8814
8815
8816
8817
8818
8819
8820
8821
8822
8823
8824
8825
8826
8827
8828
8829
8830
8831
8832
8833
8834
8835
8836
8837
8838
8839
8840
8841
8842
8843
8844
8845
8846
8847
8848
8849
8850
8851
8852
8853
8854
8855
8856
8857
8858
8859
8860
8861
8862
8863
8864
8865
8866
8867
8868
8869
8870
8871
8872
8873
8874
8875
8876
8877
8878
8879
8880
8881
8882
8883
8884
8885
8886
8887
8888
8889
8890
8891
8892
8893
8894
8895
8896
8897
8898
8899
8900
8901
8902
8903
8904
8905
8906
8907
8908
8909
8910
8911
8912
8913
8914
8915
8916
8917
8918
8919
8920
8921
8922
8923
8924
8925
8926
8927
8928
8929
8930
8931
8932
8933
8934
8935
8936
8937
8938
8939
8940
8941
8942
8943
8944
8945
8946
8947
8948
8949
8950
8951
8952
8953
8954
8955
8956
8957
8958
8959
8960
8961
8962
8963
8964
8965
8966
8967
8968
8969
8970
8971
8972
8973
8974
8975
8976
8977
8978
8979
8980
8981
8982
8983
8984
8985
8986
8987
8988
8989
8990
8991
8992
8993
8994
8995
8996
8997
8998
8999
9000
9001
9002
9003
9004
9005
9006
9007
9008
9009
9010
9011
9012
9013
9014
9015
9016
9017
9018
9019
9020
9021
9022
9023
9024
9025
9026
9027
9028
9029
9030
9031
9032
9033
9034
9035
9036
9037
9038
9039
9040
9041
9042
9043
9044
9045
9046
9047
9048
9049
9050
9051
9052
9053
9054
9055
9056
9057
9058
9059
9060
9061
9062
9063
9064
9065
9066
9067
9068
9069
9070
9071
9072
9073
9074
9075
9076
9077
9078
9079
9080
9081
9082
9083
9084
9085
9086
9087
9088
9089
9090
9091
9092
9093
9094
9095
9096
9097
9098
9099
9100
9101
9102
9103
9104
9105
9106
9107
9108
9109
9110
9111
9112
9113
9114
9115
9116
9117
9118
9119
9120
9121
9122
9123
9124
9125
9126
9127
9128
9129
9130
9131
9132
9133
9134
9135
9136
9137
9138
9139
9140
9141
9142
9143
9144
9145
9146
9147
9148
9149
9150
9151
9152
9153
9154
9155
9156
9157
9158
9159
9160
9161
9162
9163
9164
9165
9166
9167
9168
9169
9170
9171
9172
9173
9174
9175
9176
9177
9178
9179
9180
9181
9182
9183
9184
9185
9186
9187
9188
9189
9190
9191
9192
9193
9194
9195
9196
9197
9198
9199
9200
9201
9202
9203
9204
9205
9206
9207
9208
9209
9210
9211
9212
9213
9214
9215
9216
9217
9218
9219
9220
9221
9222
9223
9224
9225
9226
9227
9228
9229
9230
9231
9232
9233
9234
9235
9236
9237
9238
9239
9240
9241
9242
9243
9244
9245
9246
9247
9248
9249
9250
9251
9252
9253
9254
9255
9256
9257
9258
9259
9260
9261
9262
9263
9264
9265
9266
9267
9268
9269
9270
9271
9272
9273
9274
9275
9276
9277
9278
9279
9280
9281
9282
9283
9284
9285
9286
9287
9288
9289
9290
9291
9292
9293
9294
9295
9296
9297
9298
9299
9300
9301
9302
9303
9304
9305
9306
9307
9308
9309
9310
9311
9312
9313
9314
9315
9316
9317
9318
9319
9320
9321
9322
9323
9324
9325
9326
9327
9328
9329
9330
9331
9332
9333
9334
9335
9336
9337
9338
9339
9340
9341
9342
9343
9344
9345
9346
9347
9348
9349
9350
9351
9352
9353
9354
9355
9356
9357
9358
9359
9360
9361
9362
9363
9364
9365
9366
9367
9368
9369
9370
9371
9372
9373
9374
9375
9376
9377
9378
9379
9380
9381
9382
9383
9384
9385
9386
9387
9388
9389
9390
9391
9392
9393
9394
9395
9396
9397
9398
9399
9400
9401
9402
9403
9404
9405
9406
9407
9408
9409
9410
9411
9412
9413
9414
9415
9416
9417
9418
9419
9420
9421
9422
9423
9424
9425
9426
9427
9428
9429
9430
9431
9432
9433
9434
9435
9436
9437
9438
9439
9440
9441
9442
9443
9444
9445
9446
9447
9448
9449
9450
9451
9452
9453
9454
9455
9456
9457
9458
9459
9460
9461
9462
9463
9464
9465
9466
9467
9468
9469
9470
9471
9472
9473
9474
9475
9476
9477
9478
9479
9480
9481
9482
9483
9484
9485
9486
9487
9488
9489
9490
9491
9492
9493
9494
9495
9496
9497
9498
9499
9500
9501
9502
9503
9504
9505
9506
9507
9508
9509
9510
9511
9512
9513
9514
9515
9516
9517
9518
9519
9520
9521
9522
9523
9524
9525
9526
9527
9528
9529
9530
9531
9532
9533
9534
9535
9536
9537
9538
9539
9540
9541
9542
9543
9544
9545
9546
9547
9548
9549
9550
9551
9552
9553
9554
9555
9556
9557
9558
9559
9560
9561
9562
9563
9564
9565
9566
9567
9568
9569
9570
9571
9572
9573
9574
9575
9576
9577
9578
9579
9580
9581
9582
9583
9584
9585
9586
9587
9588
9589
9590
9591
9592
9593
9594
9595
9596
9597
9598
9599
9600
9601
9602
9603
9604
9605
9606
9607
9608
9609
9610
9611
9612
9613
9614
9615
9616
9617
9618
9619
9620
9621
9622
9623
9624
9625
9626
9627
9628
9629
9630
9631
9632
9633
9634
9635
9636
9637
9638
9639
9640
9641
9642
9643
9644
9645
9646
9647
9648
9649
9650
9651
9652
9653
9654
9655
9656
9657
9658
9659
9660
9661
9662
9663
9664
9665
9666
9667
9668
9669
9670
9671
9672
9673
9674
9675
9676
9677
9678
9679
9680
9681
9682
9683
9684
9685
9686
9687
9688
9689
9690
9691
9692
9693
9694
9695
9696
9697
9698
9699
9700
9701
9702
9703
9704
9705
9706
9707
9708
9709
9710
9711
9712
9713
9714
9715
9716
9717
9718
9719
9720
9721
9722
9723
9724
9725
9726
9727
9728
9729
9730
9731
9732
9733
9734
9735
9736
9737
9738
9739
9740
9741
9742
9743
9744
9745
9746
9747
9748
9749
9750
9751
9752
9753
9754
9755
9756
9757
9758
9759
9760
9761
9762
9763
9764
9765
9766
9767
9768
9769
9770
9771
9772
9773
9774
9775
9776
9777
9778
9779
9780
9781
9782
9783
9784
9785
9786
9787
9788
9789
9790
9791
9792
9793
9794
9795
9796
9797
9798
9799
9800
9801
9802
9803
9804
9805
9806
9807
9808
9809
9810
9811
9812
9813
9814
9815
9816
9817
9818
9819
9820
9821
9822
9823
9824
9825
9826
9827
9828
9829
9830
9831
9832
9833
9834
9835
9836
9837
9838
9839
9840
9841
9842
9843
9844
9845
9846
9847
9848
9849
9850
9851
9852
9853
9854
9855
9856
9857
9858
9859
9860
9861
9862
9863
9864
9865
9866
9867
9868
9869
9870
9871
9872
9873
9874
9875
9876
9877
9878
9879
9880
9881
9882
9883
9884
9885
9886
9887
9888
9889
9890
9891
9892
9893
9894
9895
9896
9897
9898
9899
9900
9901
9902
9903
9904
9905
9906
9907
9908
9909
9910
9911
9912
9913
9914
9915
9916
9917
9918
9919
9920
9921
9922
9923
9924
9925
9926
9927
9928
9929
9930
9931
9932
9933
9934
9935
9936
9937
9938
9939
9940
9941
9942
9943
9944
9945
9946
9947
9948
9949
9950
9951
9952
9953
9954
9955
9956
9957
9958
9959
9960
9961
9962
9963
9964
9965
9966
9967
9968
9969
9970
9971
9972
9973
9974
9975
9976
9977
9978
9979
9980
9981
9982
9983
9984
9985
9986
9987
9988
9989
9990
9991
9992
9993
9994
9995
9996
9997
9998
9999
10000
10001
10002
10003
10004
10005
10006
10007
10008
10009
10010
10011
10012
10013
10014
10015
10016
10017
10018
10019
10020
10021
10022
10023
10024
10025
10026
10027
10028
10029
10030
10031
10032
10033
10034
10035
10036
10037
10038
10039
10040
10041
10042
10043
10044
10045
10046
10047
10048
10049
10050
10051
10052
10053
10054
10055
10056
10057
10058
10059
10060
10061
10062
10063
10064
10065
10066
10067
10068
10069
10070
10071
10072
10073
10074
10075
10076
10077
10078
10079
10080
10081
10082
10083
10084
10085
10086
10087
10088
10089
10090
10091
10092
10093
10094
10095
10096
10097
10098
10099
10100
10101
10102
10103
10104
10105
10106
10107
10108
10109
10110
10111
10112
10113
10114
10115
10116
10117
10118
10119
10120
10121
10122
10123
10124
10125
10126
10127
10128
10129
10130
10131
10132
10133
10134
10135
10136
10137
10138
10139
10140
10141
10142
10143
10144
10145
10146
10147
10148
10149
10150
10151
10152
10153
10154
10155
10156
10157
10158
10159
10160
10161
10162
10163
10164
10165
10166
10167
10168
10169
10170
10171
10172
10173
10174
10175
10176
10177
10178
10179
10180
10181
10182
10183
10184
10185
10186
10187
10188
10189
10190
10191
10192
10193
10194
10195
10196
10197
10198
10199
10200
10201
10202
10203
10204
10205
10206
10207
10208
10209
10210
10211
10212
10213
10214
10215
10216
10217
10218
10219
10220
10221
10222
10223
10224
10225
10226
10227
10228
10229
10230
10231
10232
10233
10234
10235
10236
10237
10238
10239
10240
10241
10242
10243
10244
10245
10246
10247
10248
10249
10250
10251
10252
10253
10254
10255
10256
10257
10258
10259
10260
10261
10262
10263
10264
10265
10266
10267
10268
10269
10270
10271
10272
10273
10274
10275
10276
10277
10278
10279
10280
10281
10282
10283
10284
10285
10286
10287
10288
10289
10290
10291
10292
10293
10294
10295
10296
10297
10298
10299
10300
10301
10302
10303
10304
10305
10306
10307
10308
10309
10310
10311
10312
10313
10314
10315
10316
10317
10318
10319
10320
10321
10322
10323
10324
10325
10326
10327
10328
10329
10330
10331
10332
10333
10334
10335
10336
10337
10338
10339
10340
10341
10342
10343
10344
10345
10346
10347
10348
10349
10350
10351
10352
10353
10354
10355
10356
10357
10358
10359
10360
10361
10362
10363
10364
10365
10366
10367
10368
10369
10370
10371
10372
10373
10374
10375
10376
10377
10378
10379
10380
10381
10382
10383
10384
10385
10386
10387
10388
10389
10390
10391
10392
10393
10394
10395
10396
10397
10398
10399
10400
10401
10402
10403
10404
10405
10406
10407
10408
10409
10410
10411
10412
10413
10414
10415
10416
10417
10418
10419
10420
10421
10422
10423
10424
10425
10426
10427
10428
10429
10430
10431
10432
10433
10434
10435
10436
10437
10438
10439
10440
10441
10442
10443
10444
10445
10446
10447
10448
10449
10450
10451
10452
10453
10454
10455
10456
10457
10458
10459
10460
10461
10462
10463
10464
10465
10466
10467
10468
10469
10470
10471
10472
10473
10474
10475
10476
10477
10478
10479
10480
10481
10482
10483
10484
10485
10486
10487
10488
10489
10490
10491
10492
10493
10494
10495
10496
10497
10498
10499
10500
10501
10502
10503
10504
10505
10506
10507
10508
10509
10510
10511
10512
10513
10514
10515
10516
10517
10518
10519
10520
10521
10522
10523
10524
10525
10526
10527
10528
10529
10530
10531
10532
10533
10534
10535
10536
10537
10538
10539
10540
10541
10542
10543
10544
10545
10546
10547
10548
10549
10550
10551
10552
10553
10554
10555
10556
10557
10558
10559
10560
10561
10562
10563
10564
10565
10566
10567
10568
10569
10570
10571
10572
10573
10574
10575
10576
10577
10578
10579
10580
10581
10582
10583
10584
10585
10586
10587
10588
10589
10590
10591
10592
10593
10594
10595
10596
10597
10598
10599
10600
10601
10602
10603
10604
10605
10606
10607
10608
10609
10610
10611
10612
10613
10614
10615
10616
10617
10618
10619
10620
10621
10622
10623
10624
10625
10626
10627
10628
10629
10630
10631
10632
10633
10634
10635
10636
10637
10638
10639
10640
10641
10642
10643
10644
10645
10646
10647
10648
10649
10650
10651
10652
10653
10654
10655
10656
10657
10658
10659
10660
10661
10662
10663
10664
10665
10666
10667
10668
10669
10670
10671
10672
10673
10674
10675
10676
10677
10678
10679
10680
10681
10682
10683
10684
10685
10686
10687
10688
10689
10690
10691
10692
10693
10694
10695
10696
10697
10698
10699
10700
10701
10702
10703
10704
10705
10706
10707
10708
10709
10710
10711
10712
10713
10714
10715
10716
10717
10718
10719
10720
10721
10722
10723
10724
10725
10726
10727
10728
10729
10730
10731
10732
10733
10734
10735
10736
10737
10738
10739
10740
10741
10742
10743
10744
10745
10746
10747
10748
10749
10750
10751
10752
10753
10754
10755
10756
10757
10758
10759
10760
10761
10762
10763
10764
10765
10766
10767
10768
10769
10770
10771
10772
10773
10774
10775
10776
10777
10778
10779
10780
10781
10782
10783
10784
10785
10786
10787
10788
10789
10790
10791
10792
10793
10794
10795
10796
10797
10798
10799
10800
10801
10802
10803
10804
10805
10806
10807
10808
10809
10810
10811
10812
10813
10814
10815
10816
10817
10818
10819
10820
10821
10822
10823
10824
10825
10826
10827
10828
10829
10830
10831
10832
10833
10834
10835
10836
10837
10838
10839
10840
10841
10842
10843
10844
10845
10846
10847
10848
10849
10850
10851
10852
10853
10854
10855
10856
10857
10858
10859
10860
10861
10862
10863
10864
10865
10866
10867
10868
10869
10870
10871
10872
10873
10874
10875
10876
10877
10878
10879
10880
10881
10882
10883
10884
10885
10886
10887
10888
10889
10890
10891
10892
10893
10894
10895
10896
10897
10898
10899
10900
10901
10902
10903
10904
10905
10906
10907
10908
10909
10910
10911
10912
10913
10914
10915
10916
10917
10918
10919
10920
10921
10922
10923
10924
10925
10926
10927
10928
10929
10930
10931
10932
10933
10934
10935
10936
10937
10938
10939
10940
10941
10942
10943
10944
10945
10946
10947
10948
10949
10950
10951
10952
10953
10954
10955
10956
10957
10958
10959
10960
10961
10962
10963
10964
10965
10966
10967
10968
10969
10970
10971
10972
10973
10974
10975
10976
10977
10978
10979
10980
10981
10982
10983
10984
10985
10986
10987
10988
10989
10990
10991
10992
10993
10994
10995
10996
10997
10998
10999
11000
11001
11002
11003
11004
11005
11006
11007
11008
11009
11010
11011
11012
11013
11014
11015
11016
11017
11018
11019
11020
11021
11022
11023
11024
11025
11026
11027
11028
11029
11030
11031
11032
11033
11034
11035
11036
11037
11038
11039
11040
11041
11042
11043
11044
11045
11046
11047
11048
11049
11050
11051
11052
11053
11054
11055
11056
11057
11058
11059
11060
11061
11062
11063
11064
11065
11066
11067
11068
11069
11070
11071
11072
11073
11074
11075
11076
11077
11078
11079
11080
11081
11082
11083
11084
11085
11086
11087
11088
11089
11090
11091
11092
11093
11094
11095
11096
11097
11098
11099
11100
11101
11102
11103
11104
11105
11106
11107
11108
11109
11110
11111
11112
11113
11114
11115
11116
11117
11118
11119
11120
11121
11122
11123
11124
11125
11126
11127
11128
11129
11130
11131
11132
11133
11134
11135
11136
11137
11138
11139
11140
11141
11142
11143
11144
11145
11146
11147
11148
11149
11150
11151
11152
11153
11154
11155
11156
11157
11158
11159
11160
11161
11162
11163
11164
11165
11166
11167
11168
11169
11170
11171
11172
11173
11174
11175
11176
11177
11178
11179
11180
11181
11182
11183
11184
11185
11186
11187
11188
11189
11190
11191
11192
11193
11194
11195
11196
11197
11198
11199
11200
11201
11202
11203
11204
11205
11206
11207
11208
11209
11210
11211
11212
11213
11214
11215
11216
11217
11218
11219
11220
11221
11222
11223
11224
11225
11226
11227
11228
11229
11230
11231
11232
11233
11234
11235
11236
11237
11238
11239
11240
11241
11242
11243
11244
11245
11246
11247
11248
11249
11250
11251
11252
11253
11254
11255
11256
11257
11258
11259
11260
11261
11262
11263
11264
11265
11266
11267
11268
11269
11270
11271
11272
11273
11274
11275
11276
11277
11278
11279
11280
11281
11282
11283
11284
11285
11286
11287
11288
11289
11290
11291
11292
11293
11294
11295
11296
11297
11298
11299
11300
11301
11302
11303
11304
11305
11306
11307
11308
11309
11310
11311
11312
11313
11314
11315
11316
11317
11318
11319
11320
11321
11322
11323
11324
11325
11326
11327
11328
11329
11330
11331
11332
11333
11334
11335
11336
11337
11338
11339
11340
11341
11342
11343
11344
11345
11346
11347
11348
11349
11350
11351
11352
11353
11354
11355
11356
11357
11358
11359
11360
11361
11362
11363
11364
11365
11366
11367
11368
11369
11370
11371
11372
11373
11374
11375
11376
11377
11378
11379
11380
11381
11382
11383
11384
11385
11386
11387
11388
11389
11390
11391
11392
11393
11394
11395
11396
11397
11398
11399
11400
11401
11402
11403
11404
11405
11406
11407
11408
11409
11410
11411
11412
11413
11414
11415
11416
11417
11418
11419
11420
11421
11422
11423
11424
11425
11426
11427
11428
11429
11430
11431
11432
11433
11434
11435
11436
11437
11438
11439
11440
11441
11442
11443
11444
11445
11446
11447
11448
11449
11450
11451
11452
11453
11454
11455
11456
11457
11458
11459
11460
11461
11462
11463
11464
11465
11466
11467
11468
11469
11470
11471
11472
11473
11474
11475
11476
11477
11478
11479
11480
11481
11482
11483
11484
11485
11486
11487
11488
11489
11490
11491
11492
11493
11494
11495
11496
11497
11498
11499
11500
11501
11502
11503
11504
11505
11506
11507
11508
11509
11510
11511
11512
11513
11514
11515
11516
11517
11518
11519
11520
11521
11522
11523
11524
11525
11526
11527
11528
11529
11530
11531
11532
11533
11534
11535
11536
11537
11538
11539
11540
11541
11542
11543
11544
11545
11546
11547
11548
11549
11550
11551
11552
11553
11554
11555
11556
11557
11558
11559
11560
11561
11562
11563
11564
11565
11566
11567
11568
11569
11570
11571
11572
11573
11574
11575
11576
11577
11578
11579
11580
11581
11582
11583
11584
11585
11586
11587
11588
11589
11590
11591
11592
11593
11594
11595
11596
11597
11598
11599
11600
11601
11602
11603
11604
11605
11606
11607
11608
11609
11610
11611
11612
11613
11614
11615
11616
11617
11618
11619
11620
11621
11622
11623
11624
11625
11626
11627
11628
11629
11630
11631
11632
11633
11634
11635
11636
11637
11638
11639
11640
11641
11642
11643
11644
11645
11646
11647
11648
11649
11650
11651
11652
11653
11654
11655
11656
11657
11658
11659
11660
11661
11662
11663
11664
11665
11666
11667
11668
11669
11670
11671
11672
11673
11674
11675
11676
11677
11678
11679
11680
11681
11682
11683
11684
11685
11686
11687
11688
11689
11690
11691
11692
11693
11694
11695
11696
11697
11698
11699
11700
11701
11702
11703
11704
11705
11706
11707
11708
11709
11710
11711
11712
11713
11714
11715
11716
11717
11718
11719
11720
11721
11722
11723
11724
11725
11726
11727
11728
11729
11730
11731
11732
11733
11734
11735
11736
11737
11738
11739
11740
11741
11742
11743
11744
11745
11746
11747
11748
11749
11750
11751
11752
11753
11754
11755
11756
11757
11758
11759
11760
11761
11762
11763
11764
11765
11766
11767
11768
11769
11770
11771
11772
11773
11774
11775
11776
11777
11778
11779
11780
11781
11782
11783
11784
11785
11786
11787
11788
11789
11790
11791
11792
11793
11794
11795
11796
11797
11798
11799
11800
11801
11802
11803
11804
11805
11806
11807
11808
11809
11810
11811
11812
11813
11814
11815
11816
11817
11818
11819
11820
11821
11822
11823
11824
11825
11826
11827
11828
11829
11830
11831
11832
11833
11834
11835
11836
11837
11838
11839
11840
11841
11842
11843
11844
11845
11846
11847
11848
11849
11850
11851
11852
11853
11854
11855
11856
11857
11858
11859
11860
11861
11862
11863
11864
11865
11866
11867
11868
11869
11870
11871
11872
11873
11874
11875
11876
11877
11878
11879
11880
11881
11882
11883
11884
11885
11886
11887
11888
11889
11890
11891
11892
11893
11894
11895
11896
11897
11898
11899
11900
11901
11902
11903
11904
11905
11906
11907
11908
11909
11910
11911
11912
11913
11914
11915
11916
11917
11918
11919
11920
11921
11922
11923
11924
11925
11926
11927
11928
11929
11930
11931
11932
11933
11934
11935
11936
11937
11938
11939
11940
11941
11942
11943
11944
11945
11946
11947
11948
11949
11950
11951
11952
11953
11954
11955
11956
11957
11958
11959
11960
11961
11962
11963
11964
11965
11966
11967
11968
11969
11970
11971
11972
11973
11974
11975
11976
11977
11978
11979
11980
11981
11982
11983
11984
11985
11986
11987
11988
11989
11990
11991
11992
11993
11994
11995
11996
11997
11998
11999
12000
12001
12002
12003
12004
12005
12006
12007
12008
12009
12010
12011
12012
12013
12014
12015
12016
12017
12018
12019
12020
12021
12022
12023
12024
12025
12026
12027
12028
12029
12030
12031
12032
12033
12034
12035
12036
12037
12038
12039
12040
12041
12042
12043
12044
12045
12046
12047
12048
12049
12050
12051
12052
12053
12054
12055
12056
12057
12058
12059
12060
12061
12062
12063
12064
12065
12066
12067
12068
12069
12070
12071
12072
12073
12074
12075
12076
12077
12078
12079
12080
12081
12082
12083
12084
12085
12086
12087
12088
12089
12090
12091
12092
12093
12094
12095
12096
12097
12098
12099
12100
12101
12102
12103
12104
12105
12106
12107
12108
12109
12110
12111
12112
12113
12114
12115
12116
12117
12118
12119
12120
12121
12122
12123
12124
12125
12126
12127
12128
12129
12130
12131
12132
12133
12134
12135
12136
12137
12138
12139
12140
12141
12142
12143
12144
12145
12146
12147
12148
12149
12150
12151
12152
12153
12154
12155
12156
12157
12158
12159
12160
12161
12162
12163
12164
12165
12166
12167
12168
12169
12170
12171
12172
12173
12174
12175
12176
12177
12178
12179
12180
12181
12182
12183
12184
12185
12186
12187
12188
12189
12190
12191
12192
12193
12194
12195
12196
12197
12198
12199
12200
12201
12202
12203
12204
12205
12206
12207
12208
12209
12210
12211
12212
12213
12214
12215
12216
12217
12218
12219
12220
12221
12222
12223
12224
12225
12226
12227
12228
12229
12230
12231
12232
12233
12234
12235
12236
12237
12238
12239
12240
12241
12242
12243
12244
12245
12246
12247
12248
12249
12250
12251
12252
12253
12254
12255
12256
12257
12258
12259
12260
12261
12262
12263
12264
12265
12266
12267
12268
12269
12270
12271
12272
12273
12274
12275
12276
12277
12278
12279
12280
12281
12282
12283
12284
12285
12286
12287
12288
12289
12290
12291
12292
12293
12294
12295
12296
12297
12298
12299
12300
12301
12302
12303
12304
12305
12306
12307
12308
12309
12310
12311
12312
12313
12314
12315
12316
12317
12318
12319
12320
12321
12322
12323
12324
12325
12326
12327
12328
12329
12330
12331
12332
12333
12334
12335
12336
12337
12338
12339
12340
12341
12342
12343
12344
12345
12346
12347
12348
12349
12350
12351
12352
12353
12354
12355
12356
12357
12358
12359
12360
12361
12362
12363
12364

                                  Introduction

Design Goals

   Throughout _Alpine_ development, we have had to strike a balance
   between the need to include features which advanced users require and
   the need to keep things simple for beginning users. To strike this
   balance, we have tried to adhere to these design principles:

          - The model presented to the user has to be simple and clear.
          Underlying system operation is hidden as much as possible.
          - It's better to have a few easily understood commands that can
          be repeated than to have some more sophisticated command that
          will do the job all at once.
          - Whenever the user has to select a command, file name, address,
          etc., the user should be given (or can get) a menu from which to
          make the selection. Menus need to be complete, small, organized
          and well thought out.
          - _Alpine_ must provide immediate feedback for the user with
          each operation.
          - _Alpine_ must be very tolerant of user errors. Any time a user
          is about to perform an irreversible act (send a message, expunge
          messages from a folder), _Alpine_ should ask for confirmation.
          - Users should be able to learn by exploration without fear of
          doing anything wrong. This is an important feature so the user
          can get started quickly without reading any manuals and so fewer
          manuals are required.
          - The core set of _Alpine_ functions should be kept to a minimum
          so new users don't feel "lost" in seemingly extraneous commands
          and concepts.

   Just as there were goals relating to the look and feel of _Alpine_,
   there were equally important goals having to do with _Alpine_'s
   structure-the things that users never see but still rely on every time
   they use _Alpine_. While _Alpine_ can be used as a stand-alone mail
   user agent, one of its strongest assets is its use of the Internet
   Message Access Protocol (IMAP) for accessing remote email folders. In
   addition, _Pine_ (the predecessor of _Alpine_) was one of the first
   programs to support the Multipurpose Internet Mail Extensions (MIME)
   specification. With MIME, _Alpine_ users can reliably send any binary
   file to any other person on the Internet who uses a MIME compliant
   email program.

   The decision to use IMAP and MIME reflects the importance of
   interoperability, standardization and robustness in _Alpine_. As you
   work with _Alpine_ more, you will see other features which reflect the
   same values. For example, _Alpine_ enforces strict compliance with RFC
   2822, implements a strong mail folder locking mechanism and verifies a
   process before overwriting any files (e.g. addressbook, expunging
   messages).

Alpine Components

   If you have picked up the _Alpine_ distribution, then you already know
   that _Alpine_ comes in a few different pieces. They are:

   _Alpine_
          The main code from which the _Alpine_ program is compiled.
   _Pico_
          _Pico_ is the name for the _Alpine_ composer. The _Pico_ code is
          used in two ways: (1) it is compiled on its own to be a
          stand-alone editor and, (2) it is compiled as a library for
          _Alpine_ to support composition of messages within _Alpine_.
          _Pico_ is _Alpine_'s internal editor invoked when users need to
          fill in header lines or type the text of an email message.
   _Imap_
          An API for IMAP. Includes the C-Client library, which is
          compiled into _Alpine_, and the IMAP server _IMAPd_. C-Client
          implements the IMAP protocol and also negotiates all access
          between _Alpine_ and the mail folders it operates on, even if
          the folders are local. The C-Client routines are used for email
          folder parsing and interpreting MIME messages. _IMAPd_ is a
          separate server that handles IMAP connections from any
          IMAP-compliant email program. When _Alpine_ accesses a remote
          mailbox, the _Alpine_ program is the IMAP client and the _IMAPd_
          program is the IMAP server. Of course, _Alpine_ can use any
          IMAP-compliant IMAP server, not just _IMAPd_.

                               Background Details

Domain Names

   Domain names are used to uniquely name each host on the Internet. A
   domain name has a number of parts separated by periods. Each label
   represents a level in the hierarchy. An example of a name is:

     olive.cac.washington.edu

   In this domain name the top-level label is _edu_, indicating it is at
   an educational institution, the second-level label is _washington_,
   indicating the University of Washington. _cac_ is a specific department
   within the University of Washington, and _olive_ is the host name. The
   top-level names are assigned by Internet organizations, and other names
   are assigned at the appropriate level. The Domain Name Service, DNS, is
   the distributed database used to look up these names.

   _Alpine_ relies on domain names in multiple places. A domain name is
   embedded into the message-id line generated for each piece of email. A
   domain name is needed to contact an IMAP server to get access to remote
   INBOXes and folders. Most importantly, domain names are needed to
   construct the From: line of your outgoing messages so that people on
   the Internet will be able to get email back to you.

   On UNIX systems, you can set the domain via the user-domain variable in
   the _Alpine_ configuration file, or rely on the file /etc/hosts which
   usually sets the name of the local host. While _Alpine_ can often
   deliver email without the domain name being properly configured, it is
   best to have this set correctly. Problems can usually be solved by
   adjusting the system's entry in the /etc/hosts file. The
   fully-qualified name should be listed before any abbreviations. For
   example,

     128.95.112.99 olive.cac.washington.edu olive

   is preferred over

     128.95.112.99 olive olive.cac.washington.edu

   On PCs, the task of configuring the domain name is a bit different.
   Often times PCs do not have domain names-they have _IP addresses_. IP
   addresses are the numbers which uniquely identify a computer on the
   network. The way you configure your IP address depends on the
   networking software which you use on the PC. You can refer to the
   documentation which came with your networking software or see the PC
   specific installation notes for help configuring the IP address with
   your network software.

   With PCs, it is vital that users set the variable user-domain in the
   _Alpine_ configuration file (PINERC).

   Details on configuring _Alpine_ with correct domain names can be found
   in the Domain Settings section of this document.
     __________________________________________________________________

RFC 2822 Compliance

   _Alpine_ tries to adhere to RFC 2822 fairly strictly.

   As far as outgoing email is concerned, _Alpine_ fully-qualifies
   addresses whenever possible. They are even displayed in fully-qualified
   form on the terminal as the user composes a message. This makes
   addresses more clear and gives a hint to the user that the network
   extends beyond the local organization. _Alpine_ implements
   fully-qualified domain names by tacking on the local domain to all
   unqualified addresses which a user types in. Any address which does not
   contain an "@" is considered unqualified.

   The format for addresses allows for spaces and special characters in
   the full name of an address. For this reason, commas are required to
   separate addresses. If any special characters as defined in RFC 2822
   appear in the full name, quotes are required around the address.
   _Alpine_ will insert the quotes automatically if needed. The common
   cases where this happens are with periods after initials and
   parentheses.

   _Alpine_ expects dates to be in the standard RFC 822 format which is
   something like:
        [www, ] dd mmm yy hh:mm[:ss] [timezone]

   It will attempt to parse dates that are not in this format. When an
   unparsable date is encountered it is shown as question marks in the
   FOLDER INDEX screen.
     __________________________________________________________________

SMTP and Sendmail

   _Alpine_ is a _user agent_ not a _message transfer agent_ (MTA). In
   plain English, that means _Alpine_ does not know how to interact with
   other computers on the Internet to deliver or receive email. What
   _Alpine_ does know how to do is help users read, organize and create
   email. The "dirty work" of delivering and accepting email is handled by
   other programs.

   All outgoing email is delivered to an SMTP server or to a mail transfer
   agent. A common mail transfer agent is sendmail. The usual method of
   delivery used by _Alpine_ is to use either a local or a remote SMTP
   server.

   The selection of which MTA to use depends on the settings of
   smtp-server, sendmail-path, and compile-time options. The first MTA
   specified in the following list is used:
    1. _sendmail-path_ in /usr/local/lib/pine.conf.fixed
    2. _smtp-server_ in /usr/local/pine.conf.fixed
    3. _sendmail-path_ specified on the command line.
    4. _smtp-server_ specified on the command line.
    5. _sendmail-path_ in the user's .pinerc file.
    6. _smtp-server_ in the user's .pinerc file.
    7. _sendmail-path_ in /usr/local/lib/pine.conf
    8. _smtp-server_ in /usr/local/pine.conf
    9. DF_SENDMAIL_PATH defined at compile time.
   10. SENDMAIL and SENDMAILFLAGS defined at compile time.

   If the _sendmail-path_ form is used, a child process is forked, and the
   specified command is executed with the message passed on standard
   input. Standard output is then passed back and displayed for the user.
   _NOTE: The program MUST read the message to be posted on standard input,
   AND operate in the style of sendmail's "-t" option. This method is not
   recommended unless there are special reasons you want to do this._

   If an _smtp-server_ is specified, _Alpine_ operates as an SMTP client.
   SMTP stands for _Simple Mail Transfer Protocol_; it specifies the rules
   by which computers on the Internet pass email to one another. In this
   case, _Alpine_ passes outgoing email messages to a designated SMTP
   server instead of to a mail transfer program on the local machine. A
   program on the server then takes care of delivering the message. To
   make _Alpine_ operate as an SMTP client, the smtp-server variable must
   be set to the IP address or host name of the SMTP server within your
   organization. This variable accepts a comma separated list of servers,
   so you can specify multiple alternate SMTP servers. _PC-Alpine_ only
   runs as an SMTP client so the _smtp-server_ option is mandatory.

   For UNIX _Alpine_, if neither _smtp-server_ or _sendmail-path_ is set,
   the default sendmail program is invoked with the "-bs -odb -oem" flags,
   and the message is sent using the SMTP protocol.
     __________________________________________________________________

Internet Message Access Protocol (IMAP)

   IMAP is a remote access protocol for message stores. _Alpine_ uses IMAP
   to get at messages and folders which reside on remote machines. With
   IMAP, messages are kept on the server. An IMAP client (such as
   _Alpine_) can request specific messages, headers, message structures,
   message parts, etc. The client can also issue commands which delete
   messages from folders on the server. IMAP's closest kin is POP, the
   Post Office Protocol, which works by transferring an entire mailbox to
   the client where all the mail is kept. For a comparison of IMAP and
   POP, see the paper "Comparing Two Approaches to Remote Mailbox Access:
   IMAP vs. POP" by Terry Gray. A more detailed exploration of message
   access may be found in the paper " Message Access Paradigms and
   Protocols."

   IMAP Features:
     * Allows access to mail folders from more than one client computer.
     * Works well over low-bandwidth lines because information is sent in
       small pieces as needed by the user. For example, only header
       information is sent to build index lists, and if someone sends a
       large audio file via MIME, you can choose when (or if) you want to
       get that part of the message.
     * Email can be delivered and stored on a well-maintained and reliable
       server which is "always-up".
     * Folders can be accessed and manipulated from anywhere on the
       Internet.
     * Users can get to messages stored in different folders within the
       same _Alpine_ session.
     * Allows use of IMAP server for searching and parsing.
     * The latest revision of IMAP (IMAP4) also provides for disconnected
       operation, including resynchronization of message state between
       mail servers and message caches on clients. _Alpine_ does not
       support this capability, however.

   IMAP4rev1 is described in RFC 3501. Further information about IMAP may
   be obtained from the University of Washington's IMAP Information
   Center.

   _Alpine_ is an IMAP4rev1 client.
     __________________________________________________________________

Multipurpose Internet Mail Extensions (MIME)

   MIME is a way of encoding a multipart message structure into a standard
   Internet email message. The parts may be nested and may be of seven
   different types: Text, Audio, Image, Video, Message, Application and
   Multipart (nested). The MIME specification allows email programs such
   as _Alpine_ to reliably and simply exchange binary data (images,
   spreadsheets, etc.). MIME includes support for international character
   sets, tagging each part of a message with the character set it is
   written in, and providing 7-bit encoding of 8-bit character sets.

   The MIME standard was officially published in June of 1992 as RFC 1341
   and subsequently revised in RFC 2045 when it became a full Internet
   Standard. _Pine_ 3.0 was one of the first email programs to Implement
   MIME. Now, there are dozens of commercial and freely available
   MIME-capable email programs. In addition, MIME is being added to
   newsreaders so MIME messages can be posted and read in USENET
   newsgroups.

   The MIME standard also includes support for non-ASCII text in message
   headers through the extensions described in RFC 1342 and subsequently
   revised in RFC 2047.

   An actual MIME message looks something like this:
Date: Tue, 12 Mar 1996 15:39:35 -0800 (PST)
From: David L Miller <dlm@cac.washington.edu>
To: David L Miller <dlm@cac.washington.edu>
Subject: =?iso-8859-1?Q?Test_MIME_message_with_RFC-1522_headers_=28=E1?=    =?is
o-8859-1?Q?=E2=E3=29?=
Message-Id: <Pine.ULT.3.92.960312150851.21583I-101000@shiva2.cac.washington.edu>
Mime-Version: 1.0
Content-Type: MULTIPART/MIXED; BOUNDARY="0-1737669234-826673975=:21583"
Content-Id: <Pine.ULT.3.92.960312153928.21583O@shiva2.cac.washington.edu>

  This message is in MIME format.  The first part should be readable text,
  while the remaining parts are likely unreadable without MIME-aware tools.
  Send mail to mime@docserver.cac.washington.edu for more info.

--0-1737669234-826673975=:21583
Content-Type: TEXT/PLAIN; CHARSET=US-ASCII
Content-ID: <Pine.ULT.3.92.960312153104.21583L@shiva2.cac.washington.edu>

The text of the message would go here. It is readable if
one doesn't mind wading around a little bit of the MIME
formatting. After this is a binary file in base 64
encoding.

|\ |  |\/|  David L. Miller    dlm@cac.washington.edu  (206) 685-6240
|/ |_ |  |  Software Engineer, Pine Development Team   (206) 685-4045 (FAX)
University of Washington, Networks & Distributed Computing, JE-20
4545 15th Ave NE, Seattle WA 98105, USA

--0-1737669234-826673975=:21583
Content-Type: APPLICATION/ZIP; NAME="test.zip"
Content-Transfer-Encoding: BASE64
Content-ID: <Pine.ULT.3.92.960312153638.21583N@shiva2.cac.washington.edu>
Content-Description: Test Attachment

UEsDBBQAAAAIAGh8bCBbZKT4ygIAAHgFAAAEAAAAdGVzdIVUX2vbMBB/16c4
9rSBNyjsYX1UHSUROLInycv2qNhKI5ZYxlLa5dvvpDRLw6CFgJF09/t3Rxo3
WDBDD43rPJjJQpxMbw9m+h3AbyHuLLSDe7JTcPGUbtYm7NzwGP3wBYQnnT8c
7NQ5s4djsC8t4QbmYE6wsfjpLTy7uPPHCOPk/ATPk4vRDmS008GF4PzwPich
zY3m4LfxOQlPNy4GcEO3P/a2h2j/xGyp9ONpco+7CHf33+4/393ff4XNibzL
c1UVfXJXQIdIBRx877b4TYy9C3Fym2NEyzsX/pNDet8dD3aIJiagLbo2wwnG
4zT6cK66ZLK1NhH9J4tcZQEy7OxkNyd4nMwQbV9glP7JZb87E3O32fgnm7We
XQ8+us4SM47WTCkgMPt9enc2ZAW5c+Pj7o32l0IXXk/r8pSRE3A4jqOfIqqF
G+PFlSdRDOaQduXNESTwtDcYfJ8191gWXUjYmOJ43Oxdh11JTzRuSPcY37+B
vNqmf0O5RB1G27mt64rLCp4X8pW1L6BvxunCeYHNk3F7s9lb+GAwyvAhOyNE
Lxm0gv9gUnH9C+o5rKlacrHQtYAZV2VF+UoBrSp8kJIKzZkqgP1sJFMKagl8
1VSczQqy5noJki2onIGuQS+5AlXPNfaxArgoq3aGwJDq6lZDxVdcU82RKMG/
4JArTVKzYrJc4pE+8CoJpGIGc65FIp8jO4WGSs3LtqISmlY2tUKyVMUFETWw
H0xoUMvE8KbXB4aC6EPFzrDiF6iGlZxWBeFixiUrdXJb1kKx7y2C4hPM6Iou
WI4hdVyO6yXVqkZqiXmottLJ9lzWK1LVKttqk8oZ1TS1NrJGS5jqeslQI0aK
ieCvzNlgNZJqiccCc5WafLxmKdii4gsmSvYpISkteamzkRwXJiG5SoUpcERK
8xIE8QQ7o+eh5WAUy1qYRP8rioip/maI+OfyF1BLAQIUAxQAAAAIAGh8bCBb
ZKT4ygIAAHgFAAAEAAAAAAAAAAEAAACkgQAAAAB0ZXN0UEsFBgAAAAABAAEA
MgAAAOwCAAAAAA==
--0-1737669234-826673975=:21583--


   For details about _Alpine_'s implementation of MIME, see the two MIME
   sections "MIME: Reading a Message" and "MIME: Sending a Message" later
   in this document.
     __________________________________________________________________

Folder Collections

   Folder Collections are _Alpine_'s way of dealing with more than a
   single group of folders.

   For a more complete description of Folder Collections, see the section
   on "Syntax for Collections."

   The _Alpine_ distribution is designed to require as little
   configuration and effort at compile time as possible. Still, there are
   some _Alpine_ behaviors which are set at the time you compile _Alpine_.
   For each of these, there is a reasonable (our opinion) default built
   into the code, so most systems administrators will have no need for
   these steps.

                           Building and Installation

Compile-time Options

   _Alpine_'s UNIX build environment is based on Autotools (the GNU Build
   System). Once you've unpacked the source distribution find the file
   configure in the top-level directory. You may look at the many options
   available by typing

                             ./configure --help

   or you could just try building with the command

                                 ./configure

   followed by

                                    make

   Note, while the UW IMAP Toolkit (whose c-client library _Alpine_ uses
   for mailbox access) build is not based on Autotools, _Alpine_'s
   configure script should set an appropriate make target and compilation
   options for most systems.

   Some of the following can only be set when you build. Others, however,
   can be overridden by command-line flags to _Alpine_ or settings in
   _Alpine_'s user or system configuration files. Some of the options which
   can be set when building:

  Including LDAP Functionality

   By default, the configure script will attempt to find the LDAP library
   support for you. If you are having trouble with LDAP take a look at the
   configure options
   --with-ldap-dir=DIR
          Specify the root of the LDAP lib/include path.
   --with-ldap-include-dir=DIR
          Specify the LDAP include path.
   --with-ldap-lib-dir=DIR
          Specify the LDAP library path.
   --without-ldap
          Disable LDAP support.

   _Alpine_ uses LDAPv3 protocol. When using the LDAPv3 protocol, the
   results are assumed to be in the UTF-8 character set, which _Alpine_
   handles well. If the LDAP server returns non-ascii data which is not
   encoded as UTF-8 you will probably run into problems.

  Including Kerberos 5 Functionality

   This works analogously to the LDAP build. By default, the configure
   script will attempt to find the Kerberos library support for you. If
   you are having trouble with Kerberos take a look at the configure
   options
   --with-krb5-dir=DIR
          Specify the root of the Kerberos lib/include path.
   --with-krb5-include-dir=DIR
          Specify the Kerberos include path.
   --with-krb5-lib-dir=DIR
          Specify the Kerberos library path.
   --without-krb5
          Disable Kerberos support.

  Other Alpine Compile-time Options

   --disable-nls
          Do not use Native Language Support. NLS refers to the use of GNU
          gettext utilities to localize a program, in the sense that
          English is translated to some other language. At the time this
          was written the low-level support for NSL is included in _Alpine_
          but no translations have been done. If there is no translation
          available, that means that disabling NLS will make no
          difference. If you have trouble building which is due to gettext
          or libintl you could try this option, or one of the following.
   --with-libintl-prefix[=DIR]
   --without-libintl-prefix
   --with-ssl-dir=DIR
          Specify the root of the SSL lib/include path (OpenSSL).
   --with-ssl-include-dir=DIR
          Specify the SSL include path.
   --with-ssl-lib-dir=DIR
          Specify the SSL library path.
   --with-ssl-certs-dir=DIR
          Specify the path to the SSL certificates directory.
   --without-ssl
          Disable SSL support.
   --without-pthread
          Do not test for nor build with POSIX thread support, which is
          used only for the Busy-Cue in the status line at this time.
   --without-smime
          Disable S/MIME support.
   --disable-debug
          Never create debug files.
   --with-smtp-msa=PATH
          Local Mail Submission Agent (sendmail, by default).
   --with-smtp-msa-flags=FLAGS
          MSA flags for SMTP on stdin/stdout (-bs -odb -oem).

   There are many more options which you can see using the

                             ./configure --help

   command.

  IMAPd Compile-time Options

   There are no options or settings required for the version of _IMAPd_
   distributed with _Alpine_. If you need to be doing more complex
   modifications to IMAP, then you should pick up the IMAP development
   package and work with that code. The developer's version of IMAP is
   available for anonymous ftp from ftp.cac.washington.edu in the
   directory mail. The file is called imap.tar.Z. Unless it has changed
   since _Alpine_ was released, the directory imap in the _Alpine_
   distribution is the IMAP development package.

   The c-client library has not been converted to use the GNU Build
   System's autotools. The _Alpine_ configure script will try to correctly
   guess the arguments needed for the c-client make command and will build
   the library, but if you need to change anything you should take a look
   at imap/docs/BUILD for more detailed instructions.
     __________________________________________________________________

Building the Alpine Programs

   You may have already compiled _Alpine_ and tried it out. If so, great!
   If not, you should be able to do it without too much trouble by
   following these step-by-step instructions:

    1. Make sure you're in the root of the _Alpine_ source. When you type
       ls you should see the following files and directories (or something
       close to it):
aclocal.m4    config.sub    imap        Makefile.am    packages  web
alpine        configure     include     Makefile.in    pico
build.bat     configure.ac  install-sh  mapi           pith
build.cmd     contrib       LICENSE     missing        po
config.guess  depcomp       ltmain.sh   mkinstalldirs  README
config.rpath  doc           m4          NOTICE         VERSION

    2. Give the command ./configure Configure should grind away for a few
       minutes.
    3. When configure is complete, give the command make. If make stops
       and asks

         Do you want to build with IPv6 anyway? Type y or n please:
       you should answer with a 'y'. The compiler should grind away for a
       few minutes. The _Alpine_ binary will end up in .../alpine/alpine
       and the Pico and Pilot binaries in .../pico/pico and
       .../pico/pilot. Other binaries you may be interested in are
       .../alpine/rpdump and .../alpine/rpload and c-client binaries in
       the directories .../imap/imapd, .../imap/ipopd, .../imap/mailutil,
       and so on.
    4. If you need to try again, make sure you're getting a clean start by
       giving the command make clean.
     __________________________________________________________________

Installing Alpine and Pico on UNIX Platforms

   Installing _Alpine_ and _Pico_ is simple. You take the program files
   which you have just transferred or built and you move them to the
   correct directory on your system. Most often the binaries go in
   /usr/local/bin though sometimes they are placed in /usr/bin. All the
   help text is compiled into _Alpine_ so there are no _required_
   auxiliary files. Instead of copying the binaries manually, you may use
   make install to install them.

   There are three optional auxiliary files: /usr/local/lib/pine.info,
   /usr/local/lib/pine.conf, and /usr/local/lib/pine.conf.fixed. The file
   pine.info contains text on how to get further help on the local system.
   It is part of the help text for the main menu and should probably refer
   to the local help desk or the system administrator. If this file
   doesn't exist a generic version which suggests ``talking to the
   computer support staff at your site'' is shown. The file pine.conf is
   used to set system-wide default configurations for _Alpine_. The file
   pine.conf.fixed is also used to set system-wide default configurations
   for _Alpine_. The difference between these two files is that
   configuration variables set in the pine.conf.fixed file may not
   normally be over-ridden by a user. See the section on Alpine
   Configuration later in this document for details about the pine.conf
   and pine.conf.fixed files.
     __________________________________________________________________

Installing PC-Alpine

   The PC-Alpine distribution comes as a .zip file. To install, unzip the
   files to a directory where you would like the program to reside. Modern
   Windows versions come with the capability of unzipping .zip files.
   Failing that, you can use one of the many .zip file extractors out
   there. Following current Windows conventions, a common directory into
   which the files could be extracted would be C:\Program
   Files\PC-Alpine\.

   Having extracted PC-Alpine's .zip file to the directory of choice, you
   can now run that directory's alpine.exe, which is the actual PC-Alpine
   program. For convenience, you could place shortcuts to it on the task
   bar, start menu, etc.

   Upon first running PC-Alpine, you may be asked where you would like to
   access your Configuration file (called the _pinerc_). This is useful in
   accessing already existing configuration files, and it does not matter
   where this file gets created. If you are connecting to an IMAP server
   to access your email, it is also possible to store this Configuration
   data on that server, which facilitates accessing the same configuration
   from multiple machines (in fact, your configuration may have already
   been set up this way for use with other _Alpine_ programs).

   After having established the location of the configuration file, it may
   be necessary to specify a few configuration settings before reading or
   sending mail. You may be prompted for the following (which may also be
   edited from the (S)etup (C)onfig screen from the Main Menu):

     Folder to open as inbox (or _inbox-path_) - This can be an inbox
   residing on an IMAP or POP3 server, or one residing locally. An example
   of an INBOX for an IMAP server is: {server.example.com}INBOX.

     User-id, Personal name, and host/domain, which are to be used as your
   email address.

     SMTP server to forward message - You must enter your SMTP server
   before you can send any messages.

   At this point, you will be able to read and send email messages. There
   are, however, many more preferences that you can set in the
   Configuration screen.
     __________________________________________________________________

Installing IMAPd

   When the _Alpine_ distribution is built on a UNIX system, the IMAP
   server binary, imapd, is compiled. Installing imapd requires placing
   the binary in the appropriate directory, usually /usr/etc, and adding
   entries to /etc/services and /etc/inetd.conf or their counterparts.

   Instead of including installation instructions here we'll just include
   a pointer to detailed instructions in the c-client distribution. Please
   take a look at the file imap/docs/BUILD in the source tree.
     __________________________________________________________________

Support Files and Environment Variables: UNIX Alpine

   This section lists the various files which _Alpine_ uses which are not
   email folders. All of these are the default names of files, they may
   vary based on _Alpine_'s configuration.
   /usr/local/lib/pine.conf
          Pine's global configuration file.
   /usr/local/lib/pine.conf.fixed
          Non-overridable global configuration file.
   /usr/local/lib/pine.info
          Local pointer to system administrator.
   ~/.pinerc
          Personal configuration file for each user.
   ~/.pinercex
          Personal exceptions configuration file for each user.
   ~/.addressbook
          Personal addressbook
   ~/.newsrc
          Personal USENET subscription list. This is shared with other
          newsreading programs.
   ~/.pine-debugX
          The files created for debugging _Alpine_ problems. By default,
          there are 4 .pine-debug files kept at any time.
   ~/.signature
          A signature file which will be included in all outgoing email
          messages.
   ~/.pine-interrupted-mail
          The text of a message which was interrupted by some unexpected
          error which _Alpine_ detected.
   ~/mail/postponed-msgs
          A folder of messages which the user chose to postpone.
   /etc/mailcap
          System-wide mail capabilities file. Only used if $MAILCAPS not
          set.
   ~/.mailcap
          Personal mail capabilities file. Combines with system-wide
          mailcap. Only used if $MAILCAPS not set.

   The location of the following support files may be controlled by
   variables in the personal or global _Alpine_ configuration file:
   signature, addressbook and its index file, postponed messages, and
   newsrc.

   Unix _Alpine_ uses the following environment variables:
   TERM
          Tells _Alpine_ what kind of terminal is being used.
   DISPLAY
          Determines if _Alpine_ will try to display IMAGE attachments.
   TMPDIR, TMP, or TEMP
          Specifies location of temporary storage area, first one set wins
   SHELL
          If not set, default is /bin/sh
   MAILCAPS
          A semicolon delimited list of path names to mailcap files.
     __________________________________________________________________

Support Files, Environment Variables, and Registry Settings: PC-Alpine

   This section lists the various files which _PC-Alpine_ uses which are
   not normal mail folders. All of these are the default names of files,
   they may vary based on _Alpine_'s configuration.

   $PINERC or <PineRC registry value> or $HOME\PINE\PINERC or <PINE.EXE
          dir>\PINERC
          Path to (required) personal configuration file.
   $PINERCEX or $HOME\PINE\PINERCEX or <PINE.EXE dir>\PINERCEX
          Path to personal exceptions configuration file.
   $PINECONF
          Path of optional global configuration file.
   <PINERC directory>\ADDRBOOK
          Personal addressbook
   <PINERC directory>\PINEDEBG.TXT
          Location of _Alpine_ debug file.
   <PINERC directory>\MAILCAP and/or <PINE.EXE dir>\MAILCAP
          These paths are only used if $MAILCAPS not set.
   $HOME\NEWSRC or <PINERC directory>\NEWSRC
          Personal USENET subscription list. This may be shared with other
          newsreading programs.
   $HOME\MAIL\INTRUPTD
          The text of a message which was interrupted by some unexpected
          error which _Alpine_ detected.
   $HOME\MAIL\POSTPOND
          A folder of messages which the user chose to postpone.

   Registry Values:
   HKEY_LOCAL_MACHINE\Software\University of Washington\Alpine\1.0
          _Pinedir_: The directory that contains the _Alpine_ executable.
          _PineEXE_: The name of the _Alpine_ executable (most commonly
          "alpine.exe").
   HKEY_CURRENT_USER\Software\University of Washington\Alpine\1.0
          _PineRC_: The path that points to the default pinerc to use.
   HKEY_LOCAL_MACHINE\Software\Clients\Mail\Alpine
          _DLLPath_: The path that points to _Alpine_'s pmapi32.dll.
   HKLM\Software\Clients\Mail\Alpine\shell\open\command
          _(Default)_: When set as the default mailer, this is the command
          that is run by external programs.
   HKLM\Software\Clients\Mail\Alpine\Protocols\Mailto\DefaultIcon
          _(Default)_: This points to the icon to display in relation to
          _Alpine_'s mailto URL rendering.
   HKLM\Software\Clients\Mail\Alpine\Protocols\Mailto\shell\open\command
          _(Default)_: This value is the command that gets run by external
          programs when a mailto URL is run with _PC-Alpine_ set as the
          default mailer.
   HKLM\Software\Clients\News\Alpine\shell\open\command
          _(Default)_: When set as the default newsreader, this is the
          command that is run by external programs.
   HKLM\Software\Clients\News\Alpine\Protocols\news\DefaultIcon
          _(Default)_: This points to the icon to display in relation to
          _Alpine_'s news URL rendering.
   HKLM\Software\Clients\News\Alpine\Protocols\news\shell\open\command
          _(Default)_: This value is the command that gets run by external
          programs when a news URL is run with _Alpine_ set as the default
          newsreader.
   HKLM\Software\Clients\News\Alpine\Protocols\nntp\DefaultIcon
          _(Default)_: This points to the icon to display in relation to
          _Alpine_'s nntp URL rendering.
   HKLM\Software\Clients\News\Alpine\Protocols\nntp\shell\open\command
          _(Default)_: This value is the command that gets run by external
          programs when a nntp URL is run with _Alpine_ set as the default
          newsreader.

   _Alpine_'s personal configuration file may be in the same directory as
   the executable, or if that is inconvenient because the executable is on
   a shared or read-only drive, then it can be in a file named by the
   $PINERC environment variable, or in $HOME\ALPINE\PINERC, where if not
   set, $HOME defaults to the root of the current working drive.

   Most of the other support files key off of the location of the PINERC
   file. However, in the case of the NEWSRC file, the path $HOME\NEWSRC is
   checked first. Also, the postponed messages and interrupted message
   folders are placed in the default folder collection, normally in the
   directory $HOME\MAIL.

   The location of the following support files may be controlled by
   variables in the personal or global _Alpine_ configuration file:
   signature, addressbook (and its index file), postponed messages, and
   newsrc.

   _PC-Alpine_ uses the following environment variables:
   PINERC
          Overrides default path to pinerc file.
   PINERCEX
          Overrides default path to personal exceptions configuration
          file.
   PINECONF
          Optional path to global _Alpine_ config file.
   HOME
          If not set, _Alpine_ uses the root of the current drive, e.g. C:
   TMPDIR, TMP, or TEMP
          Specifies location of temporary storage area, first one set wins
   COMSPEC
          Specifies shell for external commands.
   MAILCAPS
          A semicolon delimited list of path names to mailcap files.

                             Command Line Arguments

Alpine

   _Alpine_ and _PC-Alpine_ can accept quite a few command-line arguments.
   Many of these arguments overlap with variables in the _Alpine_
   configuration file. If there is a difference, then a flag set in the
   command line takes precedence. Both _Alpine_ and _PC-Alpine_ expect
   command line arguments (other than addresses) to be preceded by the "-"
   (dash) as normally used by UNIX programs.

   _[addresses]_
          Send-to: If you give _Alpine_ an argument or arguments which do
          not begin with a dash, _Alpine_ treats them as email addresses.
          _Alpine_ will startup in the composer with a message started to
          the addresses specified. Once the message is sent, the _Alpine_
          session closes. Standard input redirection is allowed. Separate
          multiple addresses with a space between them. Addresses are
          placed in the "To" field only.
   < _file_
          _Alpine_ will startup in the composer with _file_ read into the
          body of the message. Once the message is sent, the _Alpine_
          session closes.
   -attach _file_
          Go directly into composer with given file attached.
   -attachlist _file-list_
          Go directly into composer with given files attached. This must
          be the last option on the command line.
   -attach_and_delete _file_
          Go directly into composer with given file attached, delete when
          finished.
   -aux _local_directory_
          _PC-Alpine_ only. This tells _PC-Alpine_ the local directory to
          use for storing auxiliary files, like debug files, address
          books, and signature files. The pinerc may be local or remote.
   -nosplash
          _PC-Alpine_ only. This tells _PC-Alpine_ to not display the
          splash screen upon startup. This may be helpful for certain
          troubleshooting or terminal server scenarios.
   -bail
          If the personal configuration file doesn't already exist, exit.
          This might be useful if the configuration file is accessed using
          some remote filesystem protocol. If the remote mount is missing
          this will cause _Alpine_ to quit instead of creating a new
          pinerc.
   -c _n_
          When used with the -f option, apply the _n_th context. This is
          used when there are multiple folder collections (contexts) and
          you want to open a folder not in the primary collection.
   -conf
          Configuration: Prints a sample system configuration file to the
          screen or standard output. To generate an initial system
          configuration file, execute
                alpine -conf > /usr/local/lib/pine.conf

          To generate a system configuration file using settings from an
          old system configuration file, execute
                alpine -P old-pine.conf -conf > /usr/local/lib/pine.conf

          A system configuration file is not required.
   -convert_sigs _-p pinerc_
          Convert signatures contained in signature files into literal
          signatures.
   -copy_abook _<local_abook_file> <remote_abook_folder>_
          Copy an address book file to a remote address book folder. If
          the remote folder doesn't exist, it will be created. If it
          exists but the first message in the folder isn't a remote
          address book header message, the copy will be aborted. This flag
          will not usually be used by a user. Instead, the user will
          create a remote address book from within _Alpine_ and copy
          entries from the local address book by using aggregate Save in
          the address book screen.
   -copy_pinerc _<local_pinerc_file> <remote_pinerc_folder>_
          Copy a pinerc configuration file to a remote pinerc folder. If
          the remote folder doesn't exist, it will be created. If it
          exists but the first message in the folder isn't a remote pinerc
          header message, the copy will be aborted. This flag may be
          useful to users who already have a local pinerc file and would
          like to convert it to a remote pinerc folder and use that
          instead. This gives a way to bootstrap that conversion without
          having to manually reset all of the variables in the remote
          pinerc folder.
   -d _debug-level_
          Debug Level: Sets the level of debugging information written by
          _Alpine_. _Debug-level_ can be set to any integer 0-9. A debug
          level of 0 turns off debugging for the session. (Actually there
          are some levels higher than 9, but you probably don't want to
          see them. Sensitive authentication information is hidden at
          levels less than 10.)
   -d _keywords_
          You may use a more detailed version of the debugging flag to set
          the debug level in separate parts of _Alpine_. The possibilities
          are flush, timestamp, imap=0..4, tcp, numfiles=0..31, and
          verbose=0..9. _Flush_ causes debugging information to be flushed
          immediately to the debug file as it is written. _Verbose_ is the
          general debugging verbosity level. _Timestamp_ causes timestamps
          to be added to the debug file, which is useful when you are
          trying to figure out what is responsible for delays. _Numfiles_
          sets the number of debug files saved. _Imap_ sets the debug
          level for the debugging statements related to the conversation
          with the IMAP server, and more generally, for the debugging
          related to _Alpine_'s interaction with the C-Client library. If
          _imap_ is set higher than 4, sensitive authentication information
          will be included in the debug file. _Tcp_ adds more TCP/IP
          debugging information.
   -f _folder_
          Startup folder: _Alpine_ will open this folder in place of the
          standard INBOX.
   -F _file_
          Open named text file for viewing and forwarding.
   -h
          Help: Prints the list of available command-line arguments to the
          screen.
   -i
          _Alpine_ will start up in the FOLDER INDEX screen instead of the
          MAIN MENU.
          Configuration equivalent: _initial-keystroke-list=i_.
   -I _a,b,c,..._
          Initial Keystrokes: _Alpine_ will execute this comma-separated
          sequence of commands upon startup. This allows users to get
          _Alpine_ to start in any of its menus/screens. You cannot include
          any input to the composer in the initial keystrokes. The key
          <Return> is represented by a ``CR'' in the keystroke list; the
          spacebar is designated by the letters ``SPACE''. Control keys
          are two character sequences beginning with ``^'', such as
          ``^I''. A tab character is ``TAB''. Function keys are ``F1'' -
          ``F12'' and the arrow keys are ``UP'', ``DOWN'', ``LEFT'', and
          ``RIGHT''. A restriction is that you can't mix function keys and
          character keys in this list even though you can, in some cases,
          mix them when running _Alpine_. A user can always use only
          _character_ keys in the startup list even if he or she is using
          _function_ keys normally, or vice versa. If an element in this
          list is a string of characters surrounded by double quotes (")
          then it will be expanded into the individual characters in the
          string, excluding the double quotes.
          Configuration equivalent: _initial-keystroke-list_
   -install
          For _PC-Alpine_ only, this option prompts for some basic setup
          information, then exits.
   -k
          Function-Key Mode: When invoked in this way, _Alpine_ expects
          the input of commands to be function-keys. Otherwise, commands
          are linked to the regular character keys.
          Configuration equivalent: _use-function-keys_ included in
          _feature-list_.
   -n _n_
          Message-Number: When specified, _Alpine_ starts up in the FOLDER
          INDEX screen with the current message being the specified
          message number.
   -nowrite_password_cache
          This tells _Alpine_ to use the local password cache if there is
          one, but to never offer writing new passwords to the cache.
   -o _folder_
          Opens the INBOX (or a folder specified via the -f argument)
          ReadOnly.
   -p _pinerc_
          Uses the named file as the personal configuration file instead
          of _~/.pinerc_ or the default PINERC search sequence _PC-Alpine_
          uses. Pinerc may be either a local file or a remote
          configuration folder.
   -P _pinerc_
          Uses the named file as the system wide configuration file
          instead of _/usr/local/lib/pine.conf_ on UNIX, or nothing on
          _PC-Alpine_. Pinerc may be either a local file or a remote
          configuration folder.
   -passfile _passfile_
          This tells _Alpine_ what file should be used as the password
          file. This should be a fully-qualified filename.
   -pinerc _file_
          Output fresh pinerc configuration to _file_, preserving the
          settings of variables that the user has made. Use _file_ set to
          ``-'' to make output go to standard out.
   -r
          Restricted Mode: For UNIX _Alpine_ only. _Alpine_ in restricted
          mode can only send email to itself. Save and export are limited.
   -registry _cmd_
          For _PC-Alpine_ only, this option affects the values of
          _Alpine_'s registry entries. Possible values for _cmd_ are set,
          noset, clear, clearsilent, and dump. _Set_ will always reset
          _Alpine_'s registry entries according to its current settings.
          _NoSet_ will never set any values in the registry, but it will
          still use the values already set in the registry. _Clear_ will
          clear the registry values. _Clearsilent_ will silently clear the
          registry values. _Dump_ will display the values of current
          registry settings. Note that the dump command is currently
          disabled. Without the -registry option, _PC-Alpine_ will write
          values into the registry only if there currently aren't any
          values set.
   -sort _key_
          Sort-Key: Specifies the order messages will be displayed in for
          the FOLDER INDEX screen. _Key_ can have the following values:
          arrival, date, subject, orderedsubj, thread, from, size, score,
          to, cc, arrival/reverse, date/reverse, subject/reverse,
          orderedsubj/reverse, thread/reverse, from/reverse, size/reverse,
          score/reverse, to/reverse, and cc/reverse. The default value is
          "arrival". The _key_ value reverse is equivalent to
          arrival/reverse.
          Configuration equivalent: _sort-key_.
   -supported
          Some options may or may not be supported depending on how
          _Alpine_ was compiled. This is a way to determine which options
          are supported in the particular copy of _Alpine_ you are using.
   -install
          For _PC-Alpine_ only, this option removes references to Alpine
          in Windows settings. The registry settings are removed and the
          password cache is cleared.
   -url _url_
          Open the given URL.
   -v
          Version: Print version information to the screen.
   -version
          Version: Print version information to the screen.
   -x _exceptions_config_
          Configuration settings in the exceptions config override your
          normal default settings. _Exceptions_config_ may be either a
          local file or a remote pinerc folder.
   -z
          Enable Suspend: When run with this flag, the key sequence ctrl-z
          will suspend the _Alpine_ session.
          Configuration equivalent: _enable-suspend_ included in
          _feature-list_.
   -_option_=_value_
          Assign _value_ to the config option _option_. For example,
          _-signature-file=sig1_ or _-feature-list=signature-at-bottom_.
          (Note: feature-list values are additive and features may be
          preceded with no- to turn them off).

Pico

   The following command line options are supported in _Pico_:

   +_n_
          Causes _Pico_ to be started with the cursor located _n_ lines
          into the file. (Note: no space between "+" sign and number)

   -a
          Display all files and directories, including those beginning
          with a period (.).

   -b
          Enable the option to Replace text matches found using the "Where
          is" command. This now does nothing. Instead, the option is
          always turned on (as if the -b flag had been specified).

   -d
          Rebind the "delete" key so the character the cursor is on is
          rubbed out rather than the character to its left.

   -e
          Enable file name completion.

   -f
          Use function keys for commands. _This option supported only in
          conjunction with UW Enhanced NCSA telnet._

   -g
          Enable "Show Cursor" mode in file browser. Cause cursor to be
          positioned before the current selection rather than placed at
          the lower left of the display.

   -k
          Causes "Cut Text" command to remove characters from the cursor
          position to the end of the line rather than remove the entire
          line.

   -m
          Enable mouse functionality. This only works when _Pico_ is run
          from within an X Window System "xterm" window.

   -n_n_
          The -n_n_ option enables new mail notification. The _n_ argument
          is optional, and specifies how often, in seconds, your mailbox
          is checked for new mail. For example, -n60 causes _Pico_ to
          check for new mail once every minute. The default interval is
          180 seconds, while the minimum allowed is 30. (Note: no space
          between "n" and the number)

   -o _dir_
          Sets operating directory. Only files within this directory are
          accessible. Likewise, the file browser is limited to the
          specified directory subtree.

   -p
          Preserve the "start" and "stop" characters, typically Ctrl-Q and
          Ctrl-S, which are sometimes used in communications paths to
          control data flow between devices that operate at different
          speeds.

   -q
          TermdefWins. Termcap or terminfo escape sequences are used in
          preference to default escape sequences.

   -Q _quotestr_
          Set the quote string. Especially useful when composing email,
          setting this allows the quote string to be checked for when
          Justifying paragraphs. A common quote string is "> ".

   -r_n_
          Sets column used to limit the "Justify" command's right margin.

   -t
          Enable "tool" mode. Intended for when _Pico_ is used as the
          editor within other tools (e.g., Elm, Pnews). _Pico_ will not
          prompt for save on exit, and will not rename the buffer during
          the "Write Out" command.

   -v
          View the file only, disallowing any editing.

   -version
          Print version information.

   -w
          Disable word wrap (thus allow editing of long lines).

          _Note: Pico will break any lines over 255 characters when
          reading a file, regardless of word wrapping._

   -x
          Disable keymenu at the bottom of the screen.

   -z
          Enable ^Z suspension of _Pico_.

Pilot

   The following command line options are supported in _Pilot_:

   -a
          Display all files including those beginning with a period (.).

   -f
          Use function keys for commands. _This option supported only in
          conjunction with UW Enhanced NCSA telnet._

   -g
          Enable "Show Cursor" mode. Cause cursor to be positioned before
          the current selection rather than placed at the lower left of
          the display.

   -m
          Enable mouse functionality. This only works when _Pilot_ is run
          from within an X Window System "xterm" window.

   -n_n_
          The -n_n_ option enables new mail notification. The _n_ argument
          is optional, and specifies how often, in seconds, your mailbox
          is checked for new mail. For example, -n60 causes _Pilot_ to
          check for new mail once every minute. The default interval is
          180 seconds, while the minimum allowed is 30. (Note: no space
          between "n" and the number)

   -o _dir_
          Sets operating directory. Only files within the specified
          directory are accessible and browsing is limited to the
          specified directory subtree.

   -v
          Enable single vertical column display.

   -x
          Disable keymenu at the bottom of the screen.

   -z
          Enable ^Z suspension of _Pilot_.

                         Configuration and Preferences

Alpine Configuration

   There is very little in _Alpine_ which _requires_ compile-time
   configuration. In most cases, the compiled-in preferences will suit
   users and administrators just fine. When running _Alpine_ on a UNIX
   system, the default built-in configuration can be changed by setting
   variables in the system configuration files, /usr/local/lib/pine.conf
   or /usr/local/lib/pine.conf.fixed. (Actually, these files can be
   changed using the configure arguments --with-system-pinerc=VALUE or
   --with-system-fixed-pinerc=VALUE.) The location of the pine.conf file
   can be changed with the -P command line argument. Both _Alpine_ and
   _PC-Alpine_ also use personal (user-based) configuration files. On UNIX
   machines, the personal configuration file is the file ~/.pinerc. For
   _PC-Alpine_ systems, the personal configuration file is in $PINERC or
   <PineRC registry value> or ${HOME}\ALPINE\PINERC or <ALPINE.EXE
   dir>\PINERC. Or the personal configuration file can be specified with
   the -p command line argument.

   All of these configuration files, other than the fixed system config
   pine.conf.fixed on UNIX systems, may optionally be remote configuration
   files instead of local files. This is discussed further in the
   following section and in Remote Configuration.

   After the personal configuration, _Alpine_ may optionally use a
   personal exceptions configuration file which is specified with the
   command line option "-x exceptions_config". "Exceptions_config" may
   also be either a local file or a remote configuration folder. For Unix
   _Alpine_, if you don't have a "-x" command line option, _Alpine_ will
   look for the file ".pinercex" in the same local directory that the
   regular config file is located in. If the regular config file is remote
   then Unix _Alpine_ looks in the home directory for ".pinercex".

   For _PC-Alpine_, if you don't have a "-x" command line option,
   _PC-Alpine_ will use the value of the environment variable $PINERCEX. If
   that is not set, _PC-Alpine_ will look for the local file "PINERCEX" in
   the same local directory that the regular config file is located in. If
   the regular config file is remote then _PC-Alpine_ looks in the local
   directory specified by the "-aux local_directory" command line
   argument, or the directory ${HOME}\ALPINE, or in <ALPINE.EXE
   directory>.

   The syntax of a non-list configuration variable is this:

     <variable> = <value>

   If the value is absent then the variable is unset. To set a variable to
   the empty value two double quotes (""). This is equivalent to an absent
   value except that it overrides any system-wide default value that may
   be set. Quotes may be used around any value. All values are strings and
   end at the end of the line or the closing quote. Leading and trailing
   space is ignored unless it is included in the quotes. There is one
   variable, _use-only-domain-name_, for which the only appropriate values
   are _yes_ and _no_. That's because it is a variable from the early days
   of _Alpine_ before features existed.

   There is also a second type of variable, lists. A list is a
   comma-separated list of values. The syntax for a list is:

     <variable> = <value> [, <value> , ... ]

   A list can be continued on subsequent lines by beginning the line with
   white-space. Both the per-user and global configuration files may
   contain comments which are lines beginning with a #.

   For UNIX _Alpine_, there are five ways in which each variable can be
   set. In decreasing order of precedence they are:
    1. the system-wide _fixed_ configuration file
    2. a command line argument
    3. the personal exceptions file
    4. the personal configuration file
    5. the system-wide configuration file.

   If the variable is not set in any of those places, there is a default
   setting in the source code.

   So, system-wide fixed settings always take precedence over command line
   flags, which take precedence over per-user exception settings, which
   take precedence over per-user settings, which take precedence over
   system-wide configuration settings. _PC-Alpine_ has the same list,
   except that it does not use a system-wide _fixed_ configuration file.
   This can be modified slightly by using inheritance, which is covered
   below.

   You may get a sample/fresh copy of the system configuration file by
   running _alpine -conf_. The result will be printed on the standard
   output with very short comments describing each variable. (The online
   help in the Setup screens provides much longer comments.) If you need
   to fix some of the configuration variables, you would use the same
   template for the fixed configuration file as for the regular
   system-wide configuration file. (If it isn't clear, the purpose of the
   fixed configuration file is to allow system administrators to restrict
   the configurability of _Alpine_. It is by no means a bullet-proof
   method.) _Alpine_ will automatically create the personal configuration
   file the first time it is run, so there is no need to generate a
   sample. _Alpine_ reads and writes the personal configuration file
   occasionally during normal operation. Users will not normally look at
   their personal configuration file, but will use the Setup screens from
   within _Alpine_ to set the values in this file. If a user does add
   additional comments to the personal configuration file they will be
   retained.

   References to environment variables may be included in the _Alpine_
   configuration files. The format is $variable or ${variable}. The
   character ~ will be expanded to the $HOME environment variable. For a
   more complete explanation of how environment variables work, see the
   section Using Environment Variables.

   When environment variables are used for _Alpine_ settings which take
   lists, you must have an environment variable set for each member of the
   list. That is, _Alpine_ won't properly recognize an environment
   variable which is set equal to a comma-delimited list. It is OK to
   reference unset environment variables in the _Alpine_ configuration
   file, which will expand to nothing.

  Remote and Local Configuration

   There are two types of storage for configuration information. _Local_
   configuration files are used by default. These are just regular files
   on the UNIX system or on the PC. _Remote_ configuration folders are
   stored on an IMAP server. The advantage of using a remote configuration
   is that the same information may be accessed from multiple platforms.
   For example, if you use one computer at work and another at home, the
   same configuration could be used from both places. A configuration
   change from one place would be seen in both places. Technical
   information about remote configuration is in Remote Configuration.

  Generic and Exceptional Configuration

   If you use _Alpine_ from more than one platform it may be convenient to
   split your configuration information into two pieces, a generic piece
   and exceptions which apply to a particular platform. For example,
   suppose you use _Alpine_ from home and from work. Most of your
   configuration settings are probably the same in both locations, so
   those settings belong in the generic settings configuration. However,
   you may use a different SMTP server and INBOX from home than you do
   from work. The "smtp-server" and "inbox-path" variables could be part
   of your exceptional configuration so that they could be different in
   the two places.

   You can use the command line option "-x config" to split your
   configuration into generic and exceptional pieces. Config may be either
   local or remote.

   For most people, splitting the configuration information into two
   pieces is only going to be useful if the generic information is
   accessed remotely. If you already have a local pinerc file with
   settings you like you may find that the command Setup/RemoteConfigSetup
   will be useful in helping you convert to a remote configuration. The
   command line flag copy_pinerc may also be useful.

  Configuration Inheritance

   Configuration inheritance is a power user feature. It is confusing and
   not completely supported by the configuration user interface.

   For configuration variables which are lists, like "smtp-server" or
   "incoming-folders", the inheritance mechanism makes it possible to
   _combine_ the values of options from different configuration locations
   instead of _replacing_ the value. Configuration Inheritance has more
   information about how inheritance is used.
     __________________________________________________________________

General Configuration Variables

   The following is a list of all _Alpine_ configuration variables, in
   alphabetical order. Note that not all variables apply to all versions
   of _Alpine_ and that some variables are only applicable in a system
   configuration file and some are only applicable in a personal
   configuration file. These are configuration _variables_. Configuration
   Features are in a separate section.

   _addrbook-sort-rule_
          This variable sets up the default address book sorting.
          Currently, _Alpine_ will accept the values _dont-sort_,
          _fullname-with-lists-last_, _fullname_,
          _nickname-with-lists-last_, and _nickname_. The default is to sort
          by fullname with lists last. If you use an address book from
          more than one computer and those computers sort the address book
          differently then the sort order will be the order where the last
          change to the address book was made. There are two reasons the
          sorting might be different on different systems. First, the
          addrbook-sort-rule may be set differently in the two places.
          Second, the collation rules on the two computers may be
          different. For example, one system might ignore special
          characters while the other doesn't or one may sort upper and
          lower case letters together while the other doesn't. In any
          case, the order you see is the order on the system where the
          last change was made, for example by an address book edit or a
          Take Address command.
          This option is displayed as "Addressbook Sort Rule".
   _address-book_
          A list of personal address books. Each entry in the list is an
          optional nickname followed by a pathname or file name relative
          to the home directory. The nickname is separated from the rest
          of the line with whitespace. Instead of a local pathname or file
          name, a remote folder name can be given. This causes the address
          book to be a Remote address book. Remote folder syntax is
          discussed in Syntax for Remote Folders. This list of address
          books will be combined with the global-address-book list to
          arrive at the complete set of address books.
   _addressbook-formats_
          This option specifies the format that address books are
          displayed in. By default, address books are displayed with the
          nicknames in the first column, the fullnames in the second
          column, and addresses in the third column. The system figures
          out reasonable defaults for the widths of the columns. An
          address book may be given a different format by listing special
          tokens in the order you want them to display. The possible
          tokens are NICKNAME, FULLNAME, ADDRESS, FCC, and COMMENT. More
          details are included in the online help for this variable.
   _alt-addresses_
          This option provides a place for you to list alternate email
          addresses you may have. Each address in the list should be the
          actual email address part of an address, without the full name
          field or the angle brackets. For example:

                              user@example.com
          The matching is case-insensitive, so this would match any of
          User@example.com, user@Example.Com, or USER@EXAMPLE.COM as well.
          If set, the option affects the behavior of the Reply command and
          the "+" symbol in the MESSAGE INDEX, which denotes that a
          message has been addressed specifically to you.
          In the default INDEX display the personal name (or email
          address) of the person listed in the message's "From:" header
          field is usually displayed except when that address is yours or
          one of your alternate addresses. In that case you will usually
          see the name of the first person specified in the message's
          "To:" header field with the prefix "To: " prepended.
          With respect to Reply, the reply-to-all option will exclude
          addresses listed here.
          The feature copy-to-address-to-from-if-it-is-us is somewhat
          related to this option.
          In addition to a list of actual addresses, you may use regular
          expressions (as used with egrep with the ignore case flag) to
          describe the addresses you want to match. _Alpine_ will somewhat
          arbitrarily interpret your entry as a regular expression if it
          contains any of the characters *, |, +, ?, {, [, ^, $, or \.
          Otherwise, it will be treated literally. The feature
          disable-regular-expression-matching-for-alternate-addresses may
          be used to turn off regular expression processing regardless of
          whether or not special characters appear in the entry.
          A description of how regular expressions work is beyond the
          scope of this help text, but some examples follow.
          The entry

                               .*@example.com
          in the alt-addresses list would mean that any address with a
          domain name of example.com (such as fred@example.com or
          wilma@example.com) will be considered one of your alternate
          addresses. Strictly speaking, the dot in example.com ought to be
          escaped with a backslash, as in example\.com, and a dollar sign
          anchor ought to come at the end of the expression to prevent a
          match of example.com.org. Complicating things further, the
          dollar sign is special in the _Alpine_ configuration (it
          signifies environment variable expansion) so the dollar sign
          should be doubled or backslash escaped for _Alpine_'s sake.
          Quotes around the whole expression will not escape the dollar
          sign successfully. So this example should look like

                              .*@example\.com$$
          The entry

                          ^fred[0-9]*@example.com$$
          would match fred3@example.com or fred17@example.com as well as
          fred@example.com.
          You could match all addresses that look like
          fred+stuff@example.com for any value of stuff with the entry

                           ^fred\+.*@example.com$$
          Notice that you have to escape the plus sign with a backslash
          because plus is a special character in regular expressions. If
          you wanted to match plain fred as well as fred+stuff the
          expression

                        ^fred(()|\+.*)@example.com$$
          would do it, but it would be easier to just add fred@example.com
          as a separate entry.
          One more example, a match of all first-level subdomains, is
          given by

                    ^fred@[[:alnum:]_-]*\.example\.com$$
          Because the regular expression matching is based on an old
          library (hs_regex) the regular expressions might not work
          exactly as you expect, but they should be close.
          This option is displayed as "Alternate Addresses".
   _bugs-additional-data_
          System-wide configuration files only. Program/Script used by
          _Report Bug_ command. Output from the program/script is captured
          and attached to the bug report.
   _bugs-fullname_, _bugs-address_, _local-fullname_, _local-address_,
          _suggest-fullname_, and _suggest-address_
          System-wide configuration files only. These are used by the bug
          report commands which can be accessed from some of the Help
          screens.
   _busy-cue-rate_
          When _Alpine_ is delayed for some reason it usually shows that
          something is happening with a small animated display in the
          status message line near the bottom of the screen. This option
          sets how frequently the characters (for example, a spinning bar)
          in the active status message lines are updated. At most, it can
          be set to be updated 20 times per second.
          Setting this value to zero will prevent display of the
          animations altogether.
          The option busy-cue-spinner-only can be used to remove the
          randomness from this animated display.
   _character-set_
          This is now obsolete, replaced by three separate variables:
          _display-character-set_, _keyboard-character-set_, and
          _posting-character-set_. See the section on International
          Character Sets for more details.
   _color-style_
          UNIX _Alpine_ only (color is automatically on with _PC-Alpine_).
          If the terminal or terminal emulator you are using is capable of
          displaying colors, this variable controls whether or not color
          will be used in _Alpine_. If you turn color on and things are
          set up correctly, you should see color appear on the screen
          immediately. Modern terminal emulators are usually capable of
          displaying colors.
          This variable may be set to any of the following values:

        no-color
                Don't use color.

        use-termdef
                In order to decide if your terminal is capable of color,
                _Alpine_ looks in the terminal capabilities database,
                TERMINFO or TERMCAP, depending on how _Alpine_ was
                compiled. This is a good option to choose if you switch
                between a color and a non-color terminal with the same
                _Alpine_ configuration. _Alpine_ will know to use color on
                the color terminal because it is described in the termcap
                entry, and _Alpine_ will know to use black and white on
                the non-color terminal. Color Details has more information
                about configuring a termcap entry for color. This is
                usually something a system administrator does.

        force-ansi-8color
                Because setting up a termcap entry is confusing and
                because the terminal capabilities database is often not
                correctly configured for color, this choice and the next
                may be easier for you to use. If your terminal emulator
                responds to ANSI color escape sequences, which many do,
                this option will cause _Alpine_ to believe your terminal
                will respond to the escape sequences which produce eight
                different foreground and background colors. The escape
                sequences used to set the foreground colors are

                          ESC [ 3 <color_number> m

                where the color_number is an ASCII digit between 0 and 7.
                The numbers 0 through 7 should correspond to the colors
                black, red, green, yellow, blue, magenta, cyan, and white.
                Some terminal emulators use a pre-ANSI scheme which swaps
                the colors blue and red and the colors yellow and cyan.
                This will cause the default colors to be different, but
                other than that things should work fine. There is also a
                9th color available, the last one shown, which is the
                default color from the terminal emulator. When used as a
                background color some people refer to this color as
                "transparent", which is why the letters "TRAN" are shown
                in the color swatch of the SETUP COLOR screen. The
                foreground transparent color is shown as the color of the
                "TRAN" text. (The transparent color will not work
                correctly in a PC-Alpine configuration.) The escape
                sequences used to set the background colors are the same
                as for the foreground colors except a "4" replaces the
                "3".

                Note: With the Tera Term terminal emulator this setting
                works well. You should also have the Tera Term "Full
                color" option turned OFF. You may find the "Full color"
                option in Tera Term's "Setup" menu, in the "Window"
                submenu.

        force-ansi-16color
                Many terminal emulators know about the same eight colors
                above plus eight more. This option attempts to use all 16
                colors. The same escape sequences as for the eight-color
                terminal are used for the first eight colors. The escape
                sequences used to set foreground colors 8-15 are the same
                as for 0-7 except the "3" is replaced with a "9". The
                background color sequences for colors 8-15 are the same as
                for 0-7 except the "4" is replaced with "10". You can tell
                if the 16 colors are working by turning on this option and
                then going into one of the color configuration screens,
                for example, the configuration screen for Normal Color. If
                you see 16 different colors to select from (plus a 17th
                for the transparent color), it's working.

        force-xterm-256color
                Some versions of xterm (and some other terminal emulators)
                have support for 256 colors. The escape sequences used to
                set the foreground colors are

                       ESC [ 38 ; 5 ; <color_number> m

                where the color_number is an ASCII digit between 0 and
                255. Background colors are the same with the 38 replaced
                with a 48. The numbers 0 through 15 are probably similar
                to the 16 color version above, then comes a 6x6x6 color
                cube, followed by 24 colors of gray. The terminal default
                (transparent) color is the 257th color at the bottom. Some
                terminal emulators will misinterpret these escape
                sequences causing the terminal to blink or overstrike
                characters or to do something else undesirable.

                The PuTTY terminal emulator has an option called "Allow
                terminal to use xterm 256-colour mode" which allows PuTTY
                to work well with this 256-color setting.

          There are two other possible color values which may be useful in
          some situations. In the color configuration screens there will
          sometimes be a color which has the label "NORM" inside its color
          swatch. If this is selected the corresponding foreground or
          background Normal Color will be used. Another similar color is
          the one that has the label "NONE" inside its color swatch. The
          meaning of this setting is that no color changing will be done.
          This NONE color is only useful in contexts where _Alpine_ is
          already coloring the text some color other than the Normal
          Color. For example, if the Reverse Color is set then the current
          line in the MESSAGE INDEX will be colored. If one of the index
          symbols (for example, the Index-to-me Symbol) has the NONE color
          as its background then the symbol's foreground color will be
          used to draw the actual text but the background color will be
          the same as whatever the background color already was. The color
          values which end up in the configuration file for these special
          values are the 11-character words "norm-padded", "none-padded",
          and "transparent".
          The normal default is "no-color".
          Once you've turned on color you may set the colors of many
          objects on the screen individually. The Color Configuration
          section has more information, or you may just try it by running
          the "Setup" command and typing "K" for Kolor to enter the color
          configuration screen (Kolor instead of Color because C means
          Config). Most categories of color which _Alpine_ supports are
          configurable there. Index line color is configured separately.
   _composer-word-separators_
          This option affects how a "word" is defined in the composer. The
          definition of a word is used when using the Forward Word and
          Backward Word commands in the composer, as well as when using
          the spell checker. Whitespace is always considered a word
          separator. Punctuation (like question marks, periods, commas,
          and so on) is always a word separator if it comes at the end of
          a word. By default, a punctuation character which is in the
          middle of a word does not break up that word as long as the
          character before and the character after it are both
          alphanumeric. If you add a character to this option it will be
          considered a word separator even when it occurs in the middle of
          an alphanumeric word. For example, if you want to skip through
          each part of an address instead of skipping the whole address at
          once you might want to include"@" and "." in this list. If you
          want the word-skipper to stop on each part of a UNIX filename
          you could add "/" to the list. The equal sign and dash are other
          possibilities you might find helpful.
   _composer-wrap-column_
          This option specifies an aspect of _Alpine_'s Composer. This
          gives the maximum width that auto-wrapped lines will have. It's
          also the maximum width of lines justified using the ^J Justify
          command. The normal default is _74_. The largest allowed setting
          is normally _80_ in order to prevent very long lines from being
          sent in outgoing mail. When the mail is actually sent, trailing
          spaces will be stripped off of each line.
   _current-indexline-style_
          current-indexline-style.
   _customized-hdrs_
          You may add your own custom headers to outgoing messages. Each
          header you specify here must include the header tag (Reply-To:,
          Approved:, etc.) and may optionally include a value for that
          header. If you want to see these custom headers each time you
          compose a message, you must add them to your
          default-composer-hdrs list, otherwise they become part of the
          rich header set which you only see when you press the rich
          header command. (If you are looking for a way to change which
          headers are _displayed_ when you view a message, take a look at
          the viewer-hdrs option instead.) Here's an example which shows
          how you might set your From address

                     From: Full Name <user@example.com>
          and another showing how you might set a Reply-To address

                         Reply-To: user@example.com
          You may also set non-standard header values here. For example,
          you could add

                     Organization: My Organization Name
          or even

                     X-Favorite-Colors: Purple and Gold
          If you include a value after the colon then that header will be
          included in your outgoing messages unless you delete it before
          sending. If a header in the Customized-Headers list has only a
          tag but no value, then it will not be included in outgoing
          messages unless you edit a value in manually. For example, if

                                  Reply-To:
          is in the list, then the Reply-To header will be available for
          editing but won't be included unless a value is added while in
          the composer.
          It's actually a little more complicated than that. The values of
          headers that you set with the Customized-Headers option are
          defaults. If the message you are about to compose already has a
          value for a header, that value is used instead of a value from
          your Customized-Headers. For example, if you are Replying to a
          message the Subject field will already be filled in. In that
          case, if the Customized-Headers list contains a Subject line,
          the custom subject will _NOT_ be used. The subject derived from
          the subject of the message you are Replying to will be used
          instead.
          It is also possible to make header setting even more complicated
          and more automatic by using Roles, but if all you want to do is
          set a default value for a header, you don't need to think about
          Roles.
          If you change your From address you may also find it useful to
          add the changed From address to the alt-addresses configuration
          option.
          Limitation: Because commas are used to separate the list of
          Customized-Headers, it is not possible to have the value of a
          header contain a comma. Nor is there currently an "escape"
          mechanism provided to make this work.
          This option is displayed as "Customized Headers".
   _dead-letter-files_
          This option affects _Alpine_'s behavior when you cancel a
          message being composed. _Alpine_'s usual behavior is to write
          the canceled message to a file named "dead.letter" in your home
          directory, or "DEADLETR" when using _PC-Alpine_, overwriting any
          previous message.
          If you set this option to a value higher than one, then that
          many copies of dead letter files will be saved. For example, if
          you set this option to "3" then you may have files named
          "DEADLETR", "DEADLETR2", and "DEADLETR3"; or "dead.letter",
          "dead.letter2", and "dead.letter3". In this example, the most
          recently cancelled message will be in "dead.letter", and the
          third most recently cancelled message will be in "dead.letter3".
          The fourth most recently cancelled message will no longer be
          saved.
          If you set this option to zero, then NO record of canceled
          messages is maintained.
          If the feature Quell-Dead-Letter-On-Cancel is set, that
          overrides whatever you set for this option. If this option had
          existed at the time, then the Quell feature would not have been
          added, but it is still there for backwards compatibility. So, in
          order for this option to have the desired effect, make sure the
          Quell feature is turned off.
   _default-composer-hdrs_
          You can control which headers you want visible when composing
          outgoing email using this option. You can specify any of the
          regular set, any Rich Header, or any Customized-Hdrs which you
          have already defined. If you use this setting at all, you must
          specify all the headers you want to see, you can't just add to
          the regular header set. The default set is To:, Cc:, Attchmnt:,
          and Subject:.
          Note that the "Newsgroups:" header will be abbreviated in the
          Composer display, but should be spelled out in full here.
          This option is displayed as "Default Composer Headers".
   _default-fcc_
          The name of the folder to which all outgoing mail goes is set
          here. The compiled-in default is _sent-mail_ (UNIX) or _sentmail_
          (PC). It can be set to "" (two double quotes with nothing
          between them) to turn off saving copies of outgoing mail. If
          _default-fcc_ is a relative file name, then it is relative to
          your default collection for saves (see folder-collections).
          This option is displayed as "Default Fcc (File carbon copy)".
   _default-saved-msg-folder_
          This option determines the default folder name for _Saves_... If
          this is not a path name, it will be in the default collection
          for saves. Any valid folder specification, local or IMAP, is
          allowed. This default folder only applies when the
          saved-msg-name-rule doesn't override it. Unix _Alpine_ default
          is normally _saved-messages_ in the default folder collection.
          _PC-Alpine_ default is _SAVEMAIL_ (normally stored as
          _SAVEMAIL.MTX_).
          This option is displayed as "Default Saved Message Folder".
   _disable-these-authenticators_
          This variable is a list of SASL (Simple Authentication and
          Security Layer) authenticators which will be disabled. SASL is a
          mechanism for authenticating to IMAP, POP3, SMTP, and other
          network servers.
          _Alpine_ matches its list of supported authenticators with the
          server to determine the most secure authenticator that is
          supported by both. If no matching authenticators are found,
          _Alpine_ will revert to plaintext login (or, in the case of SMTP,
          will be unable to authenticate at all).
          The candidates for disabling are listed below. There may be more
          if you compile _Alpine_ with additional authenticators and/or a
          newer version of the c-client library.
          + GSSAPI
          + CRAM-MD5
          + PLAIN
          + LOGIN
          Normally, you will not disable any authenticators. There are two
          exceptions:
         1. You use a broken server that advertises an authenticator, but
            does not actually implement it.
         2. You have a Kerberos-capable version of _Alpine_ and the server
            is also Kerberos-capable, but you can not obtain Kerberos
            credentials on the server machine, thus you desire to disable
            GSSAPI (which in turn disables _Alpine_'s Kerberos support).
          It is never necessary to disable authenticators, since _Alpine_
          will try other authenticators before giving up. However,
          disabling the relevant authenticator avoids annoying error
          messages.
   _disable-these-drivers_
          This variable is a list of mail drivers which will be disabled.
          The candidates for disabling are listed below. There may be more
          in the future if you compile _Alpine_ with a newer version of
          the c-client library.
          + mbox
          + mbx
          + mh
          + mix
          + mmdf
          + mtx
          + mx
          + news
          + phile
          + tenex
          + unix
          The _mbox_ driver enables the following behavior: if there is a
          file called mbox in your home directory, and if that file is
          either empty or in Unix mailbox format, then every time you open
          _INBOX_ the _mbox_ driver will automatically transfer mail from
          the system mail spool directory into the mbox file and delete it
          from the spool directory. If you disable the _mbox_ driver, this
          will not happen.
          It is not recommended to disable the driver which supports the
          system default mailbox format. On most non-SCO systems, that
          driver is the _unix_ driver. On most SCO systems, it is the
          _mmdf_ driver. The system default driver may be configured to
          something else on your system; check with your system manager
          for additional information.
          It is most likely not very useful for you to disable any of the
          drivers other than possibly _mbox_. You could disable some of
          the others if you know for certain that you don't need them but
          the performance gain in doing so is very modest.
   _display-character-set_
          See the discussion in International Character Sets for details.
   _display-filters_
          This option defines a list of text-filtering commands (programs
          or scripts) that may be used to filter text portions of received
          messages prior to their use (e.g., presentation in the "Message
          Text" display screen). For security reasons, the full path name
          of the filter command must be specified.
          Display filters do not work with _PC-Alpine_.
          The command is executed and the message is piped into its
          standard input. The standard output of the command is read back
          by _Alpine_. The __TMPFILE__ token (see below) overrides this
          default behavior.
          The filter's use is based on the configured _trigger_ string.
          The format of a filter definition is:

                       <trigger> <command> <arguments>
          You can specify as many filters as you wish, separating them
          with a comma. Each filter can have only one trigger and command.
          Thus, two trigger strings which invoke the same command require
          separate filter specifications.
          The _trigger_ is simply text that, if found in the message, will
          invoke the associated command. If the trigger contains any space
          characters, it must be placed within quotes. Likewise, should
          you wish a filter to be invoked unconditionally, define the
          trigger as the null string, "" (two consecutive double-quote
          characters). If the trigger string is found anywhere in the text
          of the message the filter is invoked. Placing the trigger text
          within the tokens defined below changes where within the text
          the trigger must be before considering it a match.
          Trigger Modifying Tokens:

        __CHARSET(string)__
                This token tells _Alpine_ to invoke the supplied command
                if the text is in a character set matching string (e.g.,
                ISO-8859-2 or ISO-2022-JP).

        __LEADING(string)__
                This token tells _Alpine_ to invoke the supplied command
                if the enclosed string is found to be the first
                non-whitespace text.
                NOTE: Quotes are necessary if string contains the space
                character.

        __BEGINNING(string)__
                This token tells _Alpine_ to invoke the supplied command
                if the enclosed string is found at the beginning of any
                line in the text.
                NOTE: Quotes are necessary if string contains the space
                character.

          The "command" and "arguments" portion is simply the command line
          to be invoked if the trigger string is found. Below are tokens
          that _Alpine_ will recognize and replace with special values
          when the command is actually invoked.
          Command Modifying Tokens:

        __TMPFILE__
                When the command is executed, this token is replaced with
                the path and name of the temporary file containing the
                text to be filtered. _Alpine_ expects the filter to
                replace this data with the filter's result. NOTE: Use of
                this token implies that the text to be filtered is not
                piped into standard input of the executed command and its
                standard output is ignored. _Alpine_ restores the tty
                modes before invoking the filter in case the filter
                interacts with the user via its own standard input and
                output.

        __RESULTFILE__
                When the command is executed, this token is replaced with
                the path and name of a temporary file intended to contain
                a status message from the filter. _Alpine_ displays this
                in the message status field.

        __DATAFILE__
                When the command is executed, this token is replaced with
                the path and name of a temporary file that _Alpine_
                creates once per session and deletes upon exit. The file
                is intended to be used by the filter to store state
                information between instances of the filter.

        __PREPENDKEY__
                When the command is executed, this token indicates that a
                random number will be passed down the input stream before
                the message text. This number could be used as a session
                key. It does not appear as a command-line argument. It is
                sent in this way to improve security. The number is unique
                to the current _Alpine_ session and is only generated once
                per session.

          The feature disable-terminal-reset-for-display-filters is
          related.
          Performance caveat/considerations:
          Testing for the trigger and invoking the filter doesn't come for
          free. There is overhead associated with searching for the
          trigger string, testing for the filter's existence and actually
          piping the text through the filter. The impact can be reduced if
          the Trigger Modifying Tokens above are employed.
          Limitation:
          If Header Colors are being used, the sequences of bytes which
          indicate color changes will be contained in the text which is
          passed to the display-filter. If this causes problems you'll
          need to turn off Header Colors. The thirteen bytes which
          indicate a color change are the character \377 followed by \010
          for a foreground color or \011 for a background color. Then
          comes eleven characters of RGB data which looks something like
          255,  0,255, depending on the particular color, of course.
   _download-command_
          This option affects the behavior of the _Export_ command. It
          specifies a Unix program name, and any necessary command line
          arguments, that _Alpine_ can use to transfer the exported
          message to your personal computer's disk.
   _download-command-prefix_
          This option is used in conjunction with the _download-command_
          option. It defines text to be written to the terminal emulator
          (via standard output) immediately prior to starting the download
          command. This is useful for integrated serial line file transfer
          agents that permit command passing (e.g., Kermit's APC method).
   _editor_
          UNIX _Alpine_ only. Sets the name of the alternate editor for
          composing mail (message text only, not headers). It will be
          invoked with the "^_" command or it will be invoked
          automatically if the enable-alternate-editor-implicitly feature
          is set.
   _empty-header-message_
          When sending, if both the To and Cc fields are empty and you are
          sending the message to a Bcc, _Alpine_ will put a special
          address in the To line. The default value is
          "undisclosed-recipients: ;". The reason for this is to avoid
          embarrassment caused by some Internet mail transfer software
          that interprets a "missing" To: header as an error and replaces
          it with an Apparently-to: header that may contain the addresses
          you entered on the Bcc: line, defeating the purpose of the Bcc.
          You may change the part of this message that comes before the ":
          ;" by setting the _empty-header-message_ variable to something
          else.
   _fcc-name-rule_
          Determines default folder name for fcc when composing.
          Currently, _Alpine_ will accept the values _default-fcc_,
          _by-recipient_, or _last-fcc-used_. If set to _default-fcc_, then
          _Alpine_ will use the value defined in the default-fcc variable
          (which itself has a default) for the Fcc header field. If set to
          _by-recipient_, then _Alpine_ will use the name of the recipient
          as a folder name for the fcc. The relevant recipient is the
          first address in the To field. If set to "last-fcc-used", then
          _Alpine_ will offer to Fcc to whatever folder you used
          previously. In all cases, the field can still be edited after it
          is initially assigned. If the fcc field in the address book is
          set for the first To address, that value over-rides any value
          derived from this rule.
   _feature-list_
          This is a list of the many features (options) which may be
          turned on or off. There is a separate section titled
          Configuration Features which explains each of the features.
          There is some additional explanation about the _feature-list_
          variable itself in Feature List Variable.
   _file-directory_
          _PC-Alpine_ only. This value affects the Composer's "^J Attach"
          command, the Attachment Index Screen's "S Save" command, and the
          Message Index's "E Export" command.
          Normally, when a filename is supplied that lacks a leading
          "path" component, _Alpine_ assumes the file exists in the user's
          home directory. Under Windows operating systems, this definition
          isn't always clear. This feature allows you to explicitly set
          where _Alpine_ should look for files without a leading path.
          NOTE: this feature's value is ignored if either use-current-dir
          feature is set or the PINERC has a value for the operating-dir
          variable.
   _folder-collections_
          This is a list of one or more collections where saved mail is
          stored. See the sections describing folder collections and
          collection syntax for more information. The first collection in
          this list is the default collection for _Save_s, including
          default-fcc's.
   _folder-extension_
          _PC-Alpine_ only. File extension used for local folder names.
          This is .MTX by default.
   _folder-reopen-rule_
          _Alpine_ normally checks for new mail in the currently open
          folder and in the INBOX every few minutes.
          There are some situations where automatic new-mail checking does
          not work. For example, if a mail folder is opened using the POP
          protocol or a newsgroup is being read using the NNTP protocol,
          then new-mail checking is disabled.
          It may be possible to check for new mail in these cases by
          reopening the folder. _Alpine_ does not do this for you
          automatically, but you may do the commands manually to cause
          this to happen. You reopen by going back to the folder list
          screen from the message index screen with the "<" command, and
          then going back into the message index screen with the ">"
          command. (Actually, any method you would normally use to open a
          folder will work the same as the "<" followed by ">" method. For
          example, the GoTo Folder command will work, or you may use L to
          go to the Folder List screen and Carriage Return to reopen the
          folder.)
          There are some cases where _Alpine_ knows that reopening the
          folder should be useful as a way to discover new mail. At the
          time of this writing, connections made using the POP protocol,
          news reading using the NNTP protocol, local news reading, and
          local ReadOnly folders which are in the traditional UNIX or the
          MMDF format all fall into this category. There are other cases
          where it _may_ be a way to discover new mail, but _Alpine_ has
          no way of knowing, so it might also just be an exercise in
          futility. All remote, ReadOnly folders other than those listed
          just above fall into this category. The setting of this option
          together with the type of folder controls how _Alpine_ will
          react to the apparent attempt to reopen a folder.
          If you don't reopen, then you will just be back in the message
          index with no change. You left the index and came back, but the
          folder remained "open" the whole time. However, if you do reopen
          the folder, the folder is closed and then reopened. In this
          case, the current state of the open folder is lost. The New
          status, Important and Answered flags, selected state, Zoom
          state, collapsed or expanded state of threads, current message
          number, and any other temporary state is all lost when the
          reopen happens. For POP folders (but not NNTP newsgroups) the
          Deleted flags are also lost.
          In the possibilities listed below, the text says "POP/NNTP" in
          several places. That really implies the case where _Alpine_
          knows it is a good way to discover new mail, which is more than
          just POP and NNTP, but POP and NNTP are the cases of most
          interest. This option probably has more possible values than it
          deserves. They are:

        Always reopen
                _Alpine_ will not ask whether you want to reopen but will
                just do the reopen whenever you type a command that
                implies a reopen, regardless of the access method. In
                other words, it is assumed you would always answer Yes if
                asked about reopening.

        Yes for POP/NNTP, Ask about other remote [Yes]
                _Alpine_ will assume a Yes answer if the access method is
                POP or NNTP, but will ask you whether to reopen other
                remote folders, with a default answer of Yes.

        Yes for POP/NNTP, Ask about other remote [No]
                _Alpine_ will assume a Yes answer if the access method is
                POP or NNTP, but will ask you whether to reopen other
                remote folders, with a default answer of No.

        Yes for POP/NNTP, No for other remote
                _Alpine_ will assume a Yes answer if the access method is
                POP or NNTP, and will assume a No answer for all other
                remote folders.

        Always ask [Yes]
                _Alpine_ will not differentiate based on access method. It
                will always ask for all remote folders, with a default
                answer of Yes.

        Always ask [No]
                _Alpine_ will not differentiate based on access method. It
                will always ask for all remote folders, with a default
                answer of No.

        Ask about POP/NNTP [Yes], No for other remote
                _Alpine_ will ask if the access method is POP or NNTP,
                with a default answer of Yes. It will never attempt to
                reopen other remote folders.

        Ask about POP/NNTP [No], No for other remote
                This is the default. _Alpine_ will ask if the access
                method is POP or NNTP, with a default answer of No. It
                will never attempt to reopen other remote folders.

        Never reopen
                _Alpine_ will never attempt to reopen already open
                folders.

          Remember, wherever it says POP or NNTP above it really means POP
          or NNTP or any of the other situations where it is likely that
          reopening is a good way to discover new mail.
          There is an alternative that may be of useful in some
          situations. Instead of manually checking for new mail you can
          set up a Mail Drop and automatically check for new mail.
   _folder-sort-rule_
          This option controls the order in which folder list entries will
          be presented in the FOLDER LIST screen. Choose one of the
          following:

        _Alphabetical_
                sort by alphabetical name independent of type

        _Alpha-with-dirs-last_
                sort by alphabetical name grouping directory entries to
                the end of the list

        _Alpha-with-dirs-first_
                sort by alphabetical name grouping directory entries to
                the start of the list

          The normal default is _Alphabetical_.
   _font-name_
          Winsock version of _PC-Alpine_ only.
   _font-size_
          Winsock version of _PC-Alpine_ only.
   _font-style_
          Winsock version of _PC-Alpine_ only.
   _forced-abook-entry_
          System-wide _Alpine_ configuration files only. Force these
          address book entries into all writable personal address books.
          This is a list variable. Each item in the list has the form:

     Nickname | Fullname | Address
          with optional whitespace in all the obvious places.
   _form-letter-folder_
          A Form Letter Folder is a mail folder that is intended to
          contain messages that you have composed and that are intended to
          be sent in their original form repeatedly.
          Setting this variable will alter _Alpine_'s usual behavior when
          you execute the Compose command. Normally, _Alpine_ offers a
          chance to continue a postponed or interrupted message should one
          or the other exist. When this variable is set to a folder name
          that exists, _Alpine_ will also offer the chance to select a
          message from the folder to insert into the composer, much like
          when continuing a postponed message. The difference, however, is
          that _Alpine_ will not automatically delete the selected message
          from the Form Letter Folder.
          Setting this variable will also affect _Alpine_'s behavior when
          you Postpone a message from the composer. Normally, _Alpine_
          simply stashes the message away in your Postponed-Folder.
          Regardless of the specified folder's existence, _Alpine_ will
          ask which folder you intend the message to be stored in. Choose
          the "F" option to store the message in your Form Letter Folder.
          This is the most common way to add a message to the folder.
          Another method of adding messages to the folder is via the
          _Alpine_ composer's Fcc: field. If you are sending a message that
          you expect to send in the same form again, you can enter the
          Form Letter Folder's name in this field. _Alpine_, as usual,
          will copy the message as it's sent. Note, when you later select
          this message from your Form Letter Folder, it will have the same
          recipients as the original message.
          To delete a message from the Form Letter Folder, you can either
          select the folder from a suitable FOLDER LIST screen, or use the
          Delete command in the MESSAGE INDEX offered when selecting from
          the folder as part of the Compose command. You can delete a Form
          Letter Folder just as any other folder from a suitable FOLDER
          LIST screen.
          You may find that the Roles facility can be used to replace the
          Form Letter Folder.
   _global-address-book_
          A list of shared address books. Each entry in the list is an
          optional nickname followed by a pathname or file name relative
          to the home directory. A SPACE character separates the nickname
          from the rest of the line. Instead of a local pathname or file
          name, a remote folder name can be given. This causes the address
          book to be a Remote address book. Remote folder syntax is
          discussed in Syntax for Remote Folders. This list will be added
          to the address-book list to arrive at the complete set of
          address books. Global address books are defined to be ReadOnly.
   _goto-default-rule_
          This value affects _Alpine_'s behavior when using the _Goto_
          command. There are five possible values for this option:

        _folder-in-first-collection_
                _Alpine_ will offer the most recently visited folder in
                the default collection found in the "Collection List"
                screen as the default.

        _inbox-or-folder-in-first-collection_
                If the current folder is _INBOX_, _Alpine_ will offer the
                most recently visited folder in the default collection
                found in the "Collection List" screen. If the current
                folder is other than _INBOX_, _INBOX_ is offered as the
                default.

        _inbox-or-folder-in-recent-collection_
                This is _Alpine_'s default behavior. If the current folder
                is _INBOX_, _Alpine_ will offer the last open folder as
                the default. If the current folder is other than _INBOX_,
                _INBOX_ is offered as the default.

        _first-collection-with-inbox-default_
                Instead of offering the most recently visited folder in
                the default collection, the default collection is offered
                but with _INBOX_ as the default folder. If you type in a
                folder name it will be in the default collection. If you
                simply accept the default, however, your _INBOX_ will be
                opened.

        _most-recent-folder_
                The last accepted value simply causes the most recently
                opened folder to be offered as the default regardless of
                the currently opened folder.

          NOTE: The default while a newsgroup is open remains the same;
          the last open newsgroup.
   _header-general-background-color_
   _header-general-foreground-color_
          Header Colors.
   _image-viewer_
          This variable names the program to call for displaying parts of
          a MIME message that are of type IMAGE. If your system supports
          the _mailcap_ system, you don't need to set this variable.
   _inbox-path_
          This specifies the name of the folder to use for the _INBOX_. By
          default this is unset and the system's default is used. The most
          common reason for setting this is to open an IMAP mailbox for
          the _INBOX_. For example, _{imap5.u.example.edu}inbox_ will open
          the user's standard _INBOX_ on the mail server, _imap5_.
   _incoming-archive-folders_
          This is like read-message-folder, only more general. This is a
          list of folder pairs, with the first separated from the second
          in the pair by a space. The first folder in a pair is the folder
          you want to archive, and the second folder is the folder that
          read messages from the first should be moved to. Depending on
          how you define the auto-move-read-msgs feature, you may or may
          not be asked when you leave the first folder if you want read
          messages to be moved to the second folder. In either case,
          moving the messages means they will be deleted from the first
          folder.
          If these are not path names, they will be in the default
          collection for _Save_s. Any valid folder specification, local or
          remote (via IMAP), is allowed. There is no default.
   _incoming-check-interval_
          This option has no effect unless the feature
          enable-incoming-folders-checking is set, which in turn has no
          effect unless incoming-folders is set.
          This option specifies, in seconds, how often _Alpine_ will check
          for new mail and state changes in Incoming Folders when Incoming
          Folders Checking is turned on. The default is 3 minutes (180).
          This value applies only to folders that are local to the system
          that _Alpine_ is running on or that are accessed using the IMAP
          protocol. The similar option incoming-check-interval-secondary
          applies to all other monitored folders.
   _incoming-check-interval-secondary_
          This option has no effect unless the feature
          enable-incoming-folders-checking is set, which in turn has no
          effect unless incoming-folders is set.
          This option together with the option incoming-check-interval
          specifies, in seconds, how often _Alpine_ will check for new
          mail and state changes in Incoming Folders when Incoming Folders
          Checking is turned on. The default for this option is 3 minutes
          (180). For folders that are local to this system or that are
          accessed using the IMAP protocol the value of the option
          incoming-check-interval is used. For all other monitored
          folders, the value of this option is used.
          The reason there are two separate options is because it is
          usually less expensive to check local and IMAP folders than it
          is to check other types, like POP or NNTP folders. You may want
          to set this secondary value to a higher number than the primary
          check interval.
   _incoming-check-list_
          This option has no effect unless the feature
          enable-incoming-folders-checking is set, which in turn has no
          effect unless incoming-folders is set.
          When monitoring the Incoming Message Folders for Unseen messages
          Alpine will normally monitor all Incoming Folders. You may use
          this option to restrict the list of monitored folders to a
          subset of all Incoming Folders.
   _incoming-check-timeout_
          This option has no effect unless the feature
          enable-incoming-folders-checking is set, which in turn has no
          effect unless incoming-folders is set.
          Sets the time in seconds that Alpine will attempt to open a
          network connection used for monitoring for Unseen messages in
          Incoming Folders. The default is 5. If a connection has not
          completed within this many seconds Alpine will give up and
          consider it a failed connection.
   _incoming-folders_
          This is a list of one or more folders other than _INBOX_ that
          may receive new messages. This list is slightly special in that
          it is always expanded in the folder lister. In the future, it
          may become more special. For example, it would be nice if
          _Alpine_ would monitor the folders in this list for new mail.
   _incoming-startup-rule_
          This rule affects _Alpine_'s behavior when opening the _INBOX_
          or another folder from the "INCOMING MESSAGE FOLDERS". This rule
          tells _Alpine_ which message to make the current message when an
          incoming folder is opened. There are seven possible values for
          this option:

        _first-unseen_
                The current message will be the first unseen message which
                has not been marked deleted, or the last message if all of
                the messages have been seen. This is the default setting.

        _first-recent_
                This is similar to _first-unseen_. Instead of first unseen
                it is the first recent message. A message is considered to
                be recent if it arrived since the last time the folder was
                open (by any mail client, not just the current one). So
                this option causes the current message to be set to the
                first undeleted-recent message, or the last message if
                none is both undeleted and recent.

        _first-important_
                This will result in the current message being set to the
                first message marked Important (but not Deleted). If no
                messages are marked Important, then it will be the last
                message.

        _first-important-or-unseen_
                This selects the minimum of the first unseen and the first
                important messages.

        _first-important-or-recent_
                This selects the first of the first recent and the first
                important messages.

        _first_
                Set the current message to the first undeleted message
                unless all are deleted. In that case set it to the last
                message.

        _last_
                Set the current message to the last undeleted message
                unless all are deleted. In that case set it to the last
                message.

   _incoming-unseen-background-color_
   _incoming-unseen-foreground-color_
          Incoming Unseen Color.
   _index-answered-background-color_
   _index-answered-foreground-color_
   _index-arrow-background-color_
   _index-arrow-foreground-color_
   _index-deleted-background-color_
   _index-deleted-foreground-color_
   _index-from-background-color_
   _index-from-foreground-color_
   _index-highpriority-background-color_
   _index-highpriority-foreground-color_
   _index-important-background-color_
   _index-important-foreground-color_
   _index-lowpriority-background-color_
   _index-lowpriority-foreground-color_
   _index-new-background-color_
   _index-new-foreground-color_
   _index-opening-background-color_
   _index-opening-foreground-color_
   _index-recent-background-color_
   _index-recent-foreground-color_
   _index-subject-background-color_
   _index-subject-foreground-color_
   _index-to-me-background-color_
   _index-to-me-foreground-color_
   _index-unseen-background-color_
   _index-unseen-foreground-color_
          Index Colors.
   _index-format_
          This option is used to customize the content of lines in the
          MESSAGE INDEX screen. Each line is intended to convey some
          amount of immediately relevant information about each message in
          the current folder.
          _Alpine_ provides a pre-defined set of informational fields with
          reasonable column widths automatically computed. You can,
          however, replace this default set by listing special tokens in
          the order you want them displayed.
          The list of available tokens is here.
          Spaces are used to separate listed tokens. Additionally, you can
          specify how much of the screen's width the taken's associated
          data should occupy on the index line by appending the token with
          a pair of parentheses enclosing either a number or percentage.
          For example, "SUBJECT(13)" means to allocate 13 characters of
          space to the subject column, and "SUBJECT(20%)" means to
          allocate 20% of the available space to the subjects column,
          while plain "SUBJECT" means the system will attempt to figure
          out a reasonable amount of space.
          There is always one space between every pair of columns, so if
          you use fixed column widths (like 13) you should remember to
          take that into account. Several of the fields are virtually
          fixed-width, so it doesn't make much sense to specify the width
          for them. The fields STATUS, FULLSTATUS, IMAPSTATUS, MSGNO, the
          DATE fields, SIZE, and DESCRIPSIZE all fall into that category.
          You _may_ specify widths for those if you wish, but you're
          probably better off letting the system pick those widths.
          The default is equivalent to:

   index-format=STATUS MSGNO SMARTDATETIME24 FROMORTO(33%) SIZENARROW SUBJ
                                  KEY(67%)
          This means that the four fields without percentages will be
          allocated first, and then 33% and 67% of the _remaining_ space
          will go to the from and subject fields. If one of those two
          fields is specified as a percentage and the other is left for
          the system to choose, then the percentage is taken as an
          absolute percentage of the screen, not of the space remaining
          after allocating the first four columns. It doesn't usually make
          sense to do it that way. If you leave off all the widths, then
          the subject and from fields (if both are present) are allocated
          space in a 2 to 1 ratio, which is almost exactly the same as the
          default.
          What you are most likely to do with this configuration option is
          to specify which fields appear at all, which order they appear
          in, and the percentage of screen that is used for the from and
          subject fields if you don't like the 2 to 1 default.
          If you want to retain the default format that _Pine_ 4.64 had,
          use

       Index-Format=STATUS MSGNO DATE FROMORTO(33%) SIZE SUBJKEY(67%)
          _and_ set the feature Disable-Index-Locale-Dates.
   _initial-keystroke-list_
          This is a comma-separated list of keystrokes which _Alpine_
          executes on startup. Items in the list are usually just
          characters, but there are some special values. _SPACE,_ _TAB,_
          and _CR_ mean a space character, tab character, and a carriage
          return, respectively. _F1_ through _F12_ stand for the twelve
          function keys. _UP, DOWN, LEFT, _and_ RIGHT _stand for the arrow
          keys. Control characters are represented with _^<char>_. A
          restriction is that you can't mix function keys and character
          keys in this list even though you can, in some cases, mix them
          when running _Alpine_. A user can always use only _character_
          keys in the startup list even if he or she is using _function_
          keys normally, or vice versa. If an element in this list is a
          string surrounded by double quotes (") then it will be expanded
          into the individual characters in the string, excluding the
          double quotes.
   _kblock-passwd-count_
          System-wide _Alpine_ configuration files only. Number of times a
          user will have to enter a password when they run the keyboard
          lock command in the main menu.
   _keyboard-character-set_
          See the discussion in International Character Sets for details.
   _keylabel-background-color_
   _keylabel-foreground-color_
          KeyLabel Color.
   _keyname-background-color_
   _keyname-foreground-color_
          KeyName Color.
   _keywords_
          You may define your own set of keywords and optionally set them
          on a message by message basis. These are similar to the
          "Important" flag which the user may set using the Flag command.
          The difference is that the Important flag is always present for
          each folder. User-defined keywords are chosen by the user. You
          may set up the list of possible keywords here, or you may add
          keywords from the Flag Details screen that you can get to after
          typing the Flag (*) command. After the keywords have been
          defined, then you use the Flag command to set or clear the
          keywords in each message. The behavior of the flag command may
          be modified by using the Enable-Flag-Screen-Implicitly option or
          the Enable-Flag-Screen-Keyword-Shortcut option.
          Keywords may be used when Selecting messages (Select Keyword).
          Keywords may also be used in the Patterns of Rules (Filters,
          Indexcolors, etc). Filter rules may be used to set keywords
          automatically. Keywords may be displayed as part of the Subject
          of a message by using the SUBJKEY or SUBJKEYINIT tokens in the
          Index-Format option. The Keyword-Surrounding-Chars option may be
          used to modify the display of keywords using SUBJKEY and
          SUBJKEYINIT slightly. Keywords may also be displayed in a column
          of their own in the MESSAGE INDEX screen by using the KEY or
          KEYINIT tokens. It is also possible to color keywords in the
          index using the Setup/Kolor screen (Keyword Colors). Keywords
          are not supported by all mail servers.
          You may give keywords nicknames if you wish. If the keyword
          definition you type in contains a SPACE character, then the
          actual value of the keyword is everything after the last SPACE
          and the nickname for that keyword is everything before the last
          SPACE. For example, suppose you are trying to interoperate with
          another email program which uses a particular keyword with an
          unpleasant name. Maybe it uses a keyword called

                         VendorName.SoftwareName.08
          but for you that keyword means that the message is work-related.
          You could define a keyword to have the value

                       Work VendorName.SoftwareName.08
          and then you would use the name "Work" when dealing with that
          keyword in _Alpine_. If you defined it as

                     My Work VendorName.SoftwareName.08
          the nickname would be everything before the last SPACE, that is
          the nickname would be "My Work".
          Some commonly used keywords begin with dollar signs. This
          presents a slight complication, because the dollar sign is
          normally used to signify environment variable expansion in the
          _Alpine_ configuration. In order to specify a keyword which
          begins with a dollar sign you must precede the dollar sign with
          a second dollar sign to escape its special meaning. For example,
          if you want to include the keyword

                                   $Label1
          as one of your possible keywords, you must enter the text

                                  $$Label1
          instead.
   _keyword-surrounding-chars_
          This option controls a minor aspect of _Alpine_'s MESSAGE INDEX
          and MESSAGE TEXT screens. If you have modified the Index-Format
          option so that either the "SUBJKEY" or "SUBJKEYINIT" tokens are
          used to display keywords or their initials along with the
          Subject; then this option may be used to modify the resulting
          display slightly. By default, the keywords or initials displayed
          for these tokens will be surrounded with curly braces ({ and })
          and a trailing space. For example, if keywords "Work" and "Now"
          are set for a message, the "SUBJKEY" token will normally look
          like

                          {Work Now} actual subject
          and the SUBJKEYINIT token would look like

                             {WN} actual subject
          The default character before the keywords is the left brace ({)
          and the default after the keywords is the right brace followed
          by a space (} ).
          This option allows you to change that. You should set it to two
          values separated by a space. The values may be quoted if they
          include space characters. So, for example, the default value
          could be specified explicitly by setting this option to

                     Keyword-Surrounding-Chars="{" "} "
          The first part wouldn't need to be quoted (but it doesn't hurt).
          The second part does need the quotes because it includes a space
          character. If you wanted to change the braces to brackets you
          could use

                     Keyword-Surrounding-Chars="[" "] "
          Inside the quotes you can use backslash quote to mean quote, so

                    Keyword-Surrounding-Chars="\"" "\" "
          would produce

                          "Work Now" actual subject
          It is also possible to color keywords in the index using the
          Setup/Kolor screen (Keyword Colors).
          It is not possible to change the fact that a space character is
          used to separate the keywords if more than one keyword is set
          for a message. It is also not possible to change the fact that
          there are no separators between the keyword initials if more
          than one keyword is set.
          This option is displayed as "Keyword Surrounding Characters".
   _last-time-prune-questioned_
          Personal configuration file only. This variable records the
          month the user was last asked if his or her _sent-mail_ folders
          should be pruned. The format is _yy.mm_. This is automatically
          updated by _Alpine_ when the the pruning is done or declined. If
          a user wanted to make _Alpine_ stop asking this question he or
          she could set this time to something far in the future. This may
          not be set in the system-wide configuration files. Note: The _yy_
          year is actually the number of years since 1900, so it will be
          equal to 101 in the year 2001.
   _last-version-used_
          Personal configuration file only. This is set automatically by
          _Alpine_. It is used to keep track of the last version of _Alpine_
          that was run by the user. Whenever the version number increases,
          a new version message is printed out. This may not be set in the
          system-wide configuration files.
   _ldap-servers_
          This is only available if _Alpine_ was linked with an LDAP
          library when it was compiled. This variable is normally managed
          by _Alpine_ though it can be set in the system-wide
          configuration files as well as the personal configuration. It is
          a list variable. Each item in the list contains quite a bit of
          extra information besides just the server name. To put this into
          a system-wide config file the easiest thing to do is to
          configure a personal _Alpine_ for the LDAP server then copy the
          configuration line into the system-wide config file. Each item
          in the list looks like:

     server_name[:port] "quoted stuff"
          The server_name is just a hostname and it is followed by an
          optional colon and port number. The default port is 389.
          Following the server name is a single SPACE character followed
          by a bunch of characters inside double quotes. The part inside
          the quotes is a set of _tag_ = _value_ pairs. Each tag is
          preceded by a slash (/) and followed by an equal sign. The value
          for that tag is the text up to the next slash. An example of
          some quoted stuff is:

     "/base=o=University of Washington, c=US/impl=0/.../nick=My Server"
          This would set the search base for this server to o=University
          of Washington, c=US, set the implicit bit to zero, and set the
          nickname for the server to My Server. All of the tags correspond
          directly to items in the Setup/Directory screen so experiment
          with that if you want to see what the possible tags and values
          are.
   _literal-signature_
          With this option your actual signature, as opposed to the name
          of a file containing your signature, is stored in the _Alpine_
          configuration file. If this is defined it takes precedence over
          the _signature-file_ option.
          This is simply a different way to store the signature data. The
          signature is stored inside your _Alpine_ configuration file
          instead of in a separate signature file. Tokens contained in the
          signature work the same way they do with the regular
          signature-file.
          The Setup/Signature command in _Alpine_'s Main Menu will edit
          the _literal-signature_ by default. However, if no
          _literal-signature_ is defined and the file named in the
          _signature-file_ option exists, then the latter will be used
          instead. Compose (Reply, Forward, ...) will default to using the
          _literal-signature_ if defined, otherwise it will use the
          contents of the file named in _signature-file_.
          The _Alpine_ composer is used to edit the literal-signature. The
          result of that edit is first converted to a C-style string
          before it is stored in the configuration file. In particular,
          the two character sequence \n (backslash followed by the
          character "n") will be used to signify a line-break in the
          signature. You don't have to enter the \n, but it will be
          visible in the SETUP CONFIGURATION window after you are done
          editing the signature.
   _mail-check-interval_
          This option specifies, in seconds, how often _Alpine_ will check
          for new mail. If set to zero, new-mail checking is disabled.
          (You can always manually force a new-mail check by typing ^L
          (Ctrl-L), which is also the command to refresh the screen, or by
          typing the Next command when the current message is the last
          message of the folder.) There is a minimum value for this
          option, normally 15 seconds. The default value is normally 150
          seconds. The higher you set this option, the easier it is on the
          server.
          There are some situations where automatic new-mail checking does
          not work. See the discussion about new-mail checking in
          folder-reopen-rule.
          The new-mail checking will not happen exactly at the frequency
          that you specify. For example, _Alpine_ may elect to defer a
          non-INBOX mail check if you are busy typing. Or, it may check
          more frequently than you have specified if that is thought to be
          necessary to keep the server from closing the connection to the
          folder due to inactivity. If _Alpine_ checks for new mail as a
          side effect of another command, it will reset the timer, so that
          new-mail checking may seem to happen irregularly instead of
          every X seconds like clockwork.
          If you are anxious to know about new mail as soon as possible,
          set the check interval low, and you'll know about the new mail
          by approximately that amount of time after it arrives. If you
          aren't so worried about knowing right away, set this option to a
          higher value. That will save the server some processing time and
          may save you some of the time you spend waiting for new-mail
          checks to happen if you are dealing with a slow server or slow
          network connection.
          If you suspect that new-mail checking is causing slow downs for
          you, you may want to look into the options
          Quell-Mailchecks-Composing-Except-Inbox,
          Quell-Mailchecks-Composing-Inbox and
          Mail-Check-Interval-Noncurrent, which refine when mail checking
          is done.
          If the mailbox being check uses a Mail Drop then there is a
          minimum time (maildrop-check-minimum) between new-mail checks.
          Because of this minimum you may notice that new mail does not
          appear promptly when you expect it. The reason for this is to
          protect the server from over-zealous opening and closing of the
          Mail Drop folder, since that is a costly operation.
          A side effect of disabling mail checking is that there will be
          situations in which the user's IMAP connection will be broken
          due to inactivity timers on the server. Another side effect is
          that the user-input-timeout option won't work.
   _mail-check-interval-noncurrent_
          This option is closely related to the Mail-Check-Interval
          option, as well as the Quell-Mailchecks-Composing-Except-Inbox
          and Quell-Mailchecks-Composing-Inbox options. If the
          "Mail-Check-Interval" option is set to zero, then automatic
          new-mail checking is disabled and this option will have no
          effect.
          Normally this option is set to zero, which means that the value
          used will be the same as the value for the
          "Mail-Check-Interval". If you set this option to a value
          different from zero (usually larger than the value for
          "Mail-Check-Interval") then that is the check interval that will
          be used for folders which are not the currently open folder or
          the INBOX. You may not even have any folders that are noncurrent
          and not the INBOX. If you do, it is likely that they are due to
          Stay-Open-Folders you have configured. This option also affects
          the rate of mail checking done on cached connections to folders
          you previously had open but are no longer actively using. You
          aren't expected to understand that last sentence, but if you are
          interested take a look at Max-Remote-Connections, and the
          related options.
   _mail-directory_
          This variable was more important in previous versions of
          _Alpine_. Now it is used only as the default for storing personal
          folders (and only if there are no folder-collections defined).
          The default value is _~/mail_ on UNIX and _${HOME}\MAIL_ on a
          PC.
   _mailcap-search-path_
          This variable is used to replace _Alpine_'s default mailcap file
          search path. It takes one or more file names (full paths must be
          specified) in which to look for mail capability data.
   _maildrop-check-minimum_
          New-mail checking for a Mail Drop is a little different from new
          mail checking for a regular folder. One of the differences is
          that the connection to the Mail Drop is not kept open and so the
          cost of checking (delay for you and additional load for the
          server) may be significant. Because of this additional cost we
          set a minimum time that must pass between checks. This minimum
          only applies to the automatic checking done by _Alpine_. If you
          force a check by typing ^L (Ctrl-L) or by typing the Next
          command when you are at the end of a folder index, then the
          check is done right away.
          This option specifies, in seconds, the _minimum_ time between
          Mail Drop new-mail checks. You may want to set this minimum high
          in order to avoid experiencing some of the delays associated
          with the checks. Note that the time between checks is still
          controlled by the regular Mail-Check-Interval option. When
          _Alpine_ is about to do an automatic check for new mail (because
          the Mail-Check-Interval has expired) then if the time since the
          last new-mail check of any open Mail Drops has been greater than
          the MailDrop-Check-Minimum, the Mail Drop is checked for new
          mail as well. Therefore, it is only useful to set this option to
          a value that is higher than the Mail-Check-Interval.
          If this option is set to zero, automatic Mail Drop new-mail
          checking is disabled. There is a minimum value, normally 60
          seconds. The default value is normally 60 seconds as well. This
          applies to the INBOX and to the currently open folder if that is
          different from the INBOX.
   _max-remote-connections_
          This option affects low-level behavior of _Alpine_. The default
          value for this option is _2_. If your INBOX is accessed using
          the IMAP protocol from an IMAP server, that connection is kept
          open throughout the duration of your _Alpine_ session,
          independent of the value of this option. The same is true of any
          Stay-Open-Folders you have defined. This option controls
          _Alpine_'s behavior when connecting to remote IMAP folders other
          than your INBOX or your Stay-Open-Folders. It specifies the
          maximum number of remote IMAP connections (other than those
          mentioned above) that _Alpine_ will use for accessing the rest
          of your folders. If you set this option to zero, you will turn
          off most remote connection re-use. It's difficult to understand
          exactly what this option does, and it is usually fine to leave
          it set to its default value. It is probably more likely that you
          will be interested in setting the Stay-Open-Folders option
          instead of changing the value of this option. A slightly longer
          explanation of what is going on with this option is given in the
          next paragraphs.
          There are some time costs involved in opening and closing remote
          IMAP folders, the main costs being the time you have to wait for
          the connection to the server and the time for the folder to
          open. Opening a folder may involve not only the time the server
          takes to do its processing but time that _Alpine_ uses to do
          filtering. These times can vary widely. They depend on how
          loaded the server is, how large the folder being opened is, and
          how you set up filtering, among other things. Once _Alpine_ has
          opened a connection to a particular folder, it will attempt to
          keep that connection open in case you use it again. In order to
          do this, _Alpine_ will attempt to use the Max-Remote-Connections
          (the value of this option) IMAP connections you have allotted
          for this purpose.
          For example, suppose the value of this option is set to "2". If
          your INBOX is accessed on a remote server using the IMAP
          protocol, that doesn't count as one of the remote connections
          but it is always kept open. If you then open another IMAP
          folder, that would be your first remote connection counted as
          one of the Max-Remote-Connections connections. If you open a
          third folder the second will be left open, in case you return to
          it. You won't be able to tell it has been left open. It will
          appear to be closed when you leave the folder but the connection
          will remain in the background. Now suppose you go back to the
          second folder (the first folder after the INBOX). A connection
          to that folder is still open so you won't have to wait for the
          startup time to open it. Meanwhile, the connection to the third
          folder will be left behind. Now, if you open a fourth folder,
          you will bump into the Max-Remote-Connections limit, because
          this will be the third folder other than INBOX and you have the
          option set to "2". The connection that is being used for the
          third folder will be re-used for this new fourth folder. If you
          go back to the third folder after this, it is no longer already
          connected when you get there. You'll still save some time since
          _Alpine_ will re-use the connection to the fourth folder and you
          have already logged in on that connection, but the folder will
          have to be re-opened from scratch.
          If a folder is large and the startup cost is dominated by the
          time it takes to open that folder or to run filters on it, then
          it will pay to make the value of this option large enough to
          keep it open. On the other hand, if you only revisit a handful
          of folders or if the folders are small, then it might make more
          sense to keep this number small so that the reconnect time (the
          time to start up a new connection and authenticate) is
          eliminated instead.
          You may also need to consider the impact on the server. On the
          surface, a larger number here may cause a larger impact on the
          server, since you will have more connections open to the server.
          On the other hand, not only will _you_ be avoiding the startup
          costs associated with reopening a folder, but the _server_ will
          be avoiding those costs as well.
          When twenty five minutes pass without any active use of an IMAP
          connection being saved for possible re-use, that connection will
          be shut down,
          This option is displayed as "Maximum Remote Connections".
   _meta-message-background-color_
   _meta-message-foreground-color_
          Meta-message Color.
   _mimetype-search-path_
          This variable is used to replace _Alpine_'s default mime.types
          file search path. It takes one or more file names (full paths
          must be specified) in which to look for file-name-extension to
          MIME type mapping data. See the Config Notes for details on
          _Alpine_'s usage of the MIME.Types File.
   _new-version-threshold_
          When a new version of _Alpine_ is run for the first time it
          offers a special explanatory screen to the user upon startup.
          This option helps control when and if that special screen
          appears for users that have previously run _Alpine_. It takes as
          its value a _Alpine_ version number. _Alpine_ versions less than
          the specified value will suppress this special screen while
          versions equal to or greater than that specified will behave
          normally.
   _newmail-fifo-path_
          This option is only available in UNIX _Alpine_. However, there
          is a very similar feature built in to _PC-Alpine_. In
          _PC-Alpine_'s Config menu at the top of the screen is an option
          called "New Mail Window".
          You may have _Alpine_ create a FIFO special file (also called a
          named pipe, see mkfifo(3) and fifo(4)) where it will send a
          one-line message each time a new message is received in the
          current folder, the INBOX, or any open Stay-Open-Folders. To
          protect against two different _Alpine_s both writing to the same
          FIFO, _Alpine_ will only create the FIFO and write to it if it
          doesn't already exist.
          A possible way to use this option would be to have a separate
          window on your screen running the command

                                cat filename
          where "filename" is the name of the file given for this option.
          Because the file won't exist until after you start _Alpine_, you
          must _first_ start _Alpine_ and _then_ run the "cat" command.
          You may be tempted to use "tail -f filename" to view the new
          mail log. However, the common implementations of the tail
          command will not do what you are hoping.
          The width of the messages produced for the FIFO may be altered
          with the NewMail-Window-Width option.
          On some systems, fifos may only be created in a local
          filesystem. In other words, they may not be in NFS filesystems.
          This requirement is not universal. If the system you are using
          supports it, it should work. (It is often the case that your
          home directory is in an NFS filesystem. If that is the case, you
          might try using a file in the "/tmp" filesystem, which is
          usually a local filesystem.) Even when it is possible to use an
          NFS-mounted filesystem as a place to name the fifo (for example,
          your home directory), it will still be the case that the reader
          (probably the "cat" command) and the writer (_Alpine_) of the
          fifo must be running on the same system.
   _newmail-window-width_
          UNIX _Alpine_ only.
          This option is only useful if you have turned on the
          NewMail-FIFO-Path option. That option causes new mail messages
          to be sent to a fifo file. Those messages will be 80 characters
          wide by default. You can change the width of the messages by
          changing this option. For example, if you are reading those
          messages in another window you might want to set this width to
          the width of that other window.
          For UNIX _Alpine_, this option is only useful if you have turned
          on the NewMail-FIFO-Path option. That option causes new mail
          messages to be sent to a fifo file. Those messages will be 80
          characters wide by default. You can change the width of those
          messages by changing this option. For example, if you are
          reading those messages in another window you might want to set
          this width to the width of that other window.
          If you are using _PC-Alpine_, it has an option in the Config
          menu to turn on the "New Mail Window". The present option also
          controls the width of that window.
   _news-active-file-path_
          This option tells _Alpine_ where to look for the "active file"
          for newsgroups when accessing news locally, rather than via
          NNTP. The default path is usually /usr/lib/news/active.
   _news-collections_
          This is a list of collections where news folders are located.
          See the section describing collections for more information.
   _news-spool-directory_
          This option tells _Alpine_ where to look for the "news spool"
          for newsgroups when accessing news locally, rather than via
          NNTP. The default path is usually /usr/spool/news.
   _newsrc-path_
          This option overrides the default name _Alpine_ uses for your
          "newsrc" news status and subscription file. If set, _Alpine_
          will take this value as the full pathname for the desired newsrc
          file.
   _nntp-range_
          This option applies only to newsgroups accessed using the NNTP
          protocol. It does not, for example, apply to newsgroups accessed
          using an IMAP-to-NNTP proxy.
          When you open a connection to a News server using the NNTP
          protocol, you normally have access to all of the articles in
          each newsgroup. If a server keeps a large backlog of messages it
          may speed performance some to restrict attention to only the
          newer messages in a group. This option allows you to set how
          many article numbers should be checked when opening a newsgroup.
          You can think of "nntp-range" as specifying the maximum number
          of messages you ever want to see. For example, if you only ever
          wanted to look at the last 500 messages in each newsgroup you
          could set this option to 500. In actuality, it isn't quite that.
          Instead, for performance reasons, it specifies the range of
          article numbers to be checked, beginning with the highest
          numbered article and going backwards from there. If there are
          messages that have been canceled or deleted their article
          numbers are still counted as part of the range.
          So, more precisely, setting the "nntp-range" will cause article
          numbers

      last_article_number - nntp-range + 1 through last_article_number
          to be considered when reading a newsgroup. The number of
          messages that show up in your index will be less than or equal
          to the value of "nntp-range".
          The purpose of this option is simply to speed up access when
          reading news. The speedup comes because _Alpine_ can ignore all
          but the last nntp-range article numbers, and can avoid
          downloading any information about the ignored articles. There is
          a cost you pay for this speedup. That cost is that there is no
          way for you to see those ignored articles. The articles that
          come before the range you specify are invisible to you and to
          _Alpine_, as if they did not exist at all. There is no way to see
          those messages using, for example, an unexclude command or
          something similar. The only way to see those articles is to set
          this option high enough (or set it to zero) and then to reopen
          the newsgroup.
          If this option is set to 0 (which is also the default), then the
          range is unlimited. This option applies globally to all NNTP
          servers and to all newsgroups on those servers. There is no way
          to set different values for different newsgroups or servers.
   _nntp-server_
          One or more NNTP servers (host name or IP address) which _Alpine_
          will use for reading and posting news. If you read and post news
          to and from a single NNTP server, you can get away with only
          setting the _nntp-server_ variable and leaving the
          _news-collections_ variable unset.
          When you define an NNTP server, _Alpine_ implicitly defines a
          news collection for you, assuming that server as the news server
          and assuming that you will use the NNTP protocol and a local
          newsrc configuration file for reading news. See also Configuring
          News.
          Your NNTP server may offer NNTP "AUTHINFO SASL" or "AUTHINFO
          USER" authentication. It may even require it. If your NNTP
          server does offer such authentication you may specify a user
          name parameter to cause _Alpine_ to attempt to authenticate. The
          same is true for the server name in a folder collection which
          uses NNTP. This parameter requires an associated value, the
          username identifier with which to establish the server
          connection. An example might be:

                      nntpserver.example.com/user=katie
          If authentication is offered by the server, this will cause
          _Alpine_ to attempt to use it. If authentication is not offered
          by the server, this will cause _Alpine_ to fail with an error
          similar to:

                  Error: NNTP authentication not available
          For more details about the server name possibilities see Server
          Name Syntax.
   _normal-background-color_
   _normal-foreground-color_
          Normal Color.
   _opening-text-separator-chars_
          This option controls a minor aspect of _Alpine_'s MESSAGE INDEX
          screen. With some setups the text of the subject is followed by
          the opening text of the message if there is any room available
          in the index line. If you have configured your Index-Format
          option to include one of the Subject tokens which causes this
          behavior (SUBJECTTEXT, SUBJKEYTEXT, or SUBJKEYINITTEXT), then
          this option may be used to modify what is displayed slightly. By
          default, the Subject is separated from the opening text of the
          message by the three characters space dash space;

                                    " - "
          Use this option to set it to something different. The value must
          be quoted if it includes any space characters. For example, the
          default value could be specified explicitly by setting this
          option to

                     Opening-Text-Separator-Chars=" - "
          This option is displayed as "Opening Text Separator Characters".
   _operating-dir_
          System-wide _Alpine_ configuration files only. This names the
          root of the tree to which the user is restricted when reading
          and writing folders and files. It is usually used in the _fixed_
          configuration file.
   _patterns-filters2_
          Matching patterns and their corresponding actions are stored in
          this variable. These patterns are used with Filtering. This
          variable is normally maintained through the Setup/Rules/Filters
          configuration screen. It is a list variable. Each member of the
          list is a single pattern/action pair, or it can be a file which
          contains zero or more lines of pattern/action pairs. The only
          way to create a filters file is to use the InsertFile command in
          the Setup/Rules/Filters screen with a filename which doesn't yet
          exist. Then use the Shuffle command to move existing filter
          patterns into the file. This isn't very convenient but it isn't
          thought that many users will need this functionality. The
          purpose of filter files is for sharing filters.
          This option is displayed as "Patterns Filters".
   _patterns-indexcolors_
          Matching patterns and their corresponding actions are stored in
          this variable. These patterns are used for Index Line Colors.
          This variable is normally maintained through the
          Setup/Rules/Indexcolor configuration screen. It is a list
          variable. Each member of the list is a single pattern/action
          pair, or it can be a file which contains zero or more lines of
          pattern/action pairs. The only way to create a indexcolor file
          is to use the InsertFile command in the Setup/Rules/Indexcolor
          screen with a filename which doesn't yet exist. Then use the
          Shuffle command to move existing patterns into the file. This
          isn't very convenient but it isn't thought that many users will
          need this functionality. The purpose of indexcolor files is for
          sharing indexcolors.
   _patterns-other_
          Matching patterns and their corresponding actions are stored in
          this variable. These patterns are used with Miscellaneous Rules
          configuration. This variable is normally maintained through the
          Setup/Rules/Other configuration screen. It is a list variable.
          Each member of the list is a single pattern/action pair, or it
          can be a file which contains zero or more lines of
          pattern/action pairs. The only way to create a rules file is to
          use the InsertFile command in the Setup/Rules/Other screen with
          a filename which doesn't yet exist. Then use the Shuffle command
          to move existing rules into the file. This isn't very convenient
          but it isn't thought that many users will need this
          functionality.
   _patterns-roles_
          Matching patterns and their corresponding actions are stored in
          this variable. These patterns are used with Roles. This variable
          is normally maintained through the Setup/Rules/Roles
          configuration screen. It is a list variable. Each member of the
          list is a single pattern/action pair, or it can be a file which
          contains zero or more lines of pattern/action pairs. The only
          way to create a roles file is to use the InsertFile command in
          the Setup/Rules/Roles screen with a filename which doesn't yet
          exist. Then use the Shuffle command to move existing roles into
          the file. This isn't very convenient but it isn't thought that
          many users will need this functionality. The purpose of role
          files is for sharing roles.
   _patterns-scores2_
          Matching patterns and their corresponding actions are stored in
          this variable. These patterns are used with Scoring. This
          variable is normally maintained through the
          Setup/Rules/SetScores configuration screen. It is a list
          variable. Each member of the list is a single pattern/action
          pair, or it can be a file which contains zero or more lines of
          pattern/action pairs. The only way to create a scores file is to
          use the InsertFile command in the Setup/Rules/SetScores screen
          with a filename which doesn't yet exist. Then use the Shuffle
          command to move existing scoring patterns into the file. This
          isn't very convenient but it isn't thought that many users will
          need this functionality. The purpose of scoring files is for
          sharing scoring rules.
          This option is displayed as "Patterns Scores".
   _patterns-search_
          Matching patterns for use with the Select command are stored in
          this variable. These patterns are used with Search Rules
          configuration. This variable is normally maintained through the
          Setup/Rules/searCh configuration screen. It is a list variable.
          Each member of the list is a single pattern, or it can be a file
          which contains zero or more lines of patterns. The only way to
          create a rules file is to use the InsertFile command in the
          Setup/Rules/searCh screen with a filename which doesn't yet
          exist. Then use the Shuffle command to move existing rules into
          the file. This isn't very convenient but it isn't thought that
          many users will need this functionality.
   _personal-name_
          Personal configuration file only. User's full personal name. On
          UNIX systems, the default is taken from the accounts data base
          (/etc/passwd). The easiest way to change the full From address
          is with the customized-hdrs variable.
   _personal-print-category_
          Personal configuration file only. This is the category that the
          default print command belongs to. There are three categories.
          Category 1 is an attached printer which uses the ANSI escape
          sequence, category 2 is the standard system print command, and
          category 3 is the set of custom printer commands defined by the
          user. This just helps _Alpine_ figure out where to put the
          cursor when the user runs the _Setup/Printer_ command. This is
          not used by _PC-Alpine_.
   _personal-print-command_
          Personal configuration file only. This corresponds to the third
          category in the printer menu, the personally selected print
          commands. This variable contains the list of custom commands
          that the user has entered in the _Setup/Printer_ screen. This is
          not used by _PC-Alpine_.
   _posting-character-set_
          See the discussion in International Character Sets for details.
   _postponed-folder_
          The folder where postponed messages are stored. The default is
          _postponed-msgs_ (Unix) or _POSTPOND_ (PC).
   _print-font-name_
          Winsock version of _PC-Alpine_ only.
   _print-font-size_
          Winsock version of _PC-Alpine_ only.
   _print-font-style_
          Winsock version of _PC-Alpine_ only.
   _printer_
          Personal configuration file only. This is the current setting
          for a user's printer. This variable is set from _Alpine_'s
          _Setup/Printer_ screen.
   _prompt-background-color_
   _prompt-foreground-color_
          Prompt Color.
   _pruned-folders_
          This variable allows you to define a list of one or more folders
          that _Alpine_ will offer to prune for you in the same way it
          automatically offers to prune your "sent-mail" folder each
          month. Each folder in this list must be a folder in your default
          folder collection (the first folder collection if you have more
          than one), and it is just the relative name of the folder in the
          collection, not the fully-qualified name. It is similar to
          sent-mail. Instead of something like

                   pruned-folders={servername}mail/folder
          the correct value to use would be

                                   folder
          There is an assumption here that your first collection is the
          folders in

                              {servername}mail
          Once a month, for each folder listed, _Alpine_ will offer to
          move the contents of the folder to a new folder of the same name
          but with the previous month's date appended. _Alpine_ will then
          look for any such date-appended folder names created for a
          previous month, and offer each one it finds for deletion.
          If you decline the first offer, no mail is moved and no new
          folder is created.
          The new folders will be created in your default folder
          collection.
   _pruning-rule_
          By default, _Alpine_ will ask at the beginning of each month
          whether or not you want to rename your sent-mail folder to a
          name like sent-mail-month-year. (See the feature
          prune-uses-yyyy-mm to change the format of the folder to
          sent-mail-yyyy-mm.) It will also ask whether you would like to
          delete old sent-mail folders. If you have defined
          read-message-folder or pruned-folders _Alpine_ will also ask
          about pruning those folders. With this option you may provide an
          automatic answer to the rename questions and you may tell
          _Alpine_ to not ask about deleting old folders.
   _quote1-background-color_
   _quote1-foreground-color_
   _quote2-background-color_
   _quote2-foreground-color_
   _quote3-background-color_
   _quote3-foreground-color_
          Quote Colors.
   _quote-replace-string_
          This option specifies what string to use as a quote when
          _viewing_ a message. The standard way of quoting messages when
          replying is the string "> " (quote space). With this variable
          set, viewing a message will replace occurrences of "> " with the
          replacement string. This setting works best when
          Reply-Indent-String or the equivalent setting in your
          correspondents' mail programs is set to the default "> ", but it
          will also work fine with the Reply-Indent-String set to ">".
          Enable the feature Quote-Replace-Nonflowed to also have
          quote-replacement performed on non-flowed messages.
          Setting this option will replace ">" and "> " with the new
          setting. This string may include trailing spaces. To preserve
          those spaces enclose the full string in double quotes.
          No padding to separate the text of the message from the quote
          string is added. This means that if you do not add trailing
          spaces to the value of this variable, text will be displayed
          right next to the quote string, which may be undesirable. This
          can be avoided by adding a new string separated by a space from
          your selection of quote string replacement. This last string
          will be used for padding. For example, setting this variable to
          ">" " " has the effect of setting ">" as the
          quote-replace-string, with the text padded by a space from the
          last quote string to make it more readable.
          One possible setting for this variable could be "    " (four
          spaces wrapped in quotes), which would have the effect of
          indenting each level of quoting four spaces and removing the
          ">"'s. Different levels of quoting could be made more
          discernible by setting colors for quoted text.
          Replying to or forwarding the viewed message will preserve the
          original formatting of the message, so quote-replacement will
          not be performed on messages that are being composed.
   _quote-suppression-threshold_
          This option should be used with care. It will cause some of the
          quoted text to be eliminated from the display when viewing a
          message in the MESSAGE TEXT screen. For example, if you set the
          Quote-Suppression-Threshold to the value "5", this will cause
          quoted text that is longer than five lines to be truncated.
          Quoted text of five or fewer consecutive lines will be displayed
          in its entirety. Quoted text of more than six lines will have
          the first five lines displayed followed by a line that looks
          something like

                [ 12 lines of quoted text hidden from view ]
          As a special case, if exactly one line of quoted text would be
          hidden, the entire quote will be shown instead. So for the above
          example, quoted text which is exactly six lines long will will
          be shown in its entirety. (In other words, instead of hiding a
          single line and adding a line that announces that one line was
          hidden, the line is just shown.)
          If the sender of a message has carefully chosen the quotes that
          he or she includes, hiding those quotes may change the meaning
          of the message. For that reason, _Alpine_ requires that when you
          want to set the value of this variable to something less than
          four lines, you actually have to set it to the negative of that
          number. So if you want to set this option to "3", you actually
          have to set it to "-3". The only purpose of this is to get you
          to think about whether or not you really want to do this! If you
          want to delete all quoted text you set the value of this option
          to the special value "-10".
          The legal values for this option are

               0      Default, don't hide anything
           -1,-2,-3   Suppress quote lines past 1, 2, or 3 lines
           4,5,6,...  Suppress if more than that many lines
             -10      Suppress all quoted lines
          If you set this option to a non-default value you may sometimes
          wish to view the quoted text that is not shown. When this is the
          case, the HdrMode (Header Mode) command may be used to show the
          hidden text. Typing the "H" command once will show the hidden
          text. Typing a second "H" will also turn on Full Header mode.
          The presence or absence of the HdrMode command is determined by
          the "Enable-Full-Header-Cmd" Feature-List option in your _Alpine_
          configuration, so you will want to be sure that is turned on if
          you use quote suppression.
          For the purposes of this option, a quote is a line that begins
          with the character ">".
          Quotes are only suppressed when displaying a message on the
          screen. The entire quote will be left intact when printing or
          forwarding or something similar.
   _read-message-folder_
          If set, mail in the _INBOX_ that has been read but not deleted
          is moved here, or rather, the user is asked whether or not he or
          she wants to move it here upon quitting _Alpine_.
   _remote-abook-history_
          Sets how many extra copies of remote address book data will be
          kept in each remote address book folder. The default is three.
          These extra copies are simply old versions of the data. Each
          time a change is made a new copy of the address book data is
          appended to the folder. Old copies are trimmed, if possible,
          when _Alpine_ exits. An old copy can be put back into use by
          deleting and expunging newer versions of the data from the
          folder. Don't delete the first message from the folder. It is a
          special header message for the remote address book and it must
          be there. This is to prevent regular folders from being used as
          remote address book folders and having their data destroyed.
   _remote-abook-metafile_
          Personal configuration file only. This is usually set by _Alpine_
          and is the name of a file that contains data about remote
          address books and remote configuration files.
   _remote-abook-validity_
          Sets the minimum number of minutes that a remote address book
          will be considered up to date. Whenever an entry contained in a
          remote address book is used, if more than this many minutes have
          passed since the last check the remote server will be queried to
          see if the address book has changed. If it has changed, the
          local copy is updated. The default value is five minutes. The
          special value of -1 means never check. The special value of zero
          means only check when the address book is first opened.
          No matter what the value, the validity check is always done when
          the address book is about to be changed by the user. The check
          can be initiated manually by typing _^L_ (Ctrl-L) while in the
          address book maintenance screen for the remote address book.
   _reply-indent-string_
          This variable specifies an aspect of _Alpine_'s _Reply_ command.
          When a message is replied to and the text of the message is
          included, the included text usually has the string "> "
          prepended to each line indicating it is quoted text.
          This option specifies a different value for that string. If you
          wish to use a string which begins or ends with a space, enclose
          the string in double quotes.
          Besides simple text, the prepended string can be based on the
          message being replied to. The following tokens are substituted
          for the message's corresponding value:

        _FROM_
                This token gets replaced with the message sender's
                "username". At most six characters are used.

        _NICK_
                This token gets replaced with the nickname of the message
                sender's address as found in your addressbook. If no
                addressbook entry is found, Pine replaces the characters
                "_NICK_" with nothing. At most six characters are used.

        _INIT_
                This token gets replaced with the initials of the sender
                of the message.

          When the enable-reply-indent-string-editing feature is enabled,
          you are given the opportunity to edit the string, whether it is
          the default or one automatically generated using the above
          tokens.
   _reply-leadin_
          This option is used to customize the content of the introduction
          line that is included when replying to a message and including
          the original message in the reply. The normal default (what you
          will get if you delete this variable) looks something like:

                 On Sat, 24 Oct 1998, Fred Flintstone wrote:
          where the day of the week is only included if it is available in
          the original message. You can replace this default with text of
          your own. The text may contain tokens that are replaced with
          text that depends on the message you are replying to. For
          example, the default is equivalent to:

                         On _DAYDATE_, _FROM_ wrote:
          Since this variable includes regular text mixed with special
          tokens the tokens have to be surrounded by underscore
          characters. For example, to use the token "PREFDATE" you would
          need to use "_PREFDATE_", not "PREFDATE".
          The list of available tokens is here.
          By default, the text is all on a single line and is followed by
          a blank line. If your _Reply-Leadin_ turns out to be longer than
          80 characters when replying to a particular message, it is
          shortened. However, if you use the token

                                  _NEWLINE_
          anywhere in the value, no end of line or blank line is appended,
          and no shortening is done. The _NEWLINE_ token may be used to
          get rid of the blank line following the text, to add more blank
          lines, or to form a multi-line _Reply-Leadin_. To clarify how
          _NEWLINE_ works recall that the default value is:

                         On _DAYDATE_, _FROM_ wrote:
          That is equivalent to

                On _DAYDATE_, _FROM_ wrote:_NEWLINE__NEWLINE_
          In the former case, two newlines are added automatically because
          no _NEWLINE_ token appears in the value of the option (for
          backwards compatibility). In the latter case, the newlines are
          explicit. If you want to remove the blank line that follows the
          _Reply-Leadin_ text use a single _NEWLINE_ token like

                    On _DAYDATE_, _FROM_ wrote:_NEWLINE_
          Because of the backwards compatibility problem, it is not
          possible to remove all of the ends of lines, because then there
          will be no _NEWLINE_ tokens and that will cause the automatic
          adding of two newlines! If you want, you may embed newlines in
          the middle of the text, as well, producing a multi-line
          _Reply-Leadin_.
          By default, no attempt is made to localize the date. If you
          prefer a localized form you may find that one of the tokens
          _PREFDATE_ or _PREFDATETIME_ is a satisfactory substitute. If
          you want more control one of the many other date tokens, such as
          _DATEISO_, might be better.
          For the adventurous, there is a way to conditionally include
          text based on whether or not a token would result in specific
          replacement text. For example, you could include some text based
          on whether or not the _NEWS_ token would result in any
          newsgroups if it was used. It's explained in detail here.
          In the very unlikely event that you want to include a literal
          token in the introduction line you must precede it with a
          backslash character. For example,

                           \_DAYDATE_ = _DAYDATE_
          would produce something like

                        _DAYDATE_ = Sat, 24 Oct 1998
          It is not possible to have a literal backslash followed by an
          expanded token.
   _reverse-background-color_
   _reverse-foreground-color_
          Reverse Color.
   _rsh-command_
          Sets the format of the command used to open a UNIX remote shell
          connection. The default is "%s %s -l %s exec /etc/r%sd". All
          four "%s" entries MUST exist in the provided command. The first
          is for the command's pathname, the second is for the host to
          connect to, the third is for the user to connect as, and the
          fourth is for the connection method (typically imap).
   _rsh-open-timeout_
          Sets the time in seconds that _Alpine_ will attempt to open a
          UNIX remote shell connection. The default is 15, the minimum
          non-zero value is 5, and the maximum is unlimited. If this is
          set to zero rsh connections will be completely disabled.
   _rsh-path_
          Sets the name of the command used to open a UNIX remote shell
          connection. The default is typically /usr/ucb/rsh.
   _saved-msg-name-rule_
          Determines default folder name when _Sav_ing. If set to
          _default-folder_ (which is the default setting), then _Alpine_
          will offer the folder "saved-messages" (UNIX) or "SAVEMAIL" (PC)
          for _Sav_ing messages. The default folder offered in this way
          may be changed by using the configuration variable
          default-saved-msg-folder.
          If this rule is set to _last-folder-used_, _Alpine_ offers to
          _Save_ to the folder you last successfully _Saved_ a message to
          (this session). The first time you _Save_ a message in a
          session, _Alpine_ offers to _Save_ the message to the default
          folder.
          Choosing any of the _by-_ options causes _Alpine_ to attempt to
          get the chosen option's value for the message being _Saved_ (or
          for the first message being Saved if using an aggregate Save).
          For example, if _by-from_ is chosen, _Alpine_ attempts to get
          the value of who the message came from (i.e. the from address).
          _Alpine_ then attempts to _Save_ the message to a folder matching
          that value. If _by-from_ is chosen and no value is obtained,
          _Alpine_ uses _by-sender_. The opposite is also true. If
          _by-recipient_ was chosen and the message was posted to a
          newsgroup, _Alpine_ will use the newsgroup name. If _by-replyto_
          is chosen and no value is obtained, _Alpine_ uses _by-from_.
          If any of the "by-realname" options are chosen, _Alpine_ will
          attempt to use the personal name part of the address instead of
          the mailbox part. If any of the "by-nick" options are chosen,
          the address is looked up in your address book and if found, the
          nickname for that entry is used. Only simple address book
          entries are checked, not distribution lists. Similarly, if any
          of the "by-fcc" options are chosen, the fcc from the
          corresponding address book entry is used. If by-realname, or the
          by-nick or by-fcc lookups result in no value, then if the chosen
          option ends with the "then-from", "then-sender", "then-replyto",
          or "then-recip" suffix, _Alpine_ reverts to the same behavior as
          "by-from", "by-sender", "by-replyto", or "by-recip" depending on
          which option was specified. If the chosen option doesn't end
          with one of the "then-" suffixes, then _Alpine_ reverts to the
          default folder when no match is found in the address book.
          Here is an example to make some of the options clearer. If the
          message is From

                     Fred Flintstone <flint@bedrock.org>
          and this rule is set to "by-from", then the default folder
          offered in the save dialog would be "flint".
          If this rule is set to "by-realname-of-from" then the default
          would be "Fred Flintstone".
          If this rule is set to "by-nick-of-from" then _Alpine_ will
          search for the address "flint@bedrock.org" in your address book.
          If an entry is found and it has a nickname associated with it,
          that nickname will be offered as the default folder. If not, the
          default saved message folder will be offered as the default.
          If this rule is set to "by-fcc-of-from" then _Alpine_ will
          search for the address "flint@bedrock.org" in your address book.
          If an entry is found and it has an Fcc associated with it, that
          Fcc will be offered as the default folder. If not, the default
          saved message folder will be offered as the default.
          If this rule is set to "by-nick-of-from-then-from" then _Alpine_
          will search for the address "flint@bedrock.org" in your address
          book. If an entry is found and it has a nickname associated with
          it, that nickname will be offered as the default folder. If it
          is not found (or has no nickname) then the default offered will
          be the same as it would be for the "by-from" rule. That is, it
          would be "flint"
          This option is displayed as "Saved Message Name Rule".
   _scroll-margin_
          This option controls when _Alpine_'s line-by-line scrolling
          occurs. Typically, when a selected item is at the top or bottom
          screen edge and the UP or DOWN (and Ctrl-P or Ctrl-N) keys are
          pressed, the displayed items are scrolled down or up by a single
          line.
          This option allows you to tell _Alpine_ the number of lines from
          the top and bottom screen edge that line-by-line scrolling
          should occur. For example, setting this value to one (1) will
          cause _Alpine_ to scroll the display when you move to select an
          item on the display's top or bottom edge (instead of moving when
          you move off the edge of the screen).
          By default, this variable is zero (0), indicating that scrolling
          happens when you move up or down to select an item immediately
          off the display's top or bottom edge.
   _selectable-item-background-color_
   _selectable-item-foreground-color_
          Selectable-item Color.
   _sending-filters_
          This option defines a list of text-filtering commands (programs
          and scripts) that may be selectively invoked to process a
          message just before it is sent. If set, the Composer's _^X Send_
          command will allow you to select which filter (or none) to apply
          to the message before it is sent. For security reasons, the full
          path of the filter program must be specified.
          Sending filters do not work with _PC-Alpine_ and sending filters
          are not used if the feature send-without-confirm is set.
          Command Modifying Tokens:

        __RECIPIENTS__
                When the command is executed, this token is replaced with
                the space delimited list of recipients of the message
                being sent.

        __TMPFILE__
                When the command is executed, this token is replaced with
                the path and name of the temporary file containing the
                text to be filtered. _Alpine_ expects the filter to
                replace this data with the filter's result. NOTE: Use of
                this token implies that the text to be filtered is not
                piped into standard input of the executed command and its
                standard output is ignored. _Alpine_ restores the tty
                modes before invoking the filter in case the filter
                interacts with the user via its own standard input and
                output.

        __RESULTFILE__
                When the command is executed, this token is replaced with
                the path and name of a temporary file intended to contain
                a status message from the filter. _Alpine_ displays this
                in the message status field.

        __DATAFILE__
                When the command is executed, this token is replaced in
                the command line with the path and name of a temporary
                file that _Alpine_ creates once per session and deletes
                upon exit. The file is intended to be used by the filter
                to store state information between instances of the
                filter.

        __PREPENDKEY__
                When the command is executed, this token indicates that a
                random number will be passed down the input stream before
                the message text. It is not included as a command-line
                argument. This number could be used as a session key. It
                is sent in this way to improve security. The number is
                unique to the current _Alpine_ session and is only
                generated once per session.

        __INCLUDEALLHDRS__
                When the command is executed, this token indicates that
                the headers of the message will be passed down the input
                stream before the message text. It is not included as a
                command-line argument. The filter should, of course,
                remove the headers before returning control to _Alpine_.

        __MIMETYPE__
                When the command is executed, this token is replaced in
                the command name with a temporary file name used to accept
                any new MIME Content-Type information necessitated by the
                output of the filter. Upon the filter's exit, if the file
                contains new MIME type information, _Alpine_ verifies its
                format and replaces the outgoing message's MIME type
                information with that contained in the file. This is
                basically a cheap way of sending something other than
                Text/Plain.

   _sendmail-path_
          This names the path to an alternative program, and any necessary
          arguments, to be used in posting mail messages. See the section
          on SMTP and Sendmail for more details.
   _signature-file_
          This is the name of a file which will be automatically inserted
          into outgoing messages. It typically contains information such
          as your name, email address and organizational affiliation.
          _Alpine_ adds the signature into the message as soon as you enter
          the composer so you can choose to remove it or edit it on a
          message by message basis. Signature file placement in message
          replies is controlled by the signature-at-bottom setting in the
          feature list.
          This defaults to ~/.signature on UNIX and <PINERC
          directory>\PINE.SIG on a PC.
          To create or edit your signature file choose Setup from the Main
          Menu and then select S for Signature (Main/Setup/Signature).
          This puts you into the Signature Editor where you can enter a
          _few_ lines of text containing your identity and affiliation.
          If the filename is followed by a vertical bar (|) then instead
          of reading the contents of the file the file is assumed to be a
          program which will produce the text to be used on its standard
          output. The program can't have any arguments and doesn't receive
          any input from _Alpine_, but the rest of the processing works as
          if the contents came from a file.
          Instead of storing the data in a local file, the signature data
          may be stored remotely in an IMAP folder. In order to do this,
          you must use a remote name for the file. A remote signature-file
          name might look like:

                {myimaphost.myschool.k12.wa.us}mail/signature
          or, if you have an SSL-capable version of _Alpine_, you might
          try

      {myimaphost.myschool.k12.wa.us/user=loginname/ssl}mail/signature
          The syntax used here is the same as the syntax used for remote
          configuration files from the command line. Note that you may not
          access an existing signature file remotely, you have to create a
          new _folder_ which contains the signature data. If the name you
          use here for the signature file is a remote name, then when you
          edit the file from the Setup/Signature command the data will be
          stored remotely in the folder. You aren't required to do
          anything special to create the folder, it gets created
          automatically if you use a remote name.
          Besides regular text, the signature file may also contain (or a
          signature program may produce) tokens which are replaced with
          text which usually depends on the message you are replying to or
          forwarding. For example, if the signature file contains the
          token

                                   _DATE_
          anywhere in the text, then that token is replaced by the date
          the message you are replying to or forwarding was sent. If it
          contains

                                  _CURDATE_
          that is replaced with the current date. The first is an example
          of a token which depends on the message you are replying to (or
          forwarding) and the second is an example which doesn't depend on
          anything other than the current date. You have to be a little
          careful with this facility since tokens which depend on the
          message you are replying to or forwarding will be replaced by
          nothing in the case where you are composing a new message from
          scratch. The use of roles may help you in this respect. It
          allows you to use different signature files in different cases.
          The list of tokens available for use in the signature file is
          here.
          Instead of, or along with the use of _roles_ to give you
          different signature files in different situations, there is also
          a way to conditionally include text based on whether or not a
          token would result in specific replacement text. For example,
          you could include some text based on whether or not the _NEWS_
          token would result in any newsgroups if it was used. This is
          explained in detail here. This isn't for the faint of heart.
          In the very unlikely event that you want to include a literal
          token in the signature you must precede it with a backslash
          character. For example,

                           \_DAYDATE_ = _DAYDATE_
          would produce something like

                        _DAYDATE_ = Sat, 24 Oct 1998
          It is not possible to have a literal backslash followed by an
          expanded token.
   _signature-background-color_
   _signature-foreground-color_
          Signature Color.
   _smime-public-cert-directory_
          UNIX _Alpine_ only.
          If the option smime-public-cert-container is set then this
          option will have no effect.
          Normally, Public Certificates for use with S/MIME will be stored
          in the directory which is the value of this option. Those
          certificates will be stored in PEM format, one certificate per
          file. The name of the file for the certificate corresponding to

                                emailaddress
          should be

                              emailaddress.crt
          For example, a file for user@example.com would be in the file

                            user@example.com.crt
          in this directory.
          Use the Setup/SMIME screen to modify this variable.
          Typically, the public certificates that you have will come from
          S/MIME signed messages that are sent to you. _Alpine_ will
          extract the public certificate from the signed message and store
          it in the certificates directory. These PEM format public
          certificates look something like:
-----BEGIN CERTIFICATE-----
MIIFvTCCBKWgAwIBAgIQD4fYFHVI8T20yN4nus097DANBgkqhkiG9w0BAQUFADCB
rjELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAlVUMRcwFQYDVQQHEw5TYWx0IExha2Ug
Q2l0eTEeMBwGA1UEChMVVGhlIFVTRVJUUlVTVCBOZXR3b3JrMSEwHwYDVQQLExho
...
2b9KGqDyMWW/rjNnmpjzjT2ObGM7lRA8lke4FLOLajhrz4ogO3b4DFfAAM1VSZH8
D6sOwOLJZkLY8FRsfk63K+2EMzA2+qAzMKupgeTLqXIf
-----END CERTIFICATE-----

          + General S/MIME Overview
          This option is displayed as "S/MIME - Public Cert Directory".
   _smime-public-cert-container_
          UNIX _Alpine_ only.
          If this option is set it will be used instead of
          smime-public-cert-directory
          This option gives you a way to store certificates remotely on an
          IMAP server instead of storing the certificates one per file
          locally. In order to do that you just give this option a remote
          folder name for a folder which does not yet exist. The name is
          similar to the name you might use for a remote configuration
          file. A remote folder name might look something like:

               {myimaphost.myschool.k12.wa.us}mail/publiccerts
          Use the Setup/SMIME screen to modify this variable.
          + General S/MIME Overview
          This option is displayed as "S/MIME - Public Cert Container".
   _smime-private-key-directory_
          UNIX _Alpine_ only.
          In order to sign outgoing S/MIME messages you will need a
          personal digital ID certificate. You will usually get such a
          certificate from a certificate authority such as Thawte or
          CAcert. (In order to encrypt outgoing messages you don't need a
          personal digital ID, you need the public certificate of the
          recipient instead.) If the option smime-private-key-container is
          set then this option will have no effect.
          Normally, Private Keys for use with S/MIME will be stored in the
          directory which is the value of this option. Those certificates
          will be stored in PEM format, one certificate per file. The name
          of the file for the certificate corresponding to your

                                emailaddress
          should be

                              emailaddress.key
          For example, if your address is user@example.com the name of the
          file would be

                            user@example.com.key
          in this directory.
          Use the Setup/SMIME screen to modify this variable.
          Typically, the private key that you have will come from a
          Certificate Authority. The private key should be stored in a PEM
          format file that looks something like:
-----BEGIN RSA PRIVATE KEY-----
Proc-Type: 4,ENCRYPTED
DEK-Info: DES-EDE3-CBC,2CBD328FD84CF5C6

YBEXYLgLU9NJoc1V+vJ6UvcF08RX54S6jXsmgL0b5HGkudG6fhnmHkH7+UCvM5NI
SXO/F8iuZDfs1VGG0NyitkFZ0Zn2vfaGovBvm15gx24b2xnZDLRB7/bNZkurnK5k
VjAjZ2xXn2hFp2GJwqRdmxYNqsKGu52B99oti5HUWuZ2GFRaWjn5hYOqeApZE2uA
...
oSRqfI51UdSRt0tmGhHeTvybUVrHm9eKft8TTGf+qSBqzSc55CsmoVbRzw4Nfhix
m+4TJybNGNfAgOctSkEyY/OCb49fRRQTCBZVIhzLGGmpYmkO55HbIA==
-----END RSA PRIVATE KEY-----

          + General S/MIME Overview
          This option is displayed as "S/MIME - Private Key Directory".
   _smime-private-key-container_
          UNIX _Alpine_ only.
          If this option is set it will be used instead of
          smime-private-key-directory.
          This option gives you a way to store keys remotely on an IMAP
          server instead of storing the keys one per file locally. In
          order to do that you just give this option a remote folder name
          for a folder which does not yet exist. The name is similar to
          the name you might use for a remote configuration file. A remote
          folder name might look something like:

               {myimaphost.myschool.k12.wa.us}mail/privatekeys
          Use the Setup/SMIME screen to modify this variable.
          + General S/MIME Overview
          This option is displayed as "S/MIME - Private Key Container".
   _smime-cacert-directory_
          UNIX _Alpine_ only.
          If the option smime-cacert-container is set then this option
          will have no effect.
          CACert is a shorthand name for certification authority
          certificate. Normally _Alpine_ will use the CACerts that are
          located in the standard system location for CACerts. It may be
          the case that one of your correspondents has a Digital ID which
          has been signed by a certificate authority that is not in the
          regular set of system certificate authorities. You may
          supplement the system list by adding further certificates of
          your own. These should be stored in the directory which is the
          value of this option. The certificates will be stored in PEM
          format, one certificate per file. The names of the files can be
          anything ending in ".crt".
          Use the Setup/SMIME screen to modify this variable.
          These PEM format CA certificates look very similar to your
          public certificates for particular email addresses
          (smime-public-cert-directory).
          + General S/MIME Overview
          This option is displayed as "S/MIME - Cert Authority Directory".
   _smime-cacert-container_
          UNIX _Alpine_ only.
          If this option is set it will be used instead of
          smime-cacert-directory.
          This option gives you a way to store certificates remotely on an
          IMAP server instead of storing the certificates one per file
          locally. In order to do that you just give this option a remote
          folder name for a folder which does not yet exist. The name is
          similar to the name you might use for a remote configuration
          file. A remote folder name might look something like:

                 {myimaphost.myschool.k12.wa.us}mail/cacerts
          Use the Setup/SMIME screen to modify this variable.
          + General S/MIME Overview
          This option is displayed as "S/MIME - Cert Authority Container".
   _smtp-server_
          One or more SMTP servers (host name or IP address) which _Alpine_
          will use for outgoing mail. If not set, _Alpine_ passes outgoing
          email to the _sendmail_ program on the local machine. _PC-Alpine_
          users must have this variable set in order to send mail as they
          have no _sendmail_ program.
          Your SMTP server may offer SMTP AUTH authentication. It may even
          require it. If your SMTP server offers SMTP AUTH authentication
          you may specify a "user" name parameter to cause _Alpine_ to
          attempt to authenticate. This parameter requires an associated
          value, the username identifier with which to establish the
          server connection. An example might be:

                      smtpserver.example.com/user=katie
          If AUTH authentication is offered by the server, this will cause
          _Alpine_ to attempt to use it. If AUTH authentication is not
          offered by the server, this will cause _Alpine_ to fail sending
          with an error similar to:

                  Error: SMTP authentication not available
          Another type of authentication that is used by some ISPs is
          called "POP before SMTP" or "IMAP before SMTP", which means that
          you have to authenticate yourself to the POP or IMAP server by
          opening a mailbox before you can send mail. To do this, you
          usually only have to open your INBOX.
          You may tell _Alpine_ to use the Message Submission port (587)
          instead of the SMTP port (25) by including the "submit"
          parameter in this option. At this time "/submit" is simply
          equivalent to specifying port 587, though it may imply more than
          that at some point in the future. Some ISPs are blocking port 25
          in order to reduce the amount of spam being sent to their users.
          You may find that the submit option allows you to get around
          such a block.

                        smtpserver.example.com/submit
          To specify any non-standard port number on the SMTP server you
          may follow the hostname with a colon followed by the portnumber.

                        smtpserver.example.com:12345
          Normally, when a connection is made to the Smtp-Server _Alpine_
          will attempt to negotiate a secure (encrypted) session using
          Transport Layer Security (TLS). If that fails then a
          non-encrypted connection will be attempted instead. You may
          specify that a TLS connection is required if you wish. If you
          append "/tls" to the name then the connection will fail instead
          of falling back to a non-secure connection.

                         smtpserver.example.com/tls
          See the SMTP Servers section or the Server Name Syntax section
          for some more details.
          This option is displayed as "SMTP Server (for sending)".
   _sort-key_
          This variable sets up the default Message Index sorting. The
          default is to sort by arrival order (the order the messages
          arrived in the folder). It has the same functionality as the
          _-sort_ command line argument and the _$_ command in the "Folder
          Index". If a _sort-key_ is set, then all folders open during the
          session will have that as the default sort order.
   _speller_
          UNIX _Alpine_ only.
          For _PC-Alpine_, you must install the aspell library code that
          you may get from http://aspell.net/win32/.
          This option affects the behavior of the _^T_ (spell check)
          command in the Composer. It specifies the program invoked by _^T_
          in the Composer. By default, _Alpine_ uses the system's "spell"
          command. _Alpine_ will use the command defined by this option
          (if any) instead. When invoking the spell-checking program,
          _Alpine_ appends a tempfile name (where the message is passed) to
          the command line. _Alpine_ expects the speller to correct the
          spelling in that file. When you exit from the speller program
          _Alpine_ will read the tmpfile back into the composer.
          For Unix _Alpine_ the program _ispell_ works well as an
          alternate spell checker. If your Unix system has _ispell_ it is
          probably reasonable to make it the default speller by
          configuring it as the default in the system configuration file,
          /usr/local/lib/pine.conf.
          If this option is not set, then the system's _spell_ command is
          used. The spell command does not work the same as the alternate
          speller. It produces a list of misspelled words on its standard
          output, instead, and doesn't take a tempfile as an argument.
          Don't set this speller option to the standard Unix spell
          command. That won't work. If you want to use the standard Unix
          spell command, set the speller option to nothing.
   _ssh-command_
          Sets the format of the command used to open a UNIX secure shell
          connection. The default is "%s %s -l %s exec /etc/r%sd". All
          four "%s" entries MUST exist in the provided command. The first
          is for the command's pathname, the second is for the host to
          connect to, the third is for the user to connect as, and the
          fourth is for the connection method (typically imap).
   _ssh-open-timeout_
          Sets the time in seconds that _Alpine_ will attempt to open a
          UNIX secure shell connection. The default is 15, the minimum
          non-zero value is 5, and the maximum is unlimited. If this is
          set to zero ssh connections will be completely disabled.
   _ssh-path_
          Sets the name of the command used to open a UNIX secure shell
          connection. The default is typically /usr/bin/ssh.
   _standard-printer_
          System-wide configuration file only. Specifies a list of
          commands for category 2 of the _Setup/Printer_ screen, the
          standard print command section. This is not used by _PC-Alpine_.
   _status-background-color_
   _status-foreground-color_
          Status Color.
   _status-message-delay_
          This option has evolved over time, causing the possible values
          to be counter-intuitive. Read carefully before you set this
          option. First we explain what the option does, then there is a
          longer discussion following that.
          If this is set to zero, the default value, it has _no_ effect.
          Positive and negative values serve two similar, but different
          purposes.
          If it is set to a positive number, it causes the cursor to move
          to the status line whenever a status message is printed and
          pause there for this many seconds. It will probably only be
          useful if the show-cursor feature is also turned on. Setting
          this option to a positive number can only be used to _increase_
          the status message delay. This may be useful for Braille
          displays, or other non-traditional displays.
          If it is set to a negative number the interpretation is a bit
          complicated. Negative numbers are used to _decrease_ the amount
          of delay _Alpine_ uses to allow you to read important status
          messages. Of course, this may cause you to miss some important
          messages. If you see a message flash by but miss what it says
          you can use the Journal command from the Main menu to read it.
          If you set this option to a negative value, the delay will be no
          more than one second less than the absolute value of the value
          you set. So if you set it to -1, the delay will be no more than
          zero seconds, no delay at all. If you set it to -2, the delay
          will be no more than 1 second. And so on, -3 is 2 seconds, -4 is
          3 seconds, ... If the delay that _Alpine_ would have used by
          default is less than this delay, then the smaller delay set by
          _Alpine_ will be used. Setting this option to a negative value
          can only reduce the amount of delay, never increase it.
          Here is a more detailed explanation. Status messages are the
          messages which show up spontaneously in the status message line,
          the third line from the bottom of the screen. By default,
          _Alpine_ assigns each status message it produces a minimum
          display time. Some status messages have a minimum display time
          of zero. You can see an example of such a message by paging up
          in this help text until you reach the top of the screen. If you
          try to page past the top you will see the message

                       [Already at start of help text]
          in the status line. If there is another more important use of
          the status message line this message might be replaced quickly,
          or it even might not be shown at all. However, if there is no
          reason to get rid of the message, it might stay there for
          several seconds while you read the help. An example where it is
          replaced immediately happens when you page up in the help text
          past the top of the screen, but then type the "WhereIs" command
          right after paging up. The message will disappear immediately
          without causing a delay (unless you have set this option to a
          positive value) to allow you to type input for the "WhereIs"
          command. Since it isn't a very important message, _Alpine_ has
          set its minimum display time to zero seconds.
          Other messages have minimum display times of three or more
          seconds. These are usually error messages that _Alpine_ thinks
          you ought to see. For example, it might be a message about a
          failed Save or a failed folder open. It is often the case that
          this minimum display time won't delay you in any way because the
          status message line is not needed for another reason. However,
          there are times when _Alpine_ has to delay what it is doing in
          order to display a status message for the minimum display time.
          This happens when a message is being displayed and _Alpine_
          wants to ask for input from the keyboard. For example, when you
          Save a message you use the status message line. You get a prompt
          there asking for the name of the folder to save to. If there is
          a status message being displayed that has not yet displayed for
          its minimum time _Alpine_ will display that status message
          surrounded with the characters > and < to show you that it is
          delaying. That might happen, for example, if you tried to save
          to a folder that caused an error, then followed that immediately
          with another Save command. You might find yourself waiting for a
          status message like

          [>Can't get write access to mailbox, access is readonly<]
          to finish displaying for three seconds. If that is something you
          find happening to you frequently, you may use negative values of
          this option to decrease or eliminate that delay, at the risk of
          missing the message.
   _stay-open-folders_
          This option affects low-level behavior of _Alpine_. There is no
          default value for this option. It is related to the options
          Preopen-Stayopen-Folders, Max-Remote-Connections, and
          offer-expunge-of-Stayopen-Folders.
          Note: changes made to this list take effect the next time you
          open a folder in the list.
          This is a list of folders that will be permanently kept open
          once they are first opened. The names in this list may be either
          the nickname of an Incoming folder or the full technical
          specification of a folder. The folders in this list need not be
          remote IMAP folders, they could usefully be local folders, as
          well. If a folder in the list is a newsgroup or is not accessed
          either locally or via IMAP, then the entry will be ignored. For
          example, folders accessed via NNTP or POP3 will not be kept
          open, since the way that new mail is found with those protocols
          involves closing and reopening the connection.
          Once a Stay Open folder has been opened, new-mail checking will
          continue to happen on that folder for the rest of the _Alpine_
          session. Your INBOX is always implicitly included in this
          Stay-Open list and doesn't need to be added explicitly.
          Another difference that you may notice between a Stay Open
          folder and a non-Stay Open folder is which message is selected
          as the current message when you enter the folder index.
          Normally, the starting position for an incoming folder (which
          most Stay Open folders will likely be) is controlled by the
          Incoming-Startup-Rule. However, if a folder is a Stay Open
          folder, when you re-enter the folder after the first time the
          current message will be the same as it was when you left the
          folder. An exception is made if you use the TAB command to get
          to the folder. In that case, the message number will be
          incremented by one from what it was when you left the folder.
          The above special behavior is thought to be useful. However, it
          is special and different from what you might at first expect.
          The feature Use-Regular-Startup-Rule-for-Stayopen-Folders may be
          used to turn off this special treatment.
          If the message that was current when you left the folder no
          longer exists, then the regular startup rule will be used
          instead.
          This option is displayed as "Stayopen Folders".
   _tcp-open-timeout_
          Sets the time in seconds that _Alpine_ will attempt to open a
          network connection. The default is 30, the minimum is 5, and the
          maximum is system defined (typically 75). If a connection has
          not completed within this many seconds _Alpine_ will give up and
          consider it a failed connection.
   _tcp-query-timeout_
          When _Alpine_ times out a network read or write it will normally
          just display a message saying "Still waiting". However, if
          enough time has elapsed since it started waiting it will offer
          to let you break the connection. That amount of time is set by
          this option, which defaults to 60 seconds, has a minimum of 5
          seconds, and a maximum of 1000 seconds.
   _tcp-read-warning-timeout_
          Sets the time in seconds that _Alpine_ will wait for a network
          read before warning you that things are moving slowly and
          possibly giving you the option to break the connection. The
          default is 15 seconds. The minimum is 5 seconds and the maximumn
          is 1000 seconds.
   _tcp-write-warning-timeout_
          Sets the time in seconds that _Alpine_ will wait for a network
          write before warning you that things are moving slowly and
          possibly giving you the option to break the connection. The
          default is 0 which means it is unset. If set to a non-zero
          value, the minimum is 5 and the maximum is 1000.
   _threading-display-style_
          When a folder is sorted by Threads or OrderedSubject, this
          option will affect the MESSAGE INDEX display. By default,
          _Alpine_ will display the MESSAGE INDEX in the
          "show-thread-structure" style if a folder is sorted by Threads
          or OrderedSubject. The possible values are:

        _none_
                Regular index display. The same index line as would be
                displayed without threading is used. The only difference
                will be in the order of the messages.

        _show-thread-structure_
                Threaded Subjects will be indented and vertical bars and
                horizontal lines will be added to make it easier to see
                the relationships among the messages in a thread (a
                conversation).

        _mutt-like_
                This is the same as the option above except that the
                Subject is suppressed (is blank) if it matches the
                previous Subject in the thread. The name comes from the
                email client Mutt. Here is an example of what a mutt-like
                index might look like. In this example, the first column
                represents the message number, the threading-index-style
                is set to "regular-index-with-expanded-threads", and the
                Threading-Lastreply-Character is set to a backslash:

    1    Some topic
    2  . Subject           original message in thread
    3    |->               reply to 2
    4  . |->               another reply to 2
    5  . | \->             reply to 4
    6  . |   \->           reply to 5
    7    |     \->         reply to 6
    8    |->               another reply to 2
    9  . |->New subject    another reply to 2 but with a New subject
   10    | |->             reply to 9
   11    | \->             another reply to 9
   12    |   \->           reply to 11
   13    \->               final reply to 2
   14    Next topic

        _indent-subject-1_
                Threaded Subjects will be indented one space per level of
                the conversation. The bars and lines that show up in the
                show-thread-structure display will not be there with this
                style.

        _indent-subject-2_
                Same as above but indent two spaces per level instead of
                one space.

        _indent-from-1_
                Similar to indent-subject-1, except that instead of
                indenting the Subject field one space the From field of a
                thread will be indented one space per level of the
                conversation.

        _indent-from-2_
                Same as above but indent two spaces per level instead of
                one space.

        _show-structure-in-from_
                The structure of the thread is illustrated with indenting,
                vertical bars, and horizontal lines just like with the
                show-thread-structure option, but the From field is used
                to show the relationships instead of the Subject field.

   _threading-expanded-character_
          The Threading-Expanded-Character option has a small effect on
          the MESSAGE INDEX display when using a threading-display-style
          other than _none_. The value of this option is a single
          character. This character is used to indicate that part of a
          thread has been expanded and could be collapsed if desired with
          the "/" Collapse/Expand command. By default, the value of this
          option is a dot (.).
          If this option is set to the Empty Value, then the column (and
          the following blank column) will be deleted from the display.
          This option is closely related to the
          threading-indicator-character option. Another similar option
          which affects the thread display is the
          threading-lastreply-character option.
   _threading-index-style_
          When a folder is sorted by Threads or OrderedSubject, this
          option will affect the INDEX displays. The possible values are:

        _regular-index-with-expanded-threads_
                This is the default display. If the configuration option
                threading-display-style is set to something other than
                "none", then this setting will cause _Alpine_ to start off
                with a MESSAGE INDEX with all of the threads expanded.
                That is, each message will have a line in the MESSAGE
                INDEX display. The Collapse/Expand command (/) may be used
                to manually collapse or expand a thread or subthread (see
                also slash-collapses-entire-thread).

                This setting affects the display when the folder is first
                threaded. The collapsed state may also be re-initialized
                by re-sorting the folder manually using the SortIndex
                command ($). After re-sorting the threads will once again
                all be expanded, even if you have previously collapsed
                some of them.

                If "threading-display-style" is set to "none", then the
                display will be the regular default _Alpine_ MESSAGE
                INDEX, but sorted in a different order.

        _regular-index-with-collapsed-threads_
                If the configuration option threading-display-style is set
                to something other than "none", then this setting will
                cause _Alpine_ to start out with all of the threads
                collapsed instead of starting out with all of the threads
                expanded. The Collapse/Expand command (/) may be used to
                manually collapse or expand a thread or subthread (see
                also slash-collapses-entire-thread).

                This setting affects the display when the folder is first
                threaded. The collapsed state may also be re-initialized
                by re-sorting the folder manually using the SortIndex
                command ($). After re-sorting the threads will once again
                all be collapsed, even if you have previously expanded
                some of them.

        _separate-index-screen-always_
                With this setting and the next, you will see an index of
                threads instead of an index of messages, provided you have
                sorted by Threads or OrderedSubject.

                The THREAD INDEX contains a '*' in the first column if any
                message in the thread is marked Important. If not, it
                contains a '+' if any message in the thread is to you. The
                second column is blank. The third column contains a 'D' if
                all of the messages in the thread are deleted. Otherwise,
                it contains an 'N' if any of the messages in the thread
                are New.

                When you view a particular thread from the THREAD INDEX
                you will be in the MESSAGE INDEX display but the index
                will only contain messages from the thread you are
                viewing.

        _separate-index-screen-except-for-single-messages_
                This is very similar to the option above. When you are in
                the THREAD INDEX, one of the available commands is
                "ViewThd". With the setting "separate-index-screen-always"
                (the option above) when you view a particular thread you
                will be in the MESSAGE INDEX display and the index will
                only contain messages from the thread you are viewing. If
                the thread you are viewing consists of a single message,
                the MESSAGE INDEX will be an index with only one message
                in it. If you use this
                "separate-index-screen-except-for-single-messages" setting
                instead, then that index which contains a single message
                will be skipped and you will go directly from the THREAD
                INDEX into the MESSAGE TEXT screen.

   _threading-indicator-character_
          The Threading-Indicator-Character option has a small effect on
          the MESSAGE INDEX display when using a threading-display-style
          other than _none_ and sorting by Threads or OrderedSubject. The
          value of this option is a single character. This character is
          used to indicate that part of a thread (a conversation) is
          hidden beneath a message. The message could be expanded if
          desired with the "/" Collapse/Expand command. By default, the
          value of this option is the greater than sign (>).
          If this option is set to the Empty Value, then the column (and
          the following blank column) will be deleted from the display.
          This option is closely related to the
          threading-expanded-character option. Another similar option
          which affects the thread display is the
          threading-lastreply-character option.
   _threading-lastreply-character_
          The Threading-Lastreply-Character option has a small effect on
          the MESSAGE INDEX display when using a threading-display-style
          of _show-thread-structure_, _mutt-like_, or
          _show-structure-in-from_; and sorting by Threads or
          OrderedSubject. The value of this option is a single character.
          This character is used instead of the vertical line character
          when there are no more replies directly to the parent of the
          current message. It can be used to "round-off" the bottom of the
          vertical line by setting it to a character such as a backslash
          (\) or a backquote (`). The default value of this option is the
          backslash character (\). This option may not be set to the Empty
          Value. In that case, the default will be used instead.
          This option is displayed as "Threading Last Reply Character".
   _title-background-color_
   _title-foreground-color_
          Title Color.
   _title-closed-background-color_
   _title-closed-foreground-color_
          Title-closed Color.
   _titlebar-color-style_
          titlebar-color-style.
   _unknown-character-set_
          A text message should either be made up of all US-ASCII
          characters or it should contain a charset label which tells the
          software which character set encoding to use to interpret the
          message. Sometimes a malformed message may be unlabeled but
          contain non-ascii text. This message is outside of the standards
          so any attempt to read it could fail. When _Alpine_ attempts to
          read such a message it will try to interpret the text in the
          character set you specify here. For example, if you have
          correspondents who send you unlabeled messages that are usually
          made up of characters from the WINDOWS-1251 character set,
          setting this unknown-character-set to WINDOWS-1251 will allow
          you to read those messages. Of course, if the unlabeled message
          is actually in some other character set, then you may see
          garbage on your screen.
          In the Setup/Config screen you may choose from a list of all the
          character sets _Alpine_ knows about by using the "T" ToCharsets
          command.
   _upload-command_
          This option affects the behavior of the Composer's _^R_ (Read
          File) and _^J_ (Attach File, in the header) commands. It
          specifies a Unix program name, and any necessary command line
          arguments, that _Alpine_ can use to transfer files from your
          personal computer into messages that you are composing.
   _upload-command-prefix_
          This option is used in conjunction with the _upload-command_
          option. It defines text to be written to the terminal emulator
          (via standard output) immediately prior to starting the upload
          command. This is useful for integrated serial line file transfer
          agents that permit command passing (e.g., Kermit's APC method).
   _url-viewers_
          List of programs to use to open Internet URLs. This value
          affects _Alpine_'s handling of URLs that are found in the text
          of messages you read. Normally, only URLs _Alpine_ can handle
          directly are automatically offered for selection in the "Message
          Text" screen. When one or more comma delimited Web browsers
          capable of deciphering URLs on their command line are added
          here, _Alpine_ will choose the first available browser to
          display URLs it doesn't recognize.
          Additionally, to support various connection methods and
          browsers, each entry in this list can begin with the special
          token _TEST(test-string)_. The test-string is a shell command
          that _Alpine_ will run and which must exit with a status of zero
          for _Alpine_ to consider that browser for use (the other
          criteria is that the browser must exist as a full path or a path
          relative to your home directory).
          Now for an example:

     url-viewers=_TEST("test -n '${DISPLAY}'")_ /usr/local/bin/netscape,
     /usr/local/bin/lynx, C:\BIN\NETSCAPE.BAT
          This example shows that for the first browser in the list to be
          used the environment variable DISPLAY must be defined. If it is,
          then the file /usr/local/bin/netscape must exist. If either
          condition is not met, then the file /usr/local/bin/lynx must
          exist. If it doesn't, then the final path and file must exist.
          Note that the last entry is a DOS/Windows path. This is one way
          to support _Alpine_ running on more than one architecture with
          the same configuration file.
   _use-only-domain-name_
          Can be set to _yes_ or _no._ Anything but _yes_ means _no._ If
          set to _yes_ the first label in the host name will be lopped off
          to get the domain name and the domain name will be used for
          outgoing mail and such. That is, if the host name is
          _carson.u.example.edu_ and this variable is set to _yes,_ then
          _u.example.edu_ will be used on outgoing mail. Only meaningful if
          user-domain is NOT set.
   _user-domain_
          Sets the domain or host name for the user, overriding the system
          host or domain name. See the domain name section. The easiest
          way to change the full From address is with the customized-hdrs
          variable.
   _user-id_
          _PC-Alpine_ only and personal configuration file only. Sets the
          username that is placed on all outgoing messages. The username
          is the part of the address that comes before the "@". The
          easiest way to change the full From address is with the
          customized-hdrs variable.
   _user-input-timeout_
          If this is set to an integer greater than zero, then this is the
          number of _hours_ to wait for user input before _Alpine_ times
          out. If _Alpine_ is in the midst of composing a message or is
          waiting for user response to a question, then it will not
          timeout. However, if _Alpine_ is sitting idle waiting for the
          user to tell it what to do next and the user does not give any
          input for this many hours, _Alpine_ will exit. No expunging or
          moving of read messages will take place. It will exit similarly
          to the way it would exit if it received a hangup signal. This
          may be useful for cleaning up unused _Alpine_ sessions which
          have been forgotten by their owners. The _Alpine_ developers
          envision system administrators setting this to a value of
          several hours (24?) so that it won't surprise a user who didn't
          want to be disconnected.
   _viewer-hdr-colors_
          This variable holds the optional Header Colors and patterns
          which have been defined by the user. This is usually modified by
          using the Header Colors section of the Setup Color screen.
   _viewer-hdrs_
          You may change the default list of headers that are viewed by
          listing the headers you want to view here. If the headers in
          your _viewer-hdrs_ list are present in the message, then they
          will be shown. The order of the headers you list will also be
          honored. If the special value _all-except_ is included as the
          first header in the _viewer-hdrs_ list, then all headers in the
          message except those in the list will be shown. The values are
          all case insensitive.
          This option is displayed as "Viewer Headers".
   _viewer-margin-left_
          This variable controls the left-hand vertical margin's width in
          _Alpine_'s Message Viewing screen. Its value is the number of
          space characters preceding each displayed line. For consistency
          with Viewer-Margin-Right, you may specify the column number to
          start in (column numbering begins with number 1) instead of the
          width of the margin by appending a lower case letter "c" to the
          number. For example, a value of "2c" means to start the text in
          column two, which is entirely equivalent to a value of "1",
          which means to leave a margin of 1 space.
          The default is a left margin of 0 (zero). Misconfigurations (for
          example, negative values or values with starting left columns
          greater than the ending right column) are silently ignored. If
          the number of columns for text between the Viewer-Margin-Left
          and the Viewer-Margin-Right is fewer than 8, then margins of
          zero will be used instead.
   _viewer-margin-right_
          This variable controls the right-hand vertical margin's width in
          _Alpine_'s Message Viewing screen. Its value is the number of
          space characters following each displayed line. You may specify
          the column number to end the text in (column numbering begins
          with number 1) instead of the width of the margin by appending a
          lower case letter "c" to the number. For example, a value of
          "76c" means to end the text in column 76. If the screen is 80
          characters wide, this is equivalent to a value of "4", which
          means to leave a margin of 4 spaces. However, if you use
          different size screens at different times, then these two values
          are not equivalent.
          The default right margin is 4. Misconfigurations (for example,
          negative values or values with starting left columns greater
          than the ending right column) are silently ignored. If the
          number of columns for text between the Viewer-Margin-Left and
          the Viewer-Margin-Right is fewer than 8, then margins of zero
          will be used instead.
   _viewer-overlap_
          This option specifies an aspect of _Alpine_'s Message Viewing
          screen. When the space bar is used to page forward in a message,
          the number of lines specified by the _viewer-overlap_ variable
          will be repeated from the bottom of the screen. That is, if this
          was set to two lines, then the bottom two lines of the screen
          would be repeated on the top of the next screen. The normal
          default value is "2".
   _window-position_
          Winsock version of _PC-Alpine_ only. Window position in the
          format: CxR+X+Yn Where C and R are the window size in characters
          and X and Y are the screen position of the top left corner of
          the window.
     __________________________________________________________________

Configuration Features

   There are several features (options) which may be turned off or on. The
   configuration variable feature-list is a list of all the features that
   are turned on or off. If the name of a feature is in the list it will
   be turned on. If the name of a feature with the characters no-
   prepended is in the list, it will turn the feature off. This is useful
   for overriding system-wide defaults. This is because, unlike all the
   other configuration variables, the _feature-list_ is additive. That is,
   first the system-wide _feature-list_ is read and then the user's
   _feature-list_ is read. This makes it possible for the system manager to
   turn some of the features on by default while still allowing the user
   to cancel that default. For example, if the system manager has turned
   on the _allow-talk_ feature by default then a user may turn it back off
   by including the feature _no-allow-talk_ in his or her personal
   configuration file. Of course, these details are usually handled by
   _Alpine_ when the user turns an option on or off from inside the
   _Setup/Config_ screen.

   System managers should take some care when turning on features by
   default. Some of the documentation assumes that all of the features are
   off by default, so it could be confusing for a user if some are on by
   default instead. Feature names are case-independent.

   Here is an alphabetical list of possible features.
   _allow-changing-from_
          Prior to _Pine_ 4.00 there was a _compile_-time option called
          ALLOW_CHANGING_FROM. That has been replaced by a _runtime_
          feature. If this feature is turned on then the From line can be
          changed just like all the other header fields that can be
          changed. See the configuration variables customized-hdrs and
          default-composer-hdrs for more information on editing headers.
          The default value for this feature is ON, so that editing of
          From headers is allowed by default.
   _allow-talk_
          Unix _Alpine_ only. By default, permission for others to _talk_
          to your terminal is turned off when you are running _Alpine_.
          When this feature is set, permission is instead turned on.
          Note: The _talk_ program has nothing to do with _Alpine_ or
          email. The _talk_ daemon on your system will attempt to print a
          message on your screen when someone else is trying to contact
          you. If you wish to see these messages while you are running
          _Alpine_, you should enable this feature.
          If you do enable this feature and see a _talk_ message, you must
          suspend or quit _Alpine_ before you can respond.
   _alternate-compose-menu_
          This feature controls the menu that is displayed when Compose is
          selected. If set, a list of options will be presented, with each
          option representing the type of composition that could be used.
          This feature is most useful for users who want to avoid being
          prompted with each option separately, or who want to avoid the
          checking of remote postponed or form letter folders. The
          possible types of composition are:
          New, for starting a new composition. Note that if New is
          selected and roles are set, roles are checked for matches and
          applied according to the setting of the matching role.
          Interrupted, for continuing an interrupted composition. This
          option is only offered if an interrupted message folder is
          detected.
          Postponed, for continuing postponed compositions. This option is
          offered if a postponed-folder is set in the config _REGARDLESS
          OF_ whether or not the postponed folder actually exists. This
          option is especially handy for avoiding having to check for the
          existence of a remote postponed folder.
          Form, for using form letters. This option is offered if the
          form-letter-folder is set in the config, and is not checked for
          existence for reasons similar to those explained by the
          postponed option.
          setRole, for selecting a role to apply to a composition.
   _alternate-role-menu_
          Normally the Role Command allows you to choose a role and
          compose a new message using that role. When this feature is set,
          the role command will first ask whether you want to Compose a
          new message, Forward the current message, Reply to the current
          message, or Bounce the current message. If you are not in the
          MESSAGE INDEX and are not viewing a message, then there is no
          current message and the question will be skipped. After you have
          chosen to Compose, Forward, Reply or Bounce you will then choose
          the role to be used.
          When Bouncing the "Set From" address is used for the Resent-From
          header, the "Set Fcc" value is used for the Fcc provided that
          the option "Fcc-On-Bounce" is turned on, and the "Use SMTP
          Server" value is used for the SMTP server, if set. Other actions
          of the role are ignored when Bouncing.
          This feature is displayed as "Alternate Role (#) Menu".
   _assume-slow-link_
          UNIX _Alpine_ only.
          This feature affects _Alpine_'s display routines. If set, the
          normal inverse-video cursor (used to highlight the current item
          in a list) will be replaced by an _arrow_ cursor and other
          screen update optimizations for low-speed links (e.g. 2400 bps
          dialup connections) will be activated. One of the optimizations
          is that colored index lines (set up with Indexcolor Rules) will
          not be colored. This might be useful if _you_ know you have a
          slow speed link but for some reason _Alpine_ doesn't know.
   _auto-move-read-msgs_
          This feature controls an aspect of _Alpine_'s behavior upon
          quitting. If set, and the read-message-folder variable is also
          set, then _Alpine_ will automatically transfer all read messages
          from the _INBOX_ to the designated folder and mark them as
          deleted in the _INBOX_. Messages in the _INBOX_ marked with an
          _N_ (meaning New, or unseen) are not affected.
          This feature is displayed as "Auto Move Read Messages".
   _auto-open-next-unread_
          This feature controls the behavior of the TAB key when
          traversing folders in the optional incoming-folders collection
          or in optional news-collections.
          When the TAB (Next New) key is pressed, and there are no more
          unseen messages in the current (incoming message or news)
          folder, _Alpine_ will search the list of folders in the current
          collection for one containing New or Recent (new since the last
          time the folder was opened) messages. This behavior may be
          modified slightly with the Tab-Uses-Unseen-For-Next-Folder
          feature which causes _Alpine_ to look for Unseen messages
          instead of Recent messages. By default, when such a folder is
          found, _Alpine_ will ask whether you wish to open the folder. If
          this feature is set, _Alpine_ will automatically open the folder
          without prompting.
   _auto-unselect-after-apply_
          This feature affects the behavior of the Apply command. If set,
          the Apply command will do the operation you specify, but then
          will implicitly do an "UnSelect All", so that you will
          automatically be back in the normal Index view after the Apply.
   _auto-unzoom-after-apply_
          If set, and if you are currently looking at a Zoomed Index view
          of selected messages, the _Apply_ command will do the operation
          you specify, but then will implicitly do an _UnZoom_, so that
          you will automatically be back in the normal Index view after
          the _Apply_. This feature is set by default.
   _auto-zoom-after-select_
          If set, the _; select_ command will automatically perform a
          _Zoom_ after the _select_ is complete. This feature is set by
          default.
   _busy-cue-spinner-only_
          When _Alpine_ is delayed for some reason it usually shows that
          something is happening with a small animated display in the
          status message line near the bottom of the screen. Setting this
          feature will cause that animation to be the same each time
          instead of having _Alpine_ choose a random animation. You may
          turn the animation off altogether by setting the busy-cue-rate
          option to zero.
   _check-newmail-when-quitting_
          If set, _Alpine_ will check for new mail after you give the Quit
          command. If new mail has arrived since the previous check, you
          will be notified and given the choice of quitting or not
          quitting.
   _combined-addrbook-display_
          This feature affects the address book display screens. Normally,
          expanding an address book from the ADDRESS BOOK LIST screen will
          cause the remaining address books and directory servers to
          disappear from the screen, leaving only the entries of the
          expanded address book. If this feature is set, then the other
          address books will remain on the screen, so that all of the
          address books can be present at once.
          The way that commands work won't be changed. For example, the
          Select All command will select all of the entries in the current
          address book, not all of the entries in all of the address
          books. The WhereIs command will change a little. It will search
          through all of the text on the screen plus all of the entries
          from expanded address books.
          When this feature is set, the setting of the feature
          expanded-view-of-addressbooks has an effect.
          This feature is displayed as "Combined Addressbook Display".
   _combined-folder-display_
          This feature affects the folder list display screens. Normally,
          each folder list is viewed within its collection only. This
          command allows folder lists to be viewed within a single screen
          that combines the contents of all collections.
          The way that commands work won't be changed. For example, the
          Select All command will select all of the folders in the current
          collection, not all of the entries in all of the collections.
          The WhereIs command will change a little. It will search through
          all of the folders in the current collection as well as all the
          folder in any other expanded collection.
          When this feature is set, the setting of the feature
          expanded-view-of-folders has an effect.
   _combined-subdirectory-display_
          This feature affects the Folder List screen when the
          combined-folder-display feature is enabled. Normally, selecting
          a directory from the Folder List takes you into a new screen
          displaying only the contents of that directory.
          Enabling this feature will cause the contents of the selected
          directory to be displayed within the boundaries of the
          Collection it is a part of. All previously displayed collections
          will remain in the screen.
          The way that commands work won't be changed. For example, the
          Select All command will select all of the folders in the
          directory, as opposed to all of the entries in all of the
          collections. The WhereIs command will change a little. It will
          search through all of the folders in the current collection as
          well as all the folder in any other expanded collection.
   _compose-cancel-confirm-uses-yes_
          This feature affects what happens when you type ^C to cancel a
          composition. By default, if you attempt to cancel a composition
          by typing ^C, you will be asked to confirm the cancellation by
          typing a "C" for _C_onfirm. It logically ought to be a "Y" for
          _Y_es, but that is risky because the "^C Y" needed to cancel a
          message is close (on the keyboard) to the "^X Y" needed to send
          a message.
          If this feature is set the confirmation asked for will be a
          "_Y_es" instead of a "_C_onfirm" response.
   _compose-cut-from-cursor_
          If set, the _^K_ command in the composer will cut from the
          current cursor position to the end of the line, rather than
          cutting the entire line.
          This feature is displayed as "Ctrl-K Cuts From Cursor".
   _compose-maps-delete-key-to-ctrl-d_
          If set, Delete will be equivalent to ^D, and delete the current
          character. Normally _Alpine_ defines the Delete key to be
          equivalent to ^H, which deletes the _previous_ character.
          This feature is displayed as "Delete Key Maps to Ctrl-D".
   _compose-rejects-unqualified-addrs_
          If set, unqualified names entered as addresses will be treated
          as errors unless they match an addressbook nickname or are
          looked up successfully on an LDAP server. _Alpine_ will not
          attempt to turn them into complete addresses by adding your
          local domain (which _Alpine_ normally does by default).
          A complete (fully-qualified) address is one containing a
          username followed by an _@_ symbol, followed by a host or domain
          name (e.g. _jsmith@example.com_). An unqualified name is one
          without the _@_ symbol and host or domain name (e.g. _jsmith_).
          This feature is displayed as "Compose Rejects Unqualified
          Addresses".
   _compose-send-offers-first-filter_
          If you have sending-filters configured, setting this feature
          will cause the first filter in the _sending-filters_ list to be
          offered as the default instead of _unfiltered_, the usual
          default.
   _compose-sets-newsgroup-without-confirm_
          If you enter the composer while reading a newsgroup, you will
          normally be prompted to determine whether you intend the new
          message to be posted to the current newsgroup or not. If this
          feature is set, _Alpine_ will not prompt you in this situation,
          and will assume that you do indeed wish to post to the newsgroup
          you are reading.
          This feature is displayed as "Compose Sets Newsgroup Without
          Confirming".
   _confirm-role-even-for-default_
          If you have roles, when you Reply to or Forward a message, or
          Compose a new message, _Alpine_ will search through your roles
          for one which matches. Normally, if no matches are found you
          will be placed into the composer with no opportunity to select a
          role. If this feature is set, then you will be asked to confirm
          that you don't want a role. This will give you the opportunity
          to select a role (with the ^T command). If you confirm no role
          with a Return, you will be placed in the composer with no role.
          You may also confirm with either an "N" or a "Y". These behave
          the same as if you pressed the Return. (The "N" and "Y" answers
          are available because they match what you might type if there
          was a role match.)
          If you are using the alternate form of the Compose command
          called "Role", then all of your roles will be available to you,
          independent of the value of this feature and of the values set
          for all of Reply Use, Forward Use, and Compose Use.
   _continue-tab-without-confirm_
          Normally, when you use the TAB NextNew command and there is a
          problem checking a folder, you are asked whether you want to
          continue with the search in the following folder or not. This
          gives you a chance to stop the NextNew processing.
          If this feature is set you will not be asked. It will be assumed
          that you want to continue.
          This feature is displayed as "Continue NextNew Without
          Confirming".
   _convert-dates-to-localtime_
          Normally, the message dates that you see in the MESSAGE INDEX
          and MESSAGE VIEW are displayed in the timezone they were sent
          from. For example, if a message was sent to you from a few
          timezones to the east it might appear that it was sent from the
          future; or if it was sent from somewhere to the west it might
          appear as if it is from yesterday even though it was sent only a
          few minutes ago. If this feature is set an attempt will be made
          to convert the dates to your local timezone to be displayed.
          Note that this does not affect the results of Select by Date or
          of anything else other than these displayed dates. When viewing
          the message you may look at the original unconverted value of
          the Date header by using the HdrMode Command.
   _copy-to-address-to-from-if-it-is-us_
          This feature affects the From address used when Replying to a
          message. It is probably only useful if you have some
          alt-addresses defined. When enabled, it checks to see if any of
          the addresses in the To or Cc fields of the message you are
          replying to is one of your addresses. If it is, and there is
          only one of them, then that address is used as the From address
          in the message you are composing. In other words, you will be
          using a From address that is the same as the To address that was
          used to get the mail to you in the first place.
          If a role is being used and it has a From address defined, that
          From address will be used rather than the one derived from this
          feature.
   _delete-skips-deleted_
          If set, this feature will cause the _Delete_ command to advance
          past other messages that are marked deleted. In other words,
          pressing _D_ will both mark the current message deleted and
          advance to the next message that is not marked deleted. This
          feature is set by default.
   _disable-config-cmd_
          If set, the configuration screen _Setup/Config_ will not be
          available at all.
   _disable-save-input-history_
          Many of the prompts that ask for input in the status line near
          the bottom of the screen will respond to Up Arrow and Down Arrow
          with the history of previous entries. For example, in the
          MESSAGE INDEX screen when you use the WhereIs command the text
          you entered will be remembered and can be recalled by using the
          Up Arrow key. Another example, when saving a message the folders
          saved to will be remembered and can be recalled using the arrow
          keys.
          In the Save prompt, some users prefer that the Up and Down arrow
          keys be used for the Previous Collection and Next Collection
          commands instead of for a history of previous saves. If this
          option is set the Up and Down arrow keys will become synonyms
          for the Previous Collection and Next Collection (^P and ^N)
          commands in the prompt for the name of a folder to Save to or in
          the prompt for the name of a folder to GoTo. When this feature
          is not set (the default), ^P and ^N will change the collection
          and the arrow keys will show the history.
   _disable-keyboard-lock-cmd_
          In the Main _Alpine_ menu there is a Keyboard locking command
          (_KBLock_). If this feature is set, that command won't be
          available to the user.
   _disable-keymenu_
          If set, the command key menu that normally appears on the bottom
          two lines of the screen will not usually be there. Asking for
          help with _^G_ or _?_ will cause the key menu to appear instead
          of causing the help message to come up. If you want to actually
          see the help text, another _^G_ or _?_ will show it to you.
          After the key menu has popped up with the help key it will
          remain there for an _O Other_ command but will disappear if any
          other command is typed.
   _disable-password-caching_
          Normally, loginname/password combinations are cached in _Alpine_
          so that the user does not have to enter the same password more
          than once in a session. A disadvantage to this approach is that
          the password must be stored in the memory image of the running
          _Alpine_ in order that it can be reused. In the event that
          _Alpine_ crashes and produces a core dump, and that core dump is
          readable by others, the loginname and password could possibly be
          read from the core dump.
          If this feature is set, then the passwords will not be cached
          and the user will have to retype the password whenever _Alpine_
          needs it. Even with this feature set there is still some chance
          that the core file will contain a password, so care should be
          taken to make the core files unreadable.
          NOTE: If PASSFILE caching is enabled, this does not disable it.
          That is a separate and independent feature.
   _disable-password-cmd_
          If set the _Newpassword_ command usually available under the
          _Setup_ command will not be available.
   _disable-pipes-in-sigs_
          If set it will be an error to append a vertical bar (|) to the
          name of a signature file. Appending a vertical bar normally
          causes the signature file to be executed to produce the
          signature.
   _disable-pipes-in-templates_
          If set it will be an error to append a vertical bar (|) to the
          name of a template file. Appending a vertical bar normally
          causes the signature file to be executed to produce the
          signature.
   _disable-regular-expression-matching-for-alternate-addresses_
          Normally, the alt-addresses option is interpreted as a regular
          expression. One type of address that might cause trouble is an
          address that contains a plus sign. If you want to have an
          address with a plus as one of your alternate addresses and you
          don't want to use regular expressions, then setting this feature
          will cause _Alpine_ to treat the addresses you list literally
          instead.
   _disable-roles-setup-cmd_
          If set the _Roles_ command usually available under the _Setup_
          command will not be available.
   _disable-roles-sig-edit_
          If set the roles editor in the _Setup/Roles_ command will not
          allow editing of signature files with the F subcommand.
   _disable-roles-template-edit_
          If set the roles editor in the _Setup/Roles_ command will not
          allow editing of template files with the F subcommand.
   _disable-sender_
          If set, _Alpine_ will not generate a "Sender:" or "X-X-Sender"
          header. This may be desirable on a system which is virtually
          hosting many domains, and the sysadmin has other methods
          available for tracking a message to its originator.
          This feature is displayed as "Do Not Generate Sender Header".
   _disable-setlocale-collate_
          This is a hard to understand feature that should only be used in
          rare cases. Normally, the C function call

                          setlocale(LC_COLLATE, "")
          is used by _Alpine_. If you want to try turning it off, setting
          this feature will turn it off. This part of the locale has to do
          with the sort order of characters in your locale.
   _disable-shared-namespaces_
          If this hidden feature is set the automatic search for
          namespaces "ftp", "imapshared", and "imappublic" by the
          underlying library will be disabled. The reason this feature
          exists is because there are some implementations of system
          password lookup routines which are very slow when presented with
          a long loginname which does not exist. This feature could be set
          to prevent the delay at startup time when the names above are
          searched for in the password file.
   _disable-signature-edit-cmd_
          If set the _Signature_ editing command usually available under
          the _Setup_ command will not be available.
   _disable-take-fullname-in-addresses_
          Normally, when TakeAddr is used to copy an address or addresses
          from a message into an address book entry, _Alpine_ will try to
          preserve the full name associated with each address in the list
          of addresses. The reason for this is so that if the entry is a
          list or later becomes a list, then information about the
          individual addresses in the list is preserved. If you would
          rather just have the simple addresses in the list of addresses,
          set this feature. For example, with the default setting you
          might see something like this in the ADDRESS BOOK editor after
          you type TakeAddr
 Nickname  : nick
 Fullname  : Bedrock Elders
 Fcc       :
 Comment   :
 Addresses : Fred Flintstone <flint@bedrock.org>,
             Barney Rubble <rubble@bedrock.org>

          but with this feature set it would look like
 Nickname  : nick
 Fullname  : Bedrock Elders
 Fcc       :
 Comment   :
 Addresses : flint@bedrock.org,
             rubble@bedrock.org

          instead. Note the difference in the Addresses field.
   _disable-take-last-comma-first_
          Normally, when _TakeAddr_ is used to copy an address from a
          message into an address book, _Alpine_ will attempt to rewrite
          the full name of the address in the form:

     Last, First
          instead of

     First Last
          It does this because many people find it useful to sort by Last
          name instead of First name. If this feature is set, then the
          _TakeAddr_ command will not attempt to reverse the name in this
          manner.
   _disable-terminal-reset-for-display-filters_
          UNIX _Alpine_ only.
          This feature affects _Alpine_'s behavior when using
          Display-Filters. Normally, before the display filter is run, the
          terminal mode is reset to what it was before you started
          _Alpine_. This may be necessary if the filter requires the use of
          the terminal. For example, it may need to interact with you. If
          you set this feature, then the terminal mode will not be reset.
          One thing that turning on this feature should fix is the
          coloring of quoted text in the message view, which breaks
          because the terminal reset resets the color state of the
          terminal (Color Configuration).
   _downgrade-multipart-to-text_
          This feature affects _Alpine_'s behavior when sending mail.
          Internet standards require _Alpine_ to translate all non-ASCII
          characters in messages that it sends using MIME encoding. This
          encoding can be ostensibly broken for recipients if any agent
          between _Alpine_ and the recipient, such as an email list
          expander, appends text to the message, such as list information
          or advertising. When sending such messages _Alpine_ attempts to
          protect such encoding by placing extra MIME boundaries around
          the message text.
          These extra boundaries are invisible to recipients that use
          MIME-aware email programs (the vast majority). However, if you
          correspond with users of email programs that are not MIME-aware,
          or do not handle the extra boundaries gracefully, you can use
          this feature to prevent _Alpine_ from including the extra MIME
          information. Of course, it will increase the likelihood that
          non-ASCII text you send may appear corrupt to the recipient.
   _enable-8bit-esmtp-negotiation_
          This feature affects _Alpine_'s behavior when sending mail. By
          default, this feature is set. Internet standards require that
          all electronic mail messages traversing the global Internet
          consist of 7bit ASCII characters unless a pair of cooperating
          mail transfer agents explicitly agree to allow 8bit messages. In
          general, then, exchanging messages in non-ASCII characters
          requires MIME encoding.
          However, there are now Internet standards that allow for
          unencoded 8bit exchange of messages between cooperating systems.
          When this feature is set _Alpine_ will try to negotiate
          unencoded 8bit transmission during the sending process. Should
          the negotiation fail, _Alpine_ will fall back to its ordinary
          encoding rules.
          Note, this feature relies on your system's mail transport agent
          or configured smtp-server having the negotiation mechanism
          introduced in "Extended SMTP" (ESMTP) and the specific extension
          called _8BITMIME_.
   _enable-8bit-nntp-posting_
          The Internet standard for exchanging USENET news messages
          (RFC-1036) specifies that USENET messages should conform to
          Internet mail standards and contain only 7bit characters, but
          much of the news transport software in use today is capable of
          successfully sending messages containing 8bit characters. Hence,
          many people believe that it is appropriate to send 8bit news
          messages without any MIME encoding.
          Moreover, there is no Internet standard for explicitly
          negotiating 8bit transfer, as there is for Internet email.
          Therefore, _Alpine_ provides the option of posting unencoded
          8bit news messages, though not as the default. Setting this
          feature will turn OFF _Alpine_'s MIME encoding of newsgroup
          postings that contain 8bit characters.
          Note, articles may cross a path or pass through news transport
          software that is unsafe or even hostile to 8bit characters. At
          best this will only cause the posting to become garbled. The
          safest way to transmit 8bit characters is to leave _Alpine_'s
          MIME encoding turned on, but recipients who lack MIME-aware
          tools are often annoyed when they receive MIME-encoded messages.
   _enable-aggregate-command-set_
          When this feature is set you may use the commands and
          subcommands that relate to performing operations on more than
          one message at a time. We call these "aggregate operations". In
          particular, the _; Select_, _A Apply_, and _Z Zoom_ commands are
          enabled by this feature. _Select_ is used to _tag_ one or more
          messages meeting the specified criteria. _Apply_ can then be
          used to apply any message command to all of the selected/tagged
          messages. Further, the _Zoom_ command allows you to toggle the
          "Folder Index" view between just those Selected and all messages
          in the folder.
          This feature also enables the _^X_ subcommand in the "Folder
          Index" _WhereIs_ command which causes all messages matching the
          _WhereIs_ argument to become selected.
          You may also use aggregate operations in the address book
          screens where you are operating on address book entries instead
          of on messages.
   _enable-alternate-editor-cmd_
          If this feature is set (the default), and the editor variable is
          not set, entering the _^__ (Control-underscore) key while
          composing a message will prompt you for the name of the editor
          you would like to use.
          If the environment variable $EDITOR is set, this value will be
          offered as a default. If the _editor_ variable is set, the _^__
          key will activate the specified editor without prompting, in
          which case it is not necessary to set the
          _enable-alternate-editor-cmd_ feature. This feature is not
          available in _PC-Alpine_.
          This feature is displayed as "Enable Alternate Editor Command".
   _enable-alternate-editor-implicitly_
          If this feature and the editor variable are both set, _Alpine_
          will automatically activate the specified editor when the cursor
          is moved from the header of the message being composed into the
          message text. For replies, the alternate editor will be
          activated immediately. If this feature is set but the _editor_
          variable is not set, then _Alpine_ will automatically ask for
          the name of an alternate editor when the cursor is moved out of
          the headers, or if a reply is being done. This feature is not
          available in _PC-Alpine_.
   _enable-arrow-navigation_
          This feature controls the behavior of the left and right arrow
          keys. If set, the left and right arrow keys will operate like
          the usual navigation keys _<_ and _>_. This feature is set by
          default.
          If you set this feature, and do not like the changed behavior of
          the up/down arrow keys when navigating through the FOLDER LIST
          screen -- _first_ from column to column, if more than one folder
          is displayed per row, and _then_ from row to row -- you may
          either also wish to set the feature
          enable-arrow-navigation-relaxed, single-column-folder-list, or
          use the ^P/^N (instead of up/down arrow) keys to move up/down
          the list of folders in each column.
   _enable-arrow-navigation-relaxed_
          This feature controls the behavior of the left and right arrow
          keys in the FOLDER LIST screen when the enable-arrow-navigation
          feature is set. This feature is set by default.
          When this feature is set, the left and right arrow keys in the
          FOLDER LIST screen move the highlight bar to the left or right,
          and the up and down arrows move it up or down.
          When the "Enable-Arrow-Navigation" feature is set and this
          feature is not set; the left and right arrow keys in the Folder
          List screen strictly track the commands bound to the '<' and '>'
          keys, and the up and down arrow keys move the highlight bar to
          the previous and next folder or directory name.
   _enable-background-sending_
          If set, this feature enables a subcommand in the composer's
          _Send?_ confirmation prompt. The subcommand allows you to tell
          _Alpine_ to handle the actual posting in the background. While
          this feature usually allows posting to appear to happen very
          fast, it has no affect on the actual delivery time it takes a
          message to arrive at its destination.
          This feature isn't supported on all systems. All DOS and
          Windows, as well as several Unix ports, do not recognize this
          feature. It is not possible to use background sending if the
          feature send-without-confirm is set.
          Error handling is significantly different when this feature is
          enabled. Any message posting failure results in the message
          being appended to your _Interrupted_ mail folder. When you type
          the _Compose_ command, _Alpine_ will notice this folder and
          offer to extract any messages contained. Upon continuing a
          failed message, _Alpine_ will display the nature of the failure
          in the status message line.
          Under extreme conditions, it is possible for message data to get
          lost. Do not enable this feature if you typically run close to
          any sort of disk-space limits or quotas.
   _enable-bounce-cmd_
          Setting this feature enables the _B Bounce_ command, which will
          prompt for an address and _remail_ the message to the new
          recipient. This command is used to re-direct messages that you
          have received in error, or need to be redirected for some other
          reason (e.g. list moderation). The final recipient will see a
          header indicating that you have Resent the msg, but the
          message's From: header will show the original author of the
          message, and replies to it will go back to that author, and not
          to you.
          This feature is displayed as "Enable Bounce Command".
   _enable-cruise-mode_
          This feature affects _Alpine_'s behavior when you hit the "Space
          Bar" at the end of a displayed message. Typically, _Alpine_
          complains that the end of the text has already been reached.
          Setting this feature causes such keystrokes to be interpreted as
          if the _Tab_ key had been hit, thus taking you to the next
          _interesting_ message, or scanning ahead to the next incoming
          folder with _interesting_ messages.
   _enable-cruise-mode-delete_
          This feature modifies the behavior of _Alpine_'s
          _enable-cruise-mode_ feature. Setting this feature causes _Alpine_
          to implicitly delete read messages when it moves on to display
          the next _interesting_ message.
          NOTE: Beware when enabling this feature _and_ the
          expunge-without-confirm feature.
          This feature is displayed as "Enable Cruise Mode With Deleting".
   _enable-delivery-status-notification_
          If set, this feature enables a subcommand in the composer's
          "Send?" confirmation prompt. The subcommand allows you to tell
          _Alpine_ to request the type of Delivery Status Notification
          (DSN) which you would like. Most users will be happy with the
          default, and need not enable this feature. See the online help
          for more details.
          It is not possible to use delivery status notifications if the
          feature send-without-confirm is set.
          Note that this is not a method to request _READ_ receipts, which
          tells the sender when the receiver has read the message. In this
          case we're talking about notification of delivery to the
          mailbox, not notification that the message has been seen.
   _enable-dot-files_
          If set, files beginning with dot (".") will be visible in the
          file browser. For example, you'll be able to select them when
          using the browser to add an attachment to a message.
   _enable-dot-folders_
          If set, folders beginning with dot (".") may be added and
          viewed. This feature is displayed as "Enable Hidden Folders".
   _enable-exit-via-lessthan-command_
          If set, then on screens where there is an _Exit_ command but no
          _<_ command, the _<_ key will perform the same function as the
          _Exit_ command. This feature is set by default.
   _enable-fast-recent-test_
          This feature controls the behavior of the TAB key when
          traversing folders in the optional Incoming-Folders collection
          or in optional News-Collections.
          When the TAB (NextNew) key is pressed, the default behavior is
          to explicitly examine the status of the folder for the number of
          recent messages (messages delivered since the last time it was
          viewed). Depending on the size and number of messages in the
          folder, this test can be time consuming.
          Enabling this feature will cause _Alpine_ to only test for the
          existence of any recent messages rather than to obtain the
          count. This is much faster in many cases. The downside is that
          you're not given the number of recent messages when prompted to
          view the next folder. If the feature
          Tab-Uses-Unseen-For-Next-Folder is turned on, then the present
          feature will have no effect.
   _enable-flag-cmd_
          Setting this feature enables the _* Flag_ command, which allows
          you to manipulate the status flags associated with a message. By
          default, _Flag_ will set the _Important_ flag, which results in
          an asterisk being displayed in column one of the "Folder Index"
          for such messages.
          This feature is displayed as "Enable Flag Command".
   _enable-flag-screen-implicitly_
          This feature modifies the behavior of the _* Flag_ command
          (provided it too is enabled). By default, when the _* Flag_
          command is selected, _Alpine_ offers a prompt to set one of
          several flags and also offers the option of entering the
          detailed flag manipulation screen via the _^T_ key. Enabling
          this feature causes _Alpine_ to immediately enter the detailed
          flag screen rather than first offer the simple prompt. The
          Enable-Flag-Screen-Keyword-Shortcut option offers a slightly
          different way of setting keywords.
   _enable-flag-screen-keyword-shortcut_
          This feature modifies the behavior of the Flag command and the
          Select command. By default, when the "* Flag" command is
          selected, _Alpine_ offers a prompt to set one of several flags
          and also offers the option of entering the detailed flag
          manipulation screen via the "^T" key. If you have keywords
          defined, then enabling this feature adds a shortcut way to set
          or unset keywords. You use "*" followed by the first letter of a
          keyword (or the nickname of a keyword if you've given it a
          nickname) and that will set the keyword.
          An example is easier to understand than the explanation. The
          flag command can always be used to set the system flags. For
          example, to set the Answered flag you would type

                                     * A
          Now suppose you have defined a keyword "Work" using the Keywords
          option in the Config screen. By default, to set a keyword like
          "Work" you would usually have to go to the Flag Details screen
          using the "^T To Flag Details" command. Instead, if you have
          enabled this feature, you may type

                                     * W
          to set the Work flag, or

                                    * ! W
          to unset it. Just like for the other flag setting commands, the
          case of the letter does not matter, so "w" or "W" both set the
          "Work" keyword.
          Notice that you can only use this trick for one keyword that
          begins with "W". If you happen to have a "Work" keyword and
          another keyword that is "WIFI" the "* W" command will set the
          first one in your list of keywords. Also, there are five letters
          which are reserved for system flags and the NOT command. If you
          type "* A" it will always set the Answered flag, not your
          "Aardvark" keyword. In order to set the "Aardvark" keyword
          you'll still have to use the Flag Details screen.
          Because enabling the Enable-Flag-Screen-Implicitly option causes
          _Alpine_ to skip directly to the Flag Details screen when the
          Flag command is used, setting it will cause this feature to have
          no effect at all.
          Similarly, when Selecting by Keyword, setting this option will
          allow you to use Keyword initials instead of full keywords.
   _enable-full-header-cmd_
          This feature enables the _H Full Headers_ command which toggles
          between the display of all headers in the message and the normal
          edited view of headers. The _Full Header_ command also controls
          which headers are included for _Export_, _Pipe_, _Print_,
          _Forward_, and _Reply_ functions. (For _Reply_, the _Full Header_
          mode will respect the _include-headers-in-reply_ feature
          setting.)
          If Full Header mode is turned on and you Forward a message, you
          will be asked if you'd like to forward the message as an
          attachment, as opposed to including the text of the message in
          the body of your new message.
          If you have also turned on the "Quote Suppression" option then
          the Full Headers command actually rotates through three states
          instead of just two. The first is the normal view with long
          quotes suppressed. The second is the normal view but with the
          long quotes included. The last enables the display of all
          headers in the message. When using Export, Pipe, Print, Forward,
          or Reply the quotes are never suppressed, so the first two
          states are identical.
          Normally, the Header Mode will reset to the default behavior
          when moving to a new message. The mode can be made to persist
          from message to message by setting the feature
          Quell-Full-Header-Auto-Reset.
          This feature is displayed as "Enable Full Header Command".
   _enable-full-header-and-text_
          This feature affects how the _H Full Headers_ command displays
          message text. If set, the raw message text will be displayed.
          This especially affects MIME formatted email, where the entire
          MIME format will be displayed. This feature similarly affects
          how messages are included for the _Export_, _Pipe_, _Print_,
          _Forward_, and _Reply_ functions.
   _enable-goto-in-file-browser_
          Setting this causes _Alpine_ to offer the _G Goto_ command in
          the file browser. The Goto command allows you to explicitly type
          in the desired directory. That is the default.
   _enable-incoming-folders_
          If set, this feature defines a pseudo-folder collection called
          _INCOMING MESSAGE FOLDERS_. Initially, the only folder included
          in this collection will be your _INBOX_, which will no longer
          show up in your default saved-message folder collection.
          This feature is displayed as "Enable Incoming Folders
          Collection".
   _enable-incoming-folders-checking_
          This feature is only operational if you have enabled the
          optional incoming-folders If you do have Incoming Message
          Folders and you also set this feature, then the number of Unseen
          messages in each folder will be displayed in the FOLDER LIST
          screen for the Incoming Message Folders. The number of Unseen
          messages in a folder will be displayed in parentheses to the
          right of the name of each folder. If there are no Unseen
          messages in a folder then only the name is displayed, not a set
          of parentheses with zero inside them. A redraw command, Ctrl-L,
          can be used in the FOLDER LIST screen for the Incoming Message
          Folders to cause an immediate update.
          If a check for Unseen messages fails for a particular folder
          then Alpine will no longer attempt to check that folder for the
          duration of the session and this will be indicated by a question
          mark inside the parentheses.
          The features incoming-checking-includes-total,
          incoming-checking-uses-recent, incoming-check-list,
          incoming-check-interval, incoming-check-interval-secondary, and
          incoming-check-timeout all affect how this feature behaves.
   _Disable-Index-Locale-Dates_
          This feature affects the display of dates in the MESSAGE INDEX.
          Normally an attempt is made to localize the dates used in the
          MESSAGE INDEX display to your locale. This is controlled with
          the LC_TIME locale setting on a UNIX system. On Windows the
          Regional Options control panel may be used to set the date
          format. At the programming level, _Alpine_ is using the strftime
          routine to print the parts of a date.
          If this feature is set, dates are displayed in English and with
          the conventions of the United States.
   _enable-jump-shortcut_
          When this feature is set you may enter a number (followed by
          RETURN) and jump to that message number, when in the MESSAGE
          INDEX or MESSAGE TEXT screens. In other words, it obviates the
          need for typing the _J_ for the _Jump_ command.
   _enable-lame-list-mode_
          This feature modifies the method _Alpine_ uses to ask your IMAP
          server for folder names to display in the the FOLDER LIST
          screen. It is intended to compensate for a small set of IMAP
          servers that are programmed to ignore a part of the request, and
          thus respond to _Alpine_'s query with nonsensical results.
          If you find that _Alpine_ is erroneously displaying blank folder
          lists, try enabling this feature.
          NOTE: Enabling this feature has consequences for the Goto and
          Save commands. Many servers allow access to folders outside the
          area reserved for your personal folders via some reserved
          character, typically '#' (sharp), '~' (tilde) or '/' (slash).
          This mechanism allows, at the Goto and Save prompts, quick
          access to folders outside your personal folder collection
          without requiring a specific collection definition. This
          behavior will generally not be available when this feature is
          enabled.
          This feature is displayed as "Compensate for Deficient IMAP
          servers".
   _enable-mail-check-cue_
          If set, this will cause an asterisk to appear in the upper
          left-hand corner of the screen whenever _Alpine_ checks for new
          mail, and two asterisks whenever _Alpine_ saves (checkpoints)
          the state of the current mailbox to disk.
   _enable-mailcap-param-substitution_
          If set, this will allow mailcap named parameter substitution to
          occur in mailcap entries. By default, this is turned off to
          prevent security problems which may occur with some incorrect
          mailcap configurations. For more information, RFC1524 and look
          for "named parameters" in the text of the RFC.
          This feature is displayed as "Enable Mailcap Parameter
          Substitution".
   _enable-mouse-in-xterm_
          This feature controls whether or not an X terminal mouse can be
          used with _Alpine_. If set, and the $DISPLAY variable indicates
          that an X terminal is being used, the left mouse button on the
          mouse can be used to select text or commands. Clicking on a
          command at the bottom of the screen will behave as if you had
          typed that command. Clicking on an index line will move the
          current message highlight to that line. Double-clicking on an
          index line will view the message. Double-clicking on a link will
          view the link.
          This type of mouse support will also work in some terminal
          emulators which are not actually X terminals, but which have
          extra code to support the xterm style mouse. For those emulators
          you not only need to turn this feature on but you also have to
          set the $DISPLAY environment variable even though it isn't
          needed for your terminal. That will cause _Alpine_ to think that
          it is an xterm and to properly interpret the escape sequences
          sent by the mouse.
          Note: if this feature is set, the behavior of X terminal
          cut-and-paste is also modified. It is sometimes possible to hold
          the shift key down while clicking left or middle mouse buttons
          for the normal xterm cut/paste operations. There is also an
          _Alpine_ command to toggle this mode on or off. The command is
          Ctrl-\ (Control-backslash).
   _enable-msg-view-addresses_
          This feature modifies the behavior of _Alpine_'s "Message Text"
          screen. Setting this feature causes _Alpine_ to select possible
          email addresses from the displayed text and display them in
          boldface for selection.
          The first available email address is displayed in inverse. This
          is the "selected" address. Pressing _RETURN_ will cause _Alpine_
          to enter the message composition screen with the To field filled
          in with the selected address.
          Use the up and down arrow keys to change which of the addresses
          displayed in boldface is the current selection.
          This feature is displayed as "Enable Message View Address
          Links".
   _enable-msg-view-attachments_
          This feature modifies the behavior of _Alpine_'s "Message Text"
          screen. Setting this feature causes _Alpine_ to present
          attachments in boldface. The first available attachment is
          displayed in inverse. This is the "selected" attachment.
          Pressing _RETURN_ will cause _Alpine_ to display the selected
          attachment. Use the up and down arrow keys to change which of
          the attachments displayed in boldface is the current selection.
          Speaking of arrow keys, the Up and Down Arrows will select the
          next and previous attachments if one is available on the screen
          for selection. Otherwise, they will simply adjust the viewed
          text one line up or down.
          Similarly, when selectable items are present in a message, the
          Ctrl-F key can be used to select the next item in the message
          independent of which portion of the viewed message is currently
          displayed. The Ctrl-B key can be used to select the previous
          item in the same way.
          This feature is displayed as "Enable Message View Attachment
          Links".
   _enable-msg-view-forced-arrows_
          This feature modifies Up and Down arrow key behavior in
          _Alpine_'s "Message Text" screen when selectable Attachments,
          URL's, or web-hostnames are presented. _Alpine_'s usual behavior
          is to move to the next or previous selectable item if currently
          displayed or simply to adjust the screen view by one line if the
          next selectable line is off the screen.
          Setting this feature causes the Up and Down arrow keys to behave
          as if no selectable items were present in the message.
          Note, the _Ctrl-F_ (next selectable item) and _Ctrl-B_ (previous
          selectable item) functionality is unchanged.
          This feature is displayed as "Enable Message View Forced
          Arrows".
   _enable-msg-view-urls_
          This feature modifies the behavior of _Alpine_'s "Message Text"
          screen. When this feature is set (the default) _Alpine_ will
          select possible URLs from the displayed text and display them in
          boldface for selection.
          The first available URL is displayed in inverse. This is the
          "selected" URL. Pressing _RETURN_ will cause _Alpine_ to display
          the selected URL via either built-in means as with mailto:,
          imap:, news:, and nntp:, or via an external application as
          defined by the url-viewers variable.
          Use the up and down arrow keys to change which of the URLs
          displayed in boldface is the current selection.
          This feature is displayed as "Enable Message View URL Links".
   _enable-msg-view-web-hostnames_
          This feature modifies the behavior of _Alpine_'s "Message Text"
          screen. When this feature is set (the default) _Alpine_ will
          select possible web hostnames from the displayed text and
          display them in boldface for selection.
          The first available hostname is displayed in inverse. This is
          the "selected" hostname. Pressing _RETURN_ will cause _Alpine_
          to display the selected hostname via an external application as
          defined by the url-viewers variable.
          Use the up and down arrow keys to change which of the hostnames
          displayed in boldface is the current selection.
          This feature is displayed as "Enable Message View Web Hostname
          Links".
   _enable-multiple-newsrcs_
          This feature makes it so _Alpine_ can use multiple newsrcs based
          on the news server being connected to, which allows for separate
          lists of subscribed-to newsgroups. When this feature is not set,
          there is only one list of newsgroups.
          Under this feature, the name of a newsrc is based on the news
          server. For example, if your newsrc-path is set to ".newsrc",
          and the news server you are connecting to is news.example.com,
          then the newsrc to be used is .newsrc-news.example.com. Setting
          this feature for the first time will allow for the option of
          using your old newsrc the next time you read news.
          If this feature is set, then the feature
          Mult-Newsrc-Hostnames-As-Typed also may affect the name of the
          newsrc file that is used.
   _enable-newmail-in-xterm-icon_
          This feature controls whether or not _Alpine_ will attempt to
          announce new mail arrival when it is running in an X terminal
          window and that window is iconified. If set, and the $DISPLAY
          variable indicates that an X terminal is being used, _Alpine_
          will send appropriate escape sequences to the X terminal to
          modify the label on _Alpine_'s icon to indicate that new mail
          has arrived. _Alpine_ will also modify the _Alpine_ window's
          title to indicate new mail. See also
          Enable-Newmail-Short-Text-in-Icon.
   _enable-newmail-short-text-in-icon_
          This feature controls the text to be displayed in an icon in the
          event of a new message arrival. Normally, the message will be
          the one that is displayed on the screen. This feature shortens
          the message to a count of the number of new messages in
          brackets. This may be more useful for those who use the window's
          title bar in the task bar as a new mail indicator. This feature
          is only useful if the Enable-Newmail-in-Xterm-Icon is also set.
          Like the Enable-Newmail-in-Xterm-Icon feature, this feature is
          only relevant when run in an xterm environment.
   _enable-partial-match-lists_
          This feature affects the subcommands available when _Sav_ing or
          Opening a new folder. If set, the subcommand _^X ListMatches_
          will be available. This command allows you to type in a
          substring of the folder you are looking for and when you type
          _^X_ it will display all folders which contain that substring in
          their names. This feature is set by default.
   _enable-print-via-y-command_
          By default, _Alpine_'s print command is available by pressing
          the _%_ key. In older versions of _Pine_, the print command was
          accessed by pressing the _Y_ key.
          Enabling this feature will cause _Alpine_ to recognize both the
          old command, _Y_, and the new _%_ method for invoking printing.
          Note, key menu labels are not changed as a result of enabling
          this feature.
   _enable-reply-indent-string-editing_
          This feature affects the Reply command's "Include original
          message in Reply?" prompt. When enabled, it causes the "Edit
          Indent String" sub-command to appear which allows you to edit
          the string _Alpine_ would otherwise use to denote included text
          from the message being replied to.
          Thus, you can change _Alpine_'s default message quote character
          (usually an angle bracket) on a per message basis. So you could
          change your quoted message to look, for example, like this:
On Tues, 26 Jan 1999, John Q. Smith wrote:

John: I just wanted to say hello and to congratulate you
John: on a job well done!
          The configuration option "reply-indent-string" may be used to
          change what appears as the default string to be edited.
          NOTE: Edited reply-indent-strings only apply to the message
          currently being replied to.
   _enable-rules-under-take_
          Normally, the Take command takes addresses from a message and
          helps you put them into your Address Book. If you use Rules for
          Indexcolors, Roles, Filtering, or Scoring; you may find it
          useful to be able to Take information from a message's headers
          and put it into a new Rule. When this feature is set, you will
          be given an extra prompt which gives you the choice to Take into
          the Address Book or Take into a rule.
          This feature is displayed as "Enable Take Rules".
   _enable-search-and-replace_
          If set _Alpine_'s composer offers the _R Replace_ command option
          inside the _W WhereIs_ command.
   _enable-sigdashes_
          If set and a _signature-file_ exists, the line consisting of the
          three characters "-- " (dash dash space) is included before the
          signature. This only happens if the signature doesn't already
          contain such a line.
          In addition, when you Reply or Followup to a message containing
          one of these special lines and choose to include its text,
          _Alpine_ will observe the convention of not including text beyond
          the special line in your reply.
   _enable-suspend_
          Setting this feature will allow you to type _^Z_ and temporarily
          suspend _Alpine_. Not available on _PC-Alpine_.
   _enable-tab-completion_
          This feature enables the _TAB_ key when at a prompt for a
          filename. In this case, _TAB_ will cause the partial name
          already entered to be automatically completed, provided the
          partial name is unambiguous. This feature is set by default.
          Similarly, this feature also enables TAB completion of address
          book nicknames when at a prompt for a nickname, or when typing
          in an address field in the composer.
   _enable-take-export_
          Normally, the Take command takes addresses from a message and
          helps you put them into your Address Book. When this feature is
          set, you will be given an extra prompt which gives you the
          choice to Take addresses into a file instead of your Address
          Book. Only the user@domain_name part of the address is put in
          the file.
   _enable-tray-icon_
          _PC-Alpine_ only. This option restores a behavior of previous
          versions of PC-Alpine. These versions, when started, installed a
          PC-Alpine icon in the notification tray of Window's Taskbar. The
          primary use of this icon was to indicate new mail arrival by
          turning red (while the Taskbar icon remained green).
          Additionally, the icon now changes to yellow to signify that a
          mail folder has been closed unexpectedly.
          Rather than add another icon to the Taskbar, this version of
          PC-Alpine will color its Taskbar entry's icon red (as well as
          the icon in the Window Title). This feature is only provided for
          backwards compatibility.
   _enable-unix-pipe-cmd_
          This feature enables the _| Pipe_ command that sends the current
          message to the specified Unix command for external processing.
          This feature is displayed as "Enable Unix Pipe Command".
   _enable-verbose-smtp-posting_
          This feature controls an aspect of _Alpine_'s message sending.
          When enabled, _Alpine_ will send a VERB (i.e., VERBose) command
          early in the posting process intended to cause the server SMTP
          to provide a more detailed account of the transaction. This
          feature is typically only useful to system administrators and
          other support personnel as an aid in troublshooting problems.
          Note, this feature relies on a specific capability of the
          system's mail transport agent or configured smtp-server.
   _expanded-view-of-addressbooks_
          If multiple address books (either personal or global) are
          defined, and you wish to have them all expanded implicitly upon
          entering the ADDRESS BOOK screen, then set this feature. This
          feature will have no effect unless the feature
          combined-addrbook-display is also set.
   _expanded-view-of-distribution-lists_
          If this feature is set, then distribution lists in the address
          book screen will always be expanded automatically.
   _expanded-view-of-folders_
          If multiple folder collections are defined, and you wish to have
          them all expanded implicitly upon entering the FOLDER LIST
          screen, then set this feature. This feature will have no effect
          unless the feature combined-folder-display is also set.
   _expose-hidden-config_
          The purpose of this feature is to allow you to change
          configuration features and variables which are normally hidden.
          This is particularly useful if you are using a remote
          configuration file, where it is difficult to edit the file
          manually, but it may also be used on a local pinerc
          configuration file.
          If set, most configuration variables and features which are
          normally hidden from view will show up in the
          Setup/Configuration screen. They will be at the bottom of the
          configuration screen. You can find them by searching for the
          word "hidden".
          Note that this is an advanced feature which should be used with
          care. The reason that this part of the configuration is normally
          hidden is because there is a significant potential for causing
          problems if you change these variables. If something breaks
          after a change try changing it back to see if that is what is
          causing the problem. There are also some variables which are
          normally hidden because they are manipulated through _Alpine_ in
          other ways. For example, the "address-book" variable is normally
          set using the Setup/AddressBooks screen, so there is little
          reason to edit it directly. The "incoming-folders" variable is
          normally changed by using the Add, Delete, and Rename commands
          in the FOLDER LIST screen, and the "last-time-prune-questioned"
          variable is normally used internally by _Alpine_ and not set
          directly by the user.
   _expunge-only-manually_
          Normally, when you close a folder which contains deleted
          messages you are asked if you want to expunge those messages
          from the folder permanently. If this feature is set, you won't
          be asked and the deleted messages will remain in the folder. If
          you choose to set this feature you will have to expunge the
          messages manually using the eXpunge command, which you can use
          while in the MESSAGE INDEX screen. If you do not expunge deleted
          messages the size of your folder will continue to increase until
          you are out of disk space.
   _expunge-without-confirm_
          If set, you will not be prompted to confirm your intent before
          the expunge takes place. Actually, you will still be prompted
          for confirmation if the folder is not the _INBOX_ folder or
          another folder in the Incoming Folders collection. See the
          _expunge-without-confirm-everywhere_ feature which follows.
          This feature is displayed as "Expunge Without Confirming".
   _expunge-without-confirm-everywhere_
          The regular _expunge-without-confirm_ feature actually only
          works for the _INBOX_ folder and for other folders in the
          "Incoming Folders" collection. If this feature is set then you
          also won't be prompted to confirm expunges for all other
          folders.
          This feature is displayed as "Expunge Without Confirming
          Everywhere".
   _fcc-on-bounce_
          If set, normal Fcc (File Carbon Copy) processing will be done
          for bounced messages, just as if you had composed a message to
          the address you are bouncing to. If not set, no Fcc of the
          message will be saved.
          This feature is displayed as "Include Fcc When Bouncing
          Messages".
   _fcc-only-without-confirm_
          This features controls an aspect of _Alpine_'s composer. The
          only time this feature will be used is if you attempt to send
          mail which has no recipients but does have an Fcc. Normally,
          _Alpine_ will ask if you really mean to copy the message only to
          the Fcc. That is, it asks if you really meant to have no
          recipients. If this feature is set, you will _not_ be prompted
          to confirm your intent to make only a copy of a message with no
          recipients.
          This feature is closely related to
          warn-if-blank-to-and-cc-and-newsgroups. The difference between
          this feature and that feature is that this feature considers a
          Bcc to be a recipient while that feature will ask for
          confirmation even if there is a Bcc when there is no To, Cc, or
          Newsgroup. The default values also differ. This feature defaults
          to asking the question and you have to turn it off. The
          warn-if-blank-to-and-cc-and-newsgroups feature defaults to not
          asking unless you turn it on.
          This feature is displayed as "Send to Fcc Only Without
          Confirming".
   _fcc-without-attachments_
          This features controls the way FCC's (File Carbon Copies) are
          made of the messages you send.
          Normally, _Alpine_ saves an exact copy of your message as it was
          sent. When this feature is enabled, the "body" of the message
          you send (the text you type in the composer) is preserved in the
          copy as before, however all attachments are replaced with text
          explaining what had been sent rather than the attachments
          themselves.
          This feature also affects _Alpine_'s "Send ?" confirmation
          prompt in that a new "^F Fcc Attchmnts" option becomes available
          which allows you to interactively set whether or not attachments
          are saved to the Fcc'd copy.
          This feature is displayed as "Fcc Does Not Include Attachments".
   _force-arrow-cursor_
          This feature affects _Alpine_'s MESSAGE INDEX display routine.
          If set, the normal inverse-video cursor will be replaced by a
          simple "arrow" cursor, which normally occupies the second column
          of the index display.
          This is the same index cursor you get if you turn on
          Assume-Slow-Link, but the index line coloring will still be
          present if this feature is turned on and Assume-Slow-Link is
          off.
          An alternative version of the Arrow cursor is available by
          including the ARROW token in the Index-Format option.
          It ought to be the case that this feature also affects the
          ATTACHMENT INDEX, but that is not implemented.
   _hide-nntp-path_
          Normally the Path header that _Alpine_ generates when posting to
          a newsgroup contains the name of the computer from which the
          message is being sent and the user name. Some believe that this
          information is used by spammers. If this feature is set, that
          information will be replaced with the text

                                not-for-mail
          instead.
          It should be noted that many servers being connected to will
          still reveal the information that this feature attempts to
          protect.
   _include-attachments-in-reply_
          If set, any MIME attachments that were part of the original
          message will automatically be included in a _Reply_.
   _include-header-in-reply_
          If set, and a message being replied to is included in the
          _Reply_, then headers from that message will also be part of the
          reply.
   _include-text-in-reply_
          Normally, _Alpine_ will ask whether you wish to include the
          original message in your _Reply_. If this feature is set and the
          feature enable-reply-indent-string-editing is _not_ set, then
          the original message will be included in the reply
          automatically, without prompting.
   _incoming-checking-includes-total_
          This option has no effect unless the feature
          enable-incoming-folders-checking is set, which in turn has no
          effect unless incoming-folders is set.
          When incoming folder checking is turned on the default is to
          display the number of unseen messages in each folder. More
          precisely, it is the number of undeleted unseen messages. Using
          this option you may also display the total number of messages in
          each folder. Instead of a single number representing the number
          of unseen messages you will get two numbers separated by a slash
          character. The first is the number of unseen messages and the
          second is the total number of messages.
          You may also use the recent message count instead of the unseen
          message count by turning on the feature
          incoming-checking-uses-recent.
   _incoming-checking-uses-recent_
          This option has no effect unless the feature
          enable-incoming-folders-checking is set, which in turn has no
          effect unless incoming-folders is set.
          When incoming folder checking is turned on the default is to
          display the number of unseen messages in each folder. More
          precisely, it is the number of undeleted unseen messages. Using
          this option you may display the number of recent messages
          instead of the number of unseen messages. A message is only
          counted as recent if this is the first session to see it, so the
          recent count might be less than the unseen count. The difference
          between the two would be accounted for by the unseen messages in
          the folder which were there previously but have not been looked
          at yet.
          If you simultaneously run more than one email client at a time
          (for example, you run more than one _Alpine_ in parallel) then
          turning this feature on can cause some confusion. The confusion
          stems from the fact that each message is only considered to be
          recent in one session. That means that the counts of new
          messages may be different in the two _Alpine_s running side by
          side, because each incoming message will only be counted as
          recent in one of the two sessions.
          You may also display the total number of messages in each folder
          by using the incoming-checking-includes-total option.
   _ldap-result-to-addrbook-add_
          This is only available if _Alpine_ was linked with an LDAP
          library when it was compiled. If both the per-directory-server
          option use-implicitly-from-composer and this feature are set,
          then when an implicit directory lookup is done from the composer
          you will automatically be prompted to add the result of the
          directory lookup to your address book.
          This feature is displayed as "LDAP Result to Addressbook Add".
   _maildrops-preserve-state_
          This feature affects the way Mail Drops work. Normally, when
          mail is moved from a Mail Drop folder to a destination folder,
          the state changes that have taken place since the mail was
          originally delivered are lost. Any Seen/New, Answered,
          Important/Flagged state that has changed will be ignored. All of
          the mail will be considered unSeen, unAnswered, and unImportant
          after it is moved.
          If this feature is set, then the state changes will not be lost.
          In any case, messages which are already marked Deleted when the
          mail is to be copied from the Mail Drop will be ignored.
   _mark-fcc-seen_
          This features controls the way FCCs (File Carbon Copies) are
          made of the messages you send. Normally, when _Alpine_ saves a
          copy of a message you sent as an Fcc, that copy will be marked
          as Unseen. When you look at the folder it was saved in the
          message will appear to be a New message until you read it. When
          this feature is enabled, the message will be marked as having
          been Seen.
   _mark-for-cc_
          This feature affects _Alpine_'s MESSAGE INDEX display. By
          default, a '+' is displayed in the first column if the message
          is addressed directly to you. When this feature is set and the
          message is not addressed to you, then a '-' character is
          displayed if the message is instead Cc'd directly to you.
   _mult-newsrc-hostnames-as-typed_
          This feature will be of little use to most users. It has no
          effect unless the feature Enable-Multiple-Newsrcs is set. When
          the Enable-Multiple-Newsrcs feature is set then the setting of
          this feature may have an effect on the names of the newsrc files
          used. Normally, the name of the news server will be
          canonicalized before it is used in the newsrc file name. For
          example, if you type the news server name

                                 servername
          it is likely that the canonical name will be something like

                           servername.example.com
          Or it may be the case that

                           servername.example.com
          is really an alias (a DNS CNAME) for

                            othername.example.com
          If this feature is not set, then the canonicalized names will be
          used. If this feature is set, then the name you typed in (or put
          in your configuration) will be used.
          This feature is displayed as "Multiple Newsrc Hostnames as
          Typed".
   _news-approximates-new-status_
          This feature causes certain messages to be marked as _New_ in
          the MESSAGE INDEX of newsgroups. This feature is set by default.
          When opening a newsgroup, _Alpine_ will consult your _newsrc_
          file and determine the last message you have previously disposed
          of via the _D_ key. If this feature is set, any subsequent
          messages will be shown in the Index with an _N_, and the first
          of these messages will be highlighted. Although this is only an
          approximation of true _New_ or _Unseen_ status, it provides a
          useful cue to distinguish more-or-less recent messages from
          those you have seen previously, but are not yet ready to mark
          deleted.
          Background: your _newsrc_ file (used to store message status
          information for newsgroups) is only capable of storing a single
          flag, and _Alpine_ uses this to record whether or not you are
          "done with" a message, as indicated by marking the message as
          _Deleted_. Unfortunately, this means that _Alpine_ has no way to
          record exactly which messages you have previously seen, so it
          normally does not show the _N_ status flag for any messages in a
          newsgroup. This feature enables a starting _approximation_ of
          seen/unseen status that may be useful.
   _news-deletes-across-groups_
          This feature controls what _Alpine_ does when you delete a
          message in a newsgroup that appears in more than one newsgroup.
          Such a message is sometimes termed a "crossposting" in that it
          was posted across several newsgroups.
          _Alpine_'s default behavior when you delete such a message is to
          remove only the copy in the current newsgroup from view when you
          use the "Exclude" command or the next time you visit the
          newsgroup.
          Enabling this feature causes _Alpine_ to remove every occurrence
          of the message from all newsgroups it appears in and to which
          you are subscribed.
          NOTE: As currently implemented, enabling this feature may
          increase the time it takes the Expunge command and newsgroup
          closing to complete.
   _news-offers-catchup-on-close_
          This feature controls what _Alpine_ does as it closes a
          newsgroup. When set, _Alpine_ will offer to delete all messages
          from the newsgroup as you are quitting _Alpine_ or opening a new
          folder.
          This feature is useful if you typically read all the interesting
          messages in a newsgroup each time you open it. This feature
          saves you from having to delete each message in a newsgroup as
          you read it or from selecting all the messages and doing an
          aggregate delete before you move on to the next folder or
          newsgroup.
   _news-post-without-validation_
          This feature controls whether the NNTP server is queried as
          newsgroups are entered for posting. Validation over slow links
          (e.g. dialup using SLIP or PPP) can cause delays. Set this
          feature to eliminate such delays.
   _news-read-in-newsrc-order_
          This feature controls the order that newsgroups will be
          presented. If set, they will be presented in the same order as
          they occur in your _newsrc_ file. If not set, the newsgroups
          will be presented in alphabetical order.
   _next-thread-without-confirm_
          This feature controls an aspect of _Alpine_'s Next and Prev
          commands in the case where you are using one of the
          "separate-index-screen" styles for the configuration option
          threading-index-style and currently have the folder sorted by a
          Threaded or OrderedSubject sort. When you are Viewing a
          particular thread you have a MESSAGE INDEX of only the messages
          in that thread. If you press the Next command with the last
          message in the thread highlighted you will normally be asked if
          you want to "View next thread?", assuming there is a next thread
          to view. If this feature is set it will be assumed that you
          always want to view the next thread and you won't be asked to
          confirm that. Similarly, if the first message of the thread is
          highlighted and you press the Prev command, this feature will
          prevent the question "View previous thread".
          This feature only has an effect in the MESSAGE INDEX screen. If
          you then view a particular message from that screen and press
          the Next command, you will be sent to the next thread without
          being asked, independent of the setting of this feature.
          The feature auto-open-next-unread, also has some similar
          effects.
          This feature is displayed as "Read Next Thread Without
          Confirming".
   _offer-expunge-of-inbox_
          The INBOX is normally treated differently from regular folders
          in several ways. One of the differences is that the normal
          "close" sequence of events is deferred until _Alpine_ is exited,
          instead of happening when you leave the INBOX to view another
          folder. The "close" sequence normally includes the Expunging of
          deleted messages (either automatically or after a prompt,
          controlled by the features Expunge-Without-Confirm,
          Expunge-Without-Confirm-Everywhere, and Expunge-Only-Manually),
          and the handling of the Read-Message-Folder.
          If this feature is set the "close" sequence handling will take
          place every time you leave the INBOX. The INBOX will still be
          kept open, but the offer to Expunge and the archiving to the
          Read-Message-Folder will take place each time you leave the
          INBOX instead of only once at the end of the session.
   _offer-expunge-of-stayopen-folders_
          This feature is related to the option Stay-Open-Folders. Stay
          Open folders are treated differently from regular folders in
          several ways. One of the differences is that the normal "close"
          sequence of events is deferred until _Alpine_ is exited, instead
          of happening when you leave the folder to view another folder.
          The "close" sequence normally includes the Expunging of deleted
          messages (either automatically or after a prompt, controlled by
          the features Expunge-Without-Confirm,
          Expunge-Without-Confirm-Everywhere, and Expunge-Only-Manually),
          and the handling of Incoming-Archive-Folders.
          If this feature is set the "close" sequence handling will take
          place when you leave the Stay Open folder. The folder will still
          be kept open, but the offer to Expunge and the archiving will
          take place each time you leave the folder instead of only once
          at the end of the session. This feature does not affect the
          INBOX, which will still only be processed when you exit
          _Alpine_.
   _pass-c1-control-characters-as-is_
          It is probably not useful to set this option. This is a legacy
          option left behind "just in case". Multi-byte characters which
          have an octet which has the same value as a control character
          are permitted through whether or not this option is turned on.
          If the feature pass-control-characters-as-is is set, then this
          feature has no effect. However, if you wish to filter out
          regular control characters but pass the so-called C1 control
          characters (0x80 <= char < 0xA0) through unchanged, then you may
          leave pass-control-characters-as-is unset and set this feature.
   _pass-control-characters-as-is_
          It is probably not useful to set this option. This is a legacy
          option left behind "just in case". Multi-byte characters which
          have an octet which has the same value as a control character
          are permitted through whether or not this option is turned on.
          If set, all characters in a message will be sent to the screen.
          Normally, control characters are automatically suppressed in
          order to avoid inadvertently changing terminal setup parameters.
          Control characters are usually displayed as two character
          sequences like

                                     ^C
          for Control-C,

                                     ^[
          for ESCAPE,

                                     ^?
          for DELETE, and

                                     ~E
          for the character with value 133 (0x85). (The DEL character is
          displayed as ^?, regular control characters are displayed as the
          character ^ followed by the character obtained by adding the
          five low-order bits of the character to 0x40, and the C1 control
          characters 0x80 - 0x9F are displayed as the character ~ followed
          by the character obtained by adding the five low-order bits of
          the character to 0x40.) Sometimes, in cases where changing a
          single control character into a two-character sequence would
          confuse _Alpine_'s display routines, a question mark is
          substituted for the control character.
          If you wish to filter out regular control characters but pass
          the so-called C1 control characters (0x80 <= char < 0xA0)
          through unchanged, then you may leave this feature unset and set
          the feature pass-c1-control-characters-as-is instead.
   _predict-nntp-server_
          This feature allows _Alpine_ to assume that the open NNTP server
          at the time of composition is the NNTP server to which the
          message should be posted. This is especially recommended when
          there are multiple News collections. If this feature is not set,
          _Alpine_ will try to post to the first server in the nntp-server
          variable. Setting this feature also negates the need to add News
          collection servers to the nntp-server variable.
          This feature can be especially handy when used in conjunction
          with enable-multiple-newsrcs.
          This option is displayed as "NNTP Server (for news)".
   _prefer-plain-text_
          A message being viewed may contain alternate versions of the
          same content. Those alternate versions are ordered by the
          sending software such that the first alternative is the least
          preferred and the last alternative is the most preferred.
          _Alpine_ will normally display the most-preferred version that it
          knows how to display. This is most often encountered where the
          two alternate versions are a plain text version and an HTML
          version, with the HTML version listed last as the most
          preferred.
          If this option is set, then any plain text version will be
          preferred to all other versions.
   _preopen-stayopen-folders_
          This feature is related to the option Stay-Open-Folders.
          Normally, Stay Open folders are only opened on demand, when the
          user asks to open them. From then on they are kept open for the
          duration of the session. However, if this feature is set, then
          the Stay Open folders will all be opened at startup, at the same
          time that the INBOX is opened.
   _preserve-start-stop-characters_
          This feature controls how special control key characters,
          typically _^S_ and _^Q_, are interpreted when input to _Alpine_.
          These characters are known as the "start" and "stop" characters
          and are sometimes used in communications paths to control data
          flow between devices that operate at different speeds.
          By default, _Alpine_ turns the system's handling of these
          special characters off except during printing. However, if you
          see _Alpine_ reporting input errors such as:

     [ Command "^Q" not defined for this screen. ]
          and, at the same time, see your display become garbled, then it
          is likely that setting this option will solve the problem. Be
          aware, though, that enabling this feature will also cause
          _Alpine_ to ostensibly "hang" whenever the _Ctrl-S_ key
          combination is entered as the system is now interpreting such
          input as a "stop output" command. To "start output" again,
          simply type _Ctrl-Q_.
          This feature is displayed as "Preserve Start/Stop Characters".
   _print-formfeed-between-messages_
          Setting this feature causes a formfeed to be printed between
          messages when printing multiple messages with the _Apply Print_
          command.
   _print-includes-from-line_
          If this feature is set, then the Unix mail style From line is
          included at the start of each message that is printed. This line
          looks something like the following, with the address replaced by
          the address from the From line of the message being printed:

     From user@domain.somewhere.com Mon May 13 14:11:06 1996
   _print-index-enabled_
          This feature controls the behavior of the _Print_ command when
          in the "Folder Index" screen. If set, the _Print_ command will
          give you a prompt asking if you wish to print the message index,
          or the currently highlighted message. If not set, the message
          will be printed.
   _print-offers-custom-cmd-prompt_
          When this feature is set, the _Print_ command will have an
          additional subcommand called _C CustomPrint_. If selected, you
          will have the opportunity to enter any system print command,
          instead of being restricted to using those that have been
          previously configured in the _Setup/Printer_ screen.
          This feature is displayed as "Print Offers Custom Command
          Prompt".
   _prune-uses-yyyy-mm_
          By default, _Alpine_ asks monthly whether or not you would like
          to rename some folders to a new name containing the date. It
          also asks whether or not you would like to delete some old
          folders. See the pruning-rule option for an explanation.
          By default, the name used when renaming a folder looks like

                         <foldername>-<month>-<year>
          For example, the first time you run _Alpine_ in May of 2004, the
          folder "sent-mail" might be renamed to

                             sent-mail-apr-2004
          If this feature is set, the name used will be of the form

                          <foldername>-<yyyy>-<mm>
          where "yyyy" is the year and "mm" is the two-digit month (01,
          02, ..., 12). For the April, 2004 example above, it would
          instead be

                              sent-mail-2004-04
          because April is the 4th month of the year. A reason you might
          want to set this feature is so that the folders will sort in
          chronological order.
   _publiccerts-in-keychain_
          Mac OS X _Alpine_ only.
          If this feature is set the Mac OS X default keychain will be
          used as the place to store public certificates instead of a
          smime-public-cert-directory or a smime-public-cert-container.
          This feature is displayed as "S/MIME -- Public Certs in MacOS
          Keychain".
   _quell-attachment-extension-warn_
          This feature suppresses the extra warning you can get when
          trying to view an attachment for which there is no mime-type
          match. Turning on this feature will just run the program
          according to extension instead of first warning the user that it
          will run according to the file's extension.
          This feature can be used along side
          quell-attachment-extra-prompt to preserve the behavior exhibited
          in _Pine_ versions prior to _Pine_ 4.50.
          This feature is displayed as "Suppress Attachment Extension
          Warning".
   _quell-attachment-extra-prompt_
          By default, when you attempt to view an attachment externally
          from the "Attachment View" screen, you are asked if you really
          want to view the selected attachment.
          If this feature is set, you will _not_ be prompted to confirm
          your selection. Prior to _Pine_ 4.50, the default behavior was
          to not prompt. This feature was added for those wanting to
          preserve that behavior.
          This feature is displayed as "Suppress Attachment Extra Prompt".
   _quell-berkeley-format-timezone_
          POSIX mandates a timezone in UNIX mailbox format folder
          delimiters (the line which begins with From ). Some versions of
          Berkeley mail have trouble with this, and don't recognize the
          line as a message delimiter. If this feature is set, the
          timezone will be left off the delimiter line.
          This feature is displayed as "Suppress Berkeley Format
          Timezone".
   _quell-charset-warning_
          By default, if the message you are viewing contains characters
          that are not representable in your display-character-set then
          _Alpine_ will add a warning to the start of the displayed text.
          If this option is set, then that editorial message will be
          suppressed.
          Setting this feature also suppresses the comment about the
          character set in header lines. For example, when viewing a
          message you might see

                     From: "[ISO-8859-2] Name" <address>
          in the From header if your Character-Set is something other than
          ISO-8859-2. If you set this feature, the comment about the
          character set will no longer be there.
          This feature is displayed as "Suppress Character Set Warning".
   _quell-content-id_
          This feature changes the behavior of _Alpine_ when sending
          messages. It is intended to work around a bug in Microsoft's
          Outlook XP mail user agent. As of this writing, Microsoft has
          acknowledged the bug but has not added it to the Knowledge Base.
          We have been told that there will be a post-SP1 hotfix for
          Outlook XP. This particular bug has bug fix number
          OfficeQFE:4781. The nature of the bug is that messages with
          attachments which contain a Content-ID header (which standard
          _Alpine_ attachments do) do not show the attachment indicator (a
          paperclip) when viewed with Outlook XP. So the user has no
          indication that the message contains an attachment.
          If this feature is set then _Alpine_ will remove most Content-ID
          headers before sending a message. If an attachment is of type
          MESSAGE, then the existing Content-ID headers inside the message
          will be left intact. This would only happen with _Alpine_ if a
          message was forwarded as an attachment or if a message with a
          message attached was forwarded. Similarly if an attachment of
          type MULTIPART/ALTERNATIVE is forwarded, the Content-ID headers
          of the alternative parts will not be removed.
          Because the Content-ID header is a standard part of MIME it is
          possible that setting this feature will break something. For
          example, if an attachment has a Content-ID header which is
          necessary for the correct functioning of that attachment, it is
          possible that _Alpine_ may remove that header when the
          attachment is forwarded. However, it seems fairly safe at this
          time.
          This feature is displayed as "Suppress Content-ID".
   _quell-dead-letter-on-cancel_
          This feature affects _Alpine_'s behavior when you cancel a
          message being composed. _Alpine_'s usual behavior is to write
          the canceled message to a file named dead.letter in your home
          directory (under UNIX; DEADLETR under WINDOWS/DOS) overwriting
          any previous message. Under some conditions (some routine), this
          can introduce a noticeable delay.
          Setting this feature will cause _Alpine_ NOT to write canceled
          compositions into the file called dead.letter.
          This feature affects the newer option Dead-Letter-Files, which
          specifies the number of dead letter files to keep around. If
          this feature is set, then the Dead-Letter-Files option has no
          effect.
          This feature is displayed as "Do Not Save to Deadletter on
          Cancel".
   _quell-empty-directories_
          This feature causes _Alpine_ to remove from the display any
          directories that do not contain at least one file or directory.
          This can be useful to prevent overly cluttered folder lists when
          a collection is stored on a server that treats all names as both
          a folder and a directory.
          Note, enabling this feature can cause surprising behavior! For
          example, you can still use Add to create a directory, but unless
          you immediately enter that directory and create a folder, that
          newly created directory may not be displayed next time you enter
          the folder list.
          This feature is displayed as "Hide Empty Directories".
   _quell-extra-post-prompt_
          This feature causes _Alpine_ to skip the extra question about
          posting a message which may go to thousands of readers when you
          are about to post to a newsgroup.
          This feature is displayed as "Suppress Extra Posting Prompt".
   _quell-filtering-done-message_
          This feature causes _Alpine_ to suppress the "filtering done"
          message.
          This feature is displayed as "Suppress Filtering Done Message".
   _quell-filtering-messages_
          This feature causes _Alpine_ to suppress the messages about
          moving filtered messages and setting flags in messages, due to
          Filter Rules.
          This feature is displayed as "Suppress Filtering Messages".
   _quell-flowed-text_
          _Alpine_ generates flowed text where possible. The method for
          generating flowed text is defined by RFC 3676, the benefit of
          doing so is to send message text that can properly be viewed
          both on normal width displays and on displays with smaller or
          larger than normal screen widths. With flowed text, a space at
          the end of a line tells the receiving mail client that the
          following line belongs to the same paragraph. Quoted text will
          also be affected, with only the innermost level of ">" quoting
          being followed by a space. However, if you have changed the
          "Reply-Indent-String" so that it is not equal to the default
          value of "> ", then quoted text will not be flowed. For this
          reason, we recommend that you leave your "Reply-Indent-String"
          set to the default.
          This feature turns off the generation of flowed text, as it
          might be desired to more tightly control how a message is
          displayed on the receiving end.
          If this feature is _not_ set, you can control on a message by
          message basis whether or not flowed text is generated. You do
          this by typing ^V at the Send confirmation prompt that you get
          after typing ^X to send a message. ^V is a toggle which turns
          flowing off and back on if typed again. If for some reason
          flowing cannot be done on a particular message, then the ^V
          command will not be available. This would be the case, for
          example, if this feature was set, or if your
          "Reply-Indent-String" was set to a non-default value. If the
          feature Send-Without-Confirm is set, then the opportunity to
          control on a message by message basis whether or not flowed text
          is generated is lost.
          When this feature is not set and you have typed ^V to turn off
          flowing, the Send confirmation prompt will change to look like

                         Send message (not flowed)?
          Strip-Whitespace-Before-Send will also turn off the sending of
          flowed text messages, but it differs in that it also trims all
          trailing white space from a message before sending it.
          If alternate editors are used extensively, be aware that a
          message will still be sent flowed if this feature is unset. In
          most cases this will be fine, but if the editor has a "flowed
          text" mode, it would be best to use that.
          This feature is displayed as "Do Not Send Flowed Text".
   _quell-folder-internal-msg_
          This feature determines whether or not _Alpine_ will create
          "pseudo messages" in folders that are in standard Unix or MMDF
          format.
          _Alpine_ will normally create these pseudo messages when they
          are not already present in a standard Unix or MMDF folder. Their
          purpose is to record certain mailbox state data needed for
          correct IMAP and POP server operation, and also for _Alpine_ to
          be able to mark messages as Answered when the Reply has been
          postponed.
          Sites which do not use IMAP/POP for remote mail access, and
          which need to support mail tools that are adversely affected by
          the presence of the pseudo-messages (e.g. some mail notification
          tools) may enable this feature to tell _Alpine_ not to create
          them. Note that _Alpine_'s "Answered" flag capability will be
          adversely affected if this is done.
          Note too that, even if this feature is enabled, _Alpine_ will
          not remove pseudo-messages when it encounters them (e.g. those
          created by UW's imapd or ipopd servers.) This feature has no
          effect on folders that are not in standard Unix or MMDF format,
          as pseudo-messages are not needed in the other formats to record
          mailbox state information.
          This feature is displayed as "Prevent Folder Internal Message".
   _quell-full-header-auto-reset_
          The HdrMode Command normally resets to the default state when
          switching to a new message. For example, if you've used the "H"
          command to turn on Full Headers for a message you are viewing,
          and then you type the Next command to look at the next message,
          the full headers will no longer be shown. Setting this feature
          disables that reset. Instead, the Header Mode remains the same
          from message to message.
          The presence or absence of the HdrMode command is determined by
          the "Enable-Full-Header-Cmd" Feature-List option.
          This feature is displayed as "Suppress Full Header Auto Reset".
   _quell-imap-envelope-update_
          In the MESSAGE INDEX screen, if the open folder is being
          accessed using IMAP, _Alpine_ normally tries to paint the index
          lines on the screen as soon as the information arrives from the
          IMAP server. This means that the index information makes it onto
          the screen more quickly than it otherwise would. This sometimes
          results in behavior that bothers some users. For example, when
          paging to a new page of the index, it may be possible for the
          lines to be painted on the screen in a random order, rather than
          from top to bottom.
          Setting this feature causes _Alpine_ to wait for all of the
          information to be gathered before it paints the index screen.
          Once it collects all of the information, the screen will be
          painted quickly from top to bottom.
          This feature is displayed as "Suppress IMAP Envelope Update".
   _quell-lock-failure-warnings_
          This feature affects _Alpine_'s behavior when it encounters a
          problem acquiring a mail folder lock. Typically, a secondary
          file associated with the mail folder being opened is created as
          part of the locking process. On some systems, such file creation
          has been administratively precluded by the system configuration.
          _Alpine_ issues a warning when such failures occur, which can
          become bothersome if the system is configured to disallow such
          actions. Setting this feature causes _Alpine_ to remain silent
          when this part of lock creation fails.
          WARNING: systems that have been configured in a way that
          precludes locking introduce some risk of mail folder corruption
          when more than one program attempts to modify the mail folder.
          This is most likely to occur to one's _INBOX_ or other "Incoming
          Message Folder".
          This feature is displayed as "Suppress Lock Failure Warnings".
   _Quell-Mailchecks-Composing-Except-Inbox_
          This option is closely related to the Mail-Check-Interval
          option, the Mail-Check-Interval-Noncurrent option, and
          Quell-Mailchecks-Composing-Inbox.
          If this option is set, then the normal new-mail checking which
          happens while you are composing will not happen for folders
          other than your INBOX (which depends on the setting of
          "Quell-Mailchecks-Composing-Inbox").
          You might want to set this option if you are experiencing delays
          while composing which you think might be related to the speed of
          the new-mail checks.
          Even with this option turned on, an occasional new-mail check
          may be done in order to keep the server from killing the
          connection to the folder. For example, IMAP servers may remove a
          connection to a folder if there has been no activity on the
          connection for 30 minutes or more. Instead of letting that
          happen, _Alpine_ will check for new mail before the 30 minutes
          is up even though you have turned on this feature to quell those
          checks.
          Besides new-mail checks, checkpoint operations on the folders
          will also be quelled when you set this option. The purpose of
          checkpointing is to write the changes to a folder out to disk
          periodically in order to avoid losing those changes when system
          or software problems occur. New-mail checking and checkpointing
          while you are not composing are not affected by this option.
          This feature is displayed as "Prevent Mailchecks While Composing
          Except for INBOX".
   _Quell-Mailchecks-Composing-Inbox_
          This option is closely related to the Mail-Check-Interval
          option, the Mail-Check-Interval-Noncurrent option, and
          Quell-Mailchecks-Composing-Except-Inbox.
          If this option is set, then the normal new-mail checking which
          happens while you are composing will not happen for your INBOX.
          Checking of other folders is controlled in a similar way with
          the "Quell-Mailchecks-Composing-Except-Inbox" option.
          You might want to set this option if you are experiencing delays
          while composing which you think might be related to the speed of
          the new-mail checks.
          Even with this option turned on, an occasional new-mail check
          may be done in order to keep the server from killing the
          connection to the folder. For example, IMAP servers may remove a
          connection to a folder if there has been no activity on the
          connection for 30 minutes or more. Instead of letting that
          happen, _Alpine_ will check for new mail before the 30 minutes
          is up even though you have turned on this feature to quell those
          checks.
          Besides new-mail checks, checkpoint operations on the INBOX will
          also be quelled when you set this option. The purpose of
          checkpointing is to write the changes to a folder out to disk
          periodically in order to avoid losing those changes when system
          or software problems occur. New-mail checking and checkpointing
          while you are not composing are not affected by this option.
          This feature is displayed as "Prevent Mailchecks While Composing
          for INBOX".
   _quell-maildomain-warning_
          When your configuration is set up so that your domain name
          contains no dots, it is usually a configuration error. By
          default, _Alpine_ will warn you about this when you start it up.
          You will see a warning message that looks like

                      Incomplete maildomain "<domain>".
          If this feature is set, the warning is turned off. This feature
          is displayed as "Suppress Maildomain Warning".
   _quell-news-envelope-update_
          In the MESSAGE INDEX screen, if the open folder is being
          accessed using NNTP (News), _Alpine_ normally tries to paint the
          index lines on the screen as soon as the information arrives
          from the NNTP server. This means that the index information
          makes it onto the screen more quickly than it otherwise would.
          This sometimes results in behavior that bothers some users. For
          example, when paging to a new page of the index, it may be
          possible for the lines to be painted on the screen in a random
          order, rather than from top to bottom.
          Setting this feature causes _Alpine_ to wait for all of the
          information to be gathered before it paints the index screen.
          Once it collects all of the information, the screen will be
          painted quickly from top to bottom.
          This feature is displayed as "Suppress News Envelope Update".
   _quell-partial-fetching_
          Partial fetching is a feature of the IMAP protocol. By default,
          _Alpine_ will use partial fetching when copying the contents of a
          message or attachment from the IMAP server to _Alpine_. This
          means that the fetch will be done in many small chunks instead
          of one big chunk. The main benefit of this approach is that the
          fetch becomes interruptible. That is, the user can type _^C_ to
          stop the fetch early. In some cases partial fetching may cause a
          performance problem so that the fetching of data takes
          significantly longer when partial fetching is used. Turning on
          this feature will turn off partial fetching.
          This feature is displayed as "Prevent Partial Fetching".
   _quell-personal-name-prompt_
          _PC-Alpine_ only. This feature quells the prompting for a
          personal-name. This prompt normally happens before composing a
          message, and only happens when there is no personal name already
          set.
   _quell-server-after-link-in-html_
          By default, links in HTML text are displayed with the host the
          link references appended, within square brackets, to the link
          text. _Alpine_ does this to help indicate where a link will take
          you, particularly when the link text might suggest a different
          destination.
          Setting this feature will prevent the server name from being
          appended to the displayed text.
          This feature is displayed as "Suppress Server After Link in
          HTML".
   _quell-ssl-largeblocks_
          This feature (_PC-Alpine_ only) changes the behavior of fetching
          messages and attachments so that the message data is fetched in
          chunks no larger than 12K bytes. This works around a bug in
          Microsoft's SSL/TLS support. Some versions of Microsoft SSL are
          not able to read full-sized (16K) SSL/TLS packets. Some servers
          will send such packets and this will cause _PC-Alpine_ to crash
          with the error

              incomplete SecBuffer exceeds maximum buffer size
          Microsoft is aware of the problem and has developed a hotfix for
          it, but as of this writing the hotfix has not yet been added to
          the Knowledge Base.
          This feature is displayed as "Prevent SSL Largeblocks".
   _quell-status-message-beeping_
          If set status messages will never emit a beep.
          This feature is displayed as "Suppress Status Message Beeping".
   _quell-timezone-comment-when-sending_
          Normally, when _Alpine_ generates a Date header for outgoing
          mail, it will try to include the symbolic timezone at the end of
          the header inside parentheses. The symbolic timezone is often
          three characters long, but on some operating systems, it may be
          longer. Apparently there are some SMTP servers in the world
          which will reject an incoming message if it has a Date header
          longer than about 80 characters. If this feature is set, the
          symbolic timezone normally generated by _Alpine_ will not be
          included. You probably don't need to worry about this feature
          unless you run into the problem described above.
          This feature is displayed as "Suppress Timezone Comment When
          Sending".
   _quell-user-id-prompt_
          _PC-Alpine_ only. This feature quells the prompting for a
          user-id if the information can be obtained from the login name
          used to open the INBOX. Normally, this prompt happens before
          composing a message, and only happens when there is no user-id
          already set in the configuration.
          With this feature set, composing a message is only possible
          after establishing a connection to the INBOX.
   _quell-user-lookup-in-passwd-file_
          This feature controls an aspect of _Alpine_'s Composer, and if
          needed, will usually be set by the system manager in _Alpine_'s
          system-wide configuration file. Specifically, if this feature is
          set, _Alpine_ will not attempt to look in the system password
          file to find a Full Name for the entered address.
          Normally, names you enter into address fields (e.g. To: or Cc:)
          are checked against your address book(s) to see if they match an
          address book nickname. Failing that, (in Unix _Alpine_) the name
          is then checked against the Unix password file. If the entered
          name matches a username in the system password file, _Alpine_
          extracts the corresponding Full Name information for that
          individual, and adds that to the address being entered.
          However, password file matching can have surprising (incorrect)
          results if other users of the system do not receive mail at the
          domain you are using. That is, if either the user-domain or
          use-only-domain-name option is set such that the administrative
          domain of other users on the system isn't accurately reflected,
          _Alpine_ should be told that a password file match is
          coincidental, and Full Name info will be incorrect. For example,
          a personal name from the password file could get falsely paired
          with the entered name as it is turned into an address in the
          configured domain.
          If you are seeing this behavior, enabling this feature will
          prevent Unix _Alpine_ from looking up names in the password file
          to find the Full Name for incomplete addresses you enter.
          This feature is displayed as "Prevent User Lookup in Password
          File".
   _quit-without-confirm_
          This feature controls whether or not _Alpine_ will ask for
          confirmation when a _Quit_ command is received.
          This feature is displayed as "Quit Without Confirming".
   _quote-replace-nonflowed_
          This feature, which is only active when Quote-Replace-String is
          also set, enables quote-replacement on non-flowed messages. It
          is off by default because a non-flowed message is more dependent
          on its format, and thus quote-replacement may cause
          less-than-pleasing results. Setting this feature will cause
          quote-replacement similar to that of flowed messages, but with
          the added possibility of long lines being wrapped into new lines
          if the Quote-Replacement-String is longer than the string it is
          replacing, which is "> ".
   _reply-always-uses-reply-to_
          If set, _Alpine_ will not prompt when a message being replied to
          contains a _Reply-To:_ header value, but will simply use its
          value (as opposed to using the _From:_ field's value).
   _return-to-inbox-without-confirm_
          Normally, when you use the TAB command and there are no more
          folders or newsgroups to visit, you are asked if you want to
          return to the INBOX. If this feature is set you will not be
          asked. It will be assumed that you do want to return to the
          INBOX.
          This feature is displayed as "Return to INBOX Without
          Confirming".
   _save-aggregates-copy-sequence_
          This feature will optimize an aggregate copy operation, if
          possible, by issuing a single IMAP _COPY_ command with a list of
          the messages to be copied. This feature is set by default. This
          may reduce network traffic and elapsed time for the Save.
          _However, many IMAP servers (including the UW IMAP server) do not
          preserve the order of messages when this optimization is
          applied._ If this feature is not set, _Alpine_ will copy each
          message individually and the order of the messages will be
          preserved.
          This feature is displayed as "Save Combines Copies (may be out
          of order)".
   _save-partial-msg-without-confirm_
          This feature controls an aspect of _Alpine_'s Save command. By
          default, when you Save a message that has some deleted parts,
          you will be asked to confirm that you want to Save with a prompt
          that looks like:

            Saved copy will NOT include entire message! Continue?
          If this feature is set, you will not be asked.
          This feature is displayed as "Save Partial Message Without
          Confirming".
   _save-will-advance_
          If set, _Save_ will (in addition to copying the current message
          to the designated folder) also advance to the next message.
   _save-will-not-delete_
          If set, _Save_ will not mark the message Deleted (its default
          behavior) after it has been copied to the designated folder.
   _save-will-quote-leading-froms_
          This feature controls an aspect of the _Save_ command (and also
          the way outgoing messages are saved to an FCC folder). If set,
          _Alpine_ will add a leading > character in front of message lines
          beginning with "From" when they are saved to another folder,
          including lines syntactically distinguishable from the type of
          message separator line commonly used on Unix systems.
          The default behavior is that a > will be prepended only to lines
          beginning with "From " that might otherwise be confused with a
          message separator line on Unix systems. If _Alpine_ is the only
          mail program you use, this default is reasonable. If another
          program you use has trouble displaying a message with an
          unquoted From saved by _Alpine_, you should enable this feature.
          This feature only applies to the common Unix mailbox format that
          uses message separator lines beginning with "From ". If _Alpine_
          has been configured to use a different mailbox format (possibly
          incompatible with other mail programs), then this issue does not
          arise, and the feature is irrelevant.
   _scramble-message-id_
          Normally the Message-ID header that _Alpine_ generates when
          sending a message contains the name of the computer from which
          the message is being sent. Some believe that this hostname could
          be used by spammers or could be used by others for nefarious
          purposes. If this feature is set, that name will be transformed
          with a simple Rot13 transformation. The result will still have
          the correct syntax for a Message-ID but the part of the
          MessageID that is often a domain name will not be an actual
          domain name because the letters will be scrambled.
          It is possible (but unlikely?) that some spam detection software
          will use that as a reason to reject the mail as spam. It has
          also been reported that some spam detection software uses the
          fact that there are no dots after the "@" as a reason to reject
          messages. If your _PC-Alpine_ Message-ID is using a name without
          a dot that is because that is what Windows thinks is your "Full
          computer name". The method used to set this varies from one type
          of Windows to another but check under Settings -> Control Panel
          -> System and look for Network Identification or Computer Name
          or something similar. How to set it is beyond the scope of
          _Alpine_.
          This feature is displayed as "Scramble the Message-ID When
          Sending".
   _select-without-confirm_
          This feature controls an aspect of _Alpine_'s _Save_, _Export_,
          and _Goto_ commands. These commands all take text input to
          specify the name of the folder or file to be used, but allow you
          to press _^T_ for a list of possible names. If set, the selected
          name will be used immediately, without further opportunity to
          confirm or edit the name.
          This feature is displayed as "Select Ctrl-T Foldername Without
          Confirming".
   _send-without-confirm_
          By default, when you send or post a message you will be asked to
          confirm with a question that looks something like:

                                Send message?
          If this feature is set, you will _not_ be prompted to confirm
          your intent to send and your message will be sent.
          If this feature is set it disables some possibilities and
          renders some other features meaningless. You will not be able to
          use Sending Filters, Verbose sending mode, Background Sending,
          Delivery Status Notifications, or ^V to turn off the generation
          of flowed text for this message. These options are normally
          available as suboptions in the Send prompt, but with no Send
          prompt the options are gone.
          A somewhat related feature is quell-extra-post-prompt. which may
          be used to eliminate the extra confirmation question when
          posting to a newsgroup.
          This feature is displayed as "Send Without Confirming".
   _separate-folder-and-directory-display_
          This feature affects folder collections wherein a folder and
          directory can have the same name. By default, _Alpine_ displays
          them only once, denoting that it is both a folder and directory
          by appending the folder name with the hierarchy character
          enclosed in square brackets.
          Enabling this feature will cause _Alpine_ to display such names
          separately marking the name representing a directory with a
          trailing hierarchy delimiter (typically the slash, "/",
          character).
          The feature also alters the command set slightly. By default,
          the right-arrow descends into the directory, while hitting the
          Return key will cause the folder by that name to be opened.
          With this feature set, the Return key will open the highlighted
          folder, or enter the highlighted directory.
   _show-cursor_
          If set, the system cursor will move to convenient locations in
          the displays. For example, to the beginning of the status field
          of the highlighted index line, or to the highlighted word after
          a successful _WhereIs_ command. It is intended to draw your
          attention to the _interesting_ spot on the screen.
   _show-plain-text-internally_
          This feature modifies the method _Alpine_ uses to display
          Text/Plain MIME attachments from the Attachment Index screen.
          Normally, the "View" command searches for any externally defined
          (usually via the Mailcap file) viewer, and displays the selected
          text within that viewer.
          Enabling this feature causes _Alpine_ to ignore any external
          viewer settings and always display text with _Alpine_'s internal
          viewer.
   _show-selected-in-boldface_
          This feature controls an aspect of _Alpine_'s aggregate
          operation commands; in particular, the _Select_ and _WhereIs_
          commands. _Select_ and _WhereIs_ (with the _^X_ subcommand) will
          search the current folder for messages meeting a specified
          criteria, and _tag_ the resulting messages with an _X_ in the
          first column of the applicable lines in the "Folder Index". If
          this feature is set, instead of using the _X_ to denote a
          selected message, _Alpine_ will attempt to display those index
          lines in boldface. Whether this is preferable to the _X_ will
          depend on personal taste and the type of terminal being used.
   _show-sort_
          If this feature is set and there is sufficient space on the
          screen, a short indication of the current sort order will be
          added in the titlebar (the top line on the screen), before the
          name of the folder. For example, with the default Arrival sort
          in effect, the display would have the characters

                                     [A]
          added between the title of the screen and the folder name. The
          letters are the same as the letters you may type to manually
          sort a folder with the SortIndex command ($). The letters in the
          table below are the ones that may show up in the titlebar line.

          A _A_rrival
          S _S_ubject
          F _F_rom
          T _T_o
          C _C_c
          D _D_ate
          Z si_Z_e
          O _O_rderedsubject
          E scor_E_
          H t_H_read
          If the sort order is Reversed, the letter above will be preceded
          by the letter "R", for example

                                    [RS]
          means that a Reverse Subject sort is in effect. For the case
          where the sort is in Reverse Arrival order, the "A" is left out,
          and just an "R" is shown.

                                     [R]
          This feature is displayed as "Show Sort in Titlebar".
   _signature-at-bottom_
          If this feature is set, and a message being _Repl_ied to is
          being included in the reply, then the contents of the signature
          file (if any) will be inserted after the included message. This
          feature does not affect the results of a _Forward_ command.
   _single-column-folder-list_
          If set, the "Folder List" screen will list one folder per line
          instead of several per line.
   _slash-collapses-entire-thread_
          Normally, the Collapse/Expand Thread command Collapses or
          Expands the subthread which starts at the currently highlighted
          message, if any. If this feature is set, then the slash command
          Collapses or Expands the _entire_ current thread instead of just
          the subthread.
   _smime-dont-do-smime_
          UNIX _Alpine_ only.
          Setting this feature turns off all of _Alpine_'s S/MIME support.
          You might want to set this if you are having trouble due to the
          S/MIME support.
          + General S/MIME Overview
          This feature is displayed as "S/MIME -- Turn off S/MIME".
   _smime-encrypt-by-default_
          UNIX _Alpine_ only.
          This feature only has an effect if your version of _Alpine_
          includes support for S/MIME. It affects _Alpine_'s behavior when
          you send a message. If this option is set, the "Encrypt" option
          will default to ON when sending messages.
          Only the default value is affected. In any case, you may still
          toggle the Encrypt option on or off before sending with the "E
          Encrypt" command (provided you have a the public digital ID for
          the recipient).
          + General S/MIME Overview
          This feature is displayed as "S/MIME -- Encrypt by Default".
   _smime-remember-passphrase_
          UNIX _Alpine_ only.
          This feature only has an effect if your version of _Alpine_
          includes support for S/MIME. If this option is set, you will
          only have to enter your passphrase for your private key once
          during an _Alpine_ session.
          + General S/MIME Overview
          This feature is displayed as "S/MIME -- Remember S/MIME
          Passphrase".
   _smime-sign-by-default_
          UNIX _Alpine_ only.
          This feature only has an effect if your version of _Alpine_
          includes support for S/MIME. It affects _Alpine_'s behavior when
          you send a message. If this option is set, the "Sign" option
          will default to ON when sending messages.
          Only the default value is affected. In any case, you may still
          toggle the Signing option on or off before sending with the "G
          Sign" command (provided you have a personal digital ID
          certificate).
          + General S/MIME Overview
          This feature is displayed as "S/MIME -- Sign by Default".
   _sort-default-fcc-alpha_
          This feature controls an aspect of _Alpine_'s FOLDER LIST
          screen. If set, the default FCC folder will be sorted
          alphabetically with the other folders instead of appearing right
          after the INBOX.
          This feature is displayed as "Sort Default Fcc Folder
          Alphabetically".
   _sort-default-save-alpha_
          This feature controls an aspect of _Alpine_'s FOLDER LIST
          screen. If set, the default save folder will be sorted
          alphabetically with the other folders instead of appearing right
          after the INBOX (and default FCC folder).
          This feature is displayed as "Sort Default Save Folder
          Alphabetically".
   _spell-check-before-sending_
          When this feature is set, every composed message will be
          spell-checked before being sent.
   _store-window-position-in-config_
          Normally, _PC-Alpine_ will store its window size and position in
          the Windows Registry. This is convenient if you want to use the
          same remote configuration from more than one PC. If you use
          multiple configuration files to start _PC-Alpine_, you may want
          to store the window size and position in the configuration file
          instead of in the Registry. Setting this feature causes that to
          happen.
   _strip-from-sigdashes-on-reply_
          This feature doesn't do anything if the feature enable-sigdashes
          is turned on. However, if the _enable-sigdashes_ feature is not
          turned on, then turning on this feature enables support for the
          convention of not including text beyond the sigdashes line when
          Replying or Following up to a message and including the text of
          that message.
          In other words, this is a way to turn on the signature stripping
          behavior without also turning on the dashes-adding behavior.
   _strip-whitespace-before=send_
          Trailing whitespace is not stripped from a message before
          sending. Trailing whitespace should have no effect on an email
          message, and in flowed text can aid in delimiting paragraphs.
          However, the old behavior of stripping trailing whitespace was
          in place to better deal with older clients that couldn't handle
          certain types of text encodings. This feature restores the old
          behavior
          Trailing whitespace is of aid to flowed-text-formatted messages,
          which are generated by default but can be turned off via the
          quell-flowed-text feature. strip-whitespace-before-send also has
          the effect of turning off sending of flowed text.
          This feature is displayed as "Strip Whitespace Before Sending".
   _suppress-asterisks-in-password-prompt_
          When you are running _Alpine_ you will sometimes be asked for a
          password in a prompt on the third line from the bottom of the
          screen. Normally each password character you type will cause an
          asterisk to echo on the screen. That gives you some feedback to
          know that your typing is being recognized. There is a very
          slight security risk in doing it this way because someone
          watching over your shoulder might be able to see how many
          characters there are in your password. If you'd like to suppress
          the echoing of the asterisks set this feature.
   _suppress-user-agent-when-sending_
          If this feature is set then _Alpine_ will not generate a
          User-Agent header in outgoing messages.
   _tab-checks-recent_
          In a FOLDER LIST screen, the TAB key usually just changes which
          folder is highlighted. If this feature is set, then the TAB key
          will cause the number of recent messages and the total number of
          messages in the highlighted folder to be displayed instead.
          This feature is displayed as "Tab Checks for Recent Messages".
   _tab-uses-unseen-for-next-folder_
          This feature affects _Alpine_'s behavior when using the TAB
          NextNew Command to move from one folder to the next. _Alpine_'s
          usual behavior is to search for folders with _Recent_ messages
          in them. Recent messages are messages which have arrived since
          the last time the folder was opened.
          Setting this feature causes _Alpine_ to search for _Unseen_
          messages instead of Recent messages. Unseen messages remain
          Unseen until you view them (or flag then as Seen with the Flag
          Command). Setting this feature allows you to locate messages you
          have not read instead of only recently received messages. When
          this feature is set, the feature Enable-Fast-Recent-Test will
          have no effect, so the checking may be slower.
          Another reason why you might want to use this feature is that
          _Alpine_ sometimes opens folders implicitly behind the scenes,
          and this clears the Recent status of all messages in the folder.
          One example where this happens is when Saving or filtering a
          message to another folder. If that message has some keywords
          set, then because of some shortcomings in the IMAP
          specification, the best way to ensure that those keywords are
          still set in the saved copy of the message is to open the folder
          and set the keywords explicitly. Because this clears the Recent
          status of all messages in that folder the folder will not be
          found by the NextNew command unless this feature is set.
   _tab-visits-next-new-message-only_
          This feature affects _Alpine_'s behavior when using the _TAB_
          key to move from one message to the next. _Alpine_'s usual
          behavior is to select the next _Unread_ message or message
          flagged as _Important_.
          Setting this feature causes _Alpine_ to skip the messages
          flagged as _Important_, and select _Unread_ messages
          exclusively. Tab behavior when there are no new messages left to
          select remains unchanged.
   _termdef-takes-precedence_
          This feature may affect _Alpine_'s low-level input routines.
          Termcap (or terminfo, depending on how your copy of _Alpine_ was
          compiled and linked) is the name of the database which describes
          terminal capabilities. In particular, it describes the sequences
          of characters that various keys will emit.
          An example would be the Up Arrow key on the keyboard. Up Arrow
          is not a distinct character on most Unix systems. When you press
          the Up Arrow key a short sequence of characters are produced.
          This sequence is supposed to be described in the termcap
          database by the "ku" capability (or by the "kcuu1" capability if
          you are using terminfo instead of termcap).
          By default, _Alpine_ defines some terminal escape sequences that
          are commonly used. For example, the sequence "ESC O A" is
          recognized as an Up Arrow key. The sequence "ESC [ A" is also
          recognized as an Up Arrow key. These are chosen because common
          terminals like VT100's or ANSI standard terminals produce these
          sequences when you press the Up Arrow key.
          If your system's termcap (terminfo) database assigns some other
          function to the sequence "ESC O A" it is usually ignored by
          _Alpine_. Also, if your termcap (terminfo) database assigns a
          sequence which doesn't begin with an escape character (ESC) it
          is usually ignored by _Alpine_. This usually works fine because
          most terminals emit the escape sequences that _Alpine_ has
          defined by default. We have also found that it is usually better
          to have these defaults take precedence over the definitions
          contained in the database because the defaults are more likely
          to be correct than the database.
          There are some terminals where this breaks down. If you want
          _Alpine_ to believe the definitions given in your termcap
          (terminfo) database in preference to the defaults the _Alpine_
          itself sets up, then you may turn this feature on. Then,
          sequences of characters which are defined in both termcap
          (terminfo) and in _Alpine_'s set of defaults will be interpreted
          the way that termcap (terminfo) says they should be interpreted.
          Also, if your terminal capabilities database assigns a sequence
          which doesn't begin with escape, it will not be ignored.
   _thread-index-shows-important-color_
          This option affects only the THREAD INDEX screen. Whether or not
          you ever see a THREAD INDEX screen depends on the setting of the
          configuration option threading-index-style and on the sort order
          of the index. If a message within a thread is flagged as
          Important and this option is set, then the entire line in the
          THREAD INDEX will be colored the color of the Index-important
          Symbol, which can be set using the Setup Kolor screen.
   _try-alternative-authentication-driver-first_
          This feature affects how _Alpine_ connects to IMAP servers. It's
          utility has largely been overtaken by events, but it may still
          be useful in some circumstances. If you only connect to modern
          IMAP servers that support "TLS" you can ignore this feature.
          Details:
          By default, _Alpine_ will attempt to connect to an IMAP server
          on the normal IMAP service port (143), and if the server offers
          "Transport Layer Security" (TLS) and _Alpine_ has been compiled
          with encryption capability, then a secure (encrypted) session
          will be negotiated.
          With this feature enabled, before connecting on the normal IMAP
          port, _Alpine_ will first attempt to connect to an alternate
          IMAP service port (993) used specifically for encrypted IMAP
          sessions via the Secure Sockets Layer (SSL) method. If the SSL
          attempt fails, _Alpine_ will then try the default behavior
          described in the previous paragraph.
          TLS negotiation on the normal port is preferred, and supersedes
          the use of SSL on port 993, but older servers may not provide
          TLS support. This feature may be convenient when accessing IMAP
          servers that do not support TLS, but do support SSL connections
          on port 993. However, it is important to understand that with
          this feature enabled, _Alpine_ will _attempt_ to make a secure
          connection if that is possible, but it will proceed to make an
          insecure connection if that is the only option offered by the
          server, or if the _Alpine_ in question has been built without
          encryption capability.
          Note that this feature specifies a per-user (or system-wide)
          default behavior, but host/folder specification flags may be
          used to control the behavior of any specific connection. This
          feature interacts with some of the possible host/folder path
          specification flags as follows:
          The /tls host flag, for example,

                         {foo.example.com/tls}INBOX
          will over-ride this feature for the specified host by bypassing
          the SSL connection attempt. Moreover, with /tls specified, the
          connection attempt will fail if the service on port 143 does not
          offer TLS support.
          The /ssl host flag, for example,

                         {foo.example.com/ssl}INBOX
          will insist on an SSL connection for the specified host, and
          will fail if the SSL service on port 993 is not available.
          _Alpine_ will not subsequently retry a connection on port 143 if
          /ssl is specified.
   _unselect-will-not-advance_
          Normally, when the Unselect current message command (:) is typed
          when the current message is selected, the message will be
          unselected and the next message will become the current message.
          If this feature is set, the cursor will not advance to the next
          message. Instead, the current message will remain the current
          message after unselecting.
   _use-current-dir_
          This feature controls an aspect of several commands. If set,
          your "current working directory" will be used instead of your
          home directory for all of the following operations:
          + _Export_ in the "Folder Index" and "Message Text" screens
          + Attachment _Save_ in the "Message Text" and "Attachment Text"
            screens
          + _^R_ file inclusion in the Composer
          + _^J_ file attachment in the Composer
          This feature is displayed as "Use Current Directory".
   _use-function-keys_
          This feature specifies that _Alpine_ will respond to function
          keys instead of the normal single-letter commands. In this mode,
          the key menus at the bottom of each screen will show function
          key designations instead of the normal mnemonic key.
   _use-regular-startup-rule-for-stayopen-folders_
          This feature affects which message is selected as the current
          message when you enter a Stay Open folder.
          Normally, the starting position for an incoming folder (which
          most Stay Open folders will likely be) is controlled by the
          Incoming-Startup-Rule. However, if a folder is a Stay Open
          folder, when you re-enter the folder after the first time the
          current message will be the same as it was when you left the
          folder. An exception is made if you use the TAB command to get
          to the folder. In that case, the message number will be
          incremented by one from what it was when you left the folder.
          The above special behavior is thought to be useful. However, it
          is special and different from what you might at first expect. If
          this feature is set, then Stay Open folders will not be treated
          specially as far as the startup rule is concerned.
   _use-resent-to-in-rules_
          This feature is turned off by default because turning it on
          causes problems with some deficient IMAP servers. In _Alpine_
          Filters and other types of Rules, if the Pattern contains a To
          header pattern and this feature is turned on, then a check is
          made in the message to see if a Resent-To header is present, and
          that is used instead of the To header. If this feature is not
          turned on, then the regular To header will always be used.
   _use-sender-not-x-sender_
          Normally _Alpine_ on Unix adds a header line labeled
          _X-X-Sender_, if the sender is different from the _From:_ line.
          The standard specifies that this header line should be labeled
          _Sender_, not _X-X-Sender_. Setting this feature causes _Sender_
          to be used instead of _X-X-Sender_. The standard also states
          that the data associated with this header field should not be
          used as a Reply address. Unfortunately, certain implementations
          of mail list management servers will use the Sender address for
          such purposes. These implementations often even recognize the
          _X-Sender_ fields as being equivalent to the _Sender_ field, and
          use it if present. This is why _Alpine_ defaults to
          _X-X-Sender_.
          Note, _PC-Alpine_ always adds either an _X-X-Sender_ line if
          there is an open, remote mailbox, or an _X-Warning:
          UNAuthenticated User_ otherwise
          This feature is displayed as "Use Sender Instead of X-X-Sender".
   _use-subshell-for-suspend_
          This feature affects _Alpine_'s behavior when process suspension
          is enabled and then activated via the _^Z_ key. _Alpine_
          suspension allows one to temporarily interact with the operating
          system command "shell" without quitting _Alpine_, and then
          subsequently resume the still-active _Alpine_ session.
          When the _enable-suspend_ feature is set and subsequently the
          _^Z_ key is pressed, _Alpine_ will normally suspend itself and
          return temporary control to _Alpine_'s parent shell process.
          However, if this feature is set, _Alpine_ will instead create an
          inferior subshell process. This is useful when the parent
          process is not intended to be used interactively. Examples
          include invoking _Alpine_ via the -e argument of the Unix _xterm_
          program, or via a menu system.
          Note that one typically resumes a suspended _Alpine_ by entering
          the Unix _fg_ command, but if this feature is set, it will be
          necessary to enter the _exit_ command instead.
   _use-system-translation_
          UNIX _Alpine_ only. _Alpine_ normally uses its own internal
          software to convert between the multi-byte representation of
          characters and the Unicode representation of those same
          characters ( see the section on International Character Sets).
          It converts from the multi-byte characters your keyboard
          produces to Unicode, and from Unicode to the multi-byte
          characters your display expects. Alpine also uses its own
          internal software to decide how much space on the screen a
          particular Unicode character will occupy.
          Setting this feature tells _Alpine_ to use the system-supplied
          routines to perform these tasks instead. In particular there are
          three tasks and three system routines that will be used for
          these tasks.
          To convert from multi-byte to Unicode the routine

                                  mbstowcs
          is used. To convert from Unicode to multi-byte the routine

                                   wcrtomb
          is used. And to find the screen width a particular Unicode
          character will occupy the routine used is

                                   wcwidth
          This feature has been only lightly tested. The internal routines
          should normally be used unless you run into a problem that you
          think may be solved by using the system routines. Note that your
          environment needs to be set up for these routines to work
          correctly. In particular, the LANG or LC_CTYPE variable in your
          environment will need to be set.
   _vertical-folder-list_
          This feature controls an aspect of _Alpine_'s FOLDER LIST
          screen. If set, the folders will be listed alphabetically down
          the columns rather than across the columns as is the default.
          This feature is displayed as "Use Vertical Folder List".
   _warn-if-blank-subject_
          This feature affects _Alpine_'s behavior when you send a message
          being composed. If this option is set, _Alpine_ will check to
          see if the message about to be sent has a subject or not. If
          not, you will be asked if you want to send the message anyway.
   _warn-if-blank-to-and-cc-and-newsgroups_
          This feature affects _Alpine_'s behavior when you send a message
          being composed. If this option is set, _Alpine_ will check to
          see if the message about to be sent has either a To address, a
          Cc address, or a Newsgroup. If none of these is set, you will be
          asked if you want to send the message anyway.
          This feature is closely related to fcc-only-without-confirm.
          _Alpine_ will normally ask if you want to copy a message only to
          the Fcc. This feature also applies to cases where there is a Bcc
          but still no To, Cc, or Newsgroup. If the
          Fcc-Only-Without-Confirm feature is set and you are sending a
          message with only an Fcc, then you won't be asked about sending
          with a blank To and Cc and Newsgroups header even if this
          feature is set. Similarly, if you have already been asked if you
          want to send to the Fcc only and you have answered Yes, then you
          won't be asked again about sending with blank To, Cc, and
          Newsgroups headers even if this feature is set.

Hidden Config Variables and Features

   There are several configuration variables and features which are
   normally hidden from the user. That is, they don't appear on any of the
   configuration screens. Some of these are suppressed because they are
   intended to be used by system administrators, and in fact may only be
   set in system-wide configuration files. Others are available to users
   but are thought to be of such little value to most users that their
   presence on the Config screens would cause more confusion than help.
   Others are hidden in the Setup/Config screen because they are normally
   configured in one of the other configuration screens. For example, all
   of the colors are hidden because the normal way to configure colors is
   through Setup/Colors not Setup/Config. You may set the feature
   expose-hidden-config to cause most of these hidden variables and
   features to show up at the bottom of the Setup/Config screen.

  Hidden Variables Not Settable by Users

   These variables are settable only in system-wide configuration files.
     * bugs-additional-data
     * bugs-address
     * bugs-fullname
     * forced-abook-entry
     * kblock-passwd-count
     * local-address
     * local-fullname
     * mail-directory
     * standard-printer
     * suggest-address
     * suggest-fullname

  Hidden Variables Which are Settable by Users

   These variables are not shown to users but are settable by means of
   hand editing the personal configuration file. This first group is
   usually maintained by _Alpine_ and there will usually be no reason to
   edit them by hand.
     * last-version-used
     * patterns-filters2
     * patterns-indexcolors
     * patterns-roles
     * patterns-scores2
     * remote-abook-metafile

   This group is usually correct but may be changed by system managers or
   users in special cases.
     * disable-these-authenticators
     * disable-these-drivers
     * last-time-prune-questioned
     * new-version-threshold
     * remote-abook-history
     * remote-abook-validity
     * rsh-command
     * rsh-open-timeout
     * rsh-path
     * sendmail-path
     * ssh-command
     * ssh-open-timeout
     * ssh-path
     * tcp-open-timeout
     * tcp-query-timeout
     * tcp-read-warning-timeout
     * tcp-write-warning-timeout
     * use-function-keys

   System managers are usually interested in setting these in the
   system-wide configuration files, though users may set them if they
   wish.
     * operating-dir
     * user-input-timeout

  Hidden Features Which are Settable by Users

   These are _features_ (as opposed to variables) which users or system
   administrators may set. Some of them only make sense for
   administrators. To turn these on manually, the configuration file
   should be edited and the feature added to the _feature-list_ variable.
   You may set the feature expose-hidden-config to cause these hidden
   features to show up in the Setup/Config screen. They will be at the
   bottom of the screen.
     * disable-config-cmd
     * disable-keyboard-lock-cmd
     * disable-password-cmd
     * disable-pipes-in-sigs
     * disable-pipes-in-templates
     * disable-roles-setup-cmd
     * disable-roles-sig-edit
     * disable-roles-template-edit
     * disable-setlocale-collate
     * disable-shared-namespaces
     * disable-signature-edit-cmd

Retired Variables and Features

   Variables and features that are no longer used by the current _Alpine_
   version. When an obsolete variable is encountered, its value is applied
   to any new corresponding setting. The replaced values include:

   _character-set_
          Replaced by three separate variables: _display-character-set_,
          _keyboard-character-set_, and _posting-character-set_.
   _compose-mime_
   _elm-style-save_
          Replaced by _saved-msg-name-rule_
   _feature-level_
          Replaced by _feature-list._
   _header-in-reply_
          Replaced by _include-header-in-reply_ in the _feature-list._
   _old-style-reply_
          Replaced by _signature-at-bottom_ in the _feature-list._
   _use-old-unix-format-write_
          No replacement.
   _patterns_
          Replaced by four separate patterns variables: _patterns-roles_,
          _patterns-filters_, _patterns-scores_, and
          _patterns-indexcolors_. Since then, _patterns-filters_ has also
          become obsolete and is replaced by _patterns-filters2_;
          _patterns-scores_ is replaced by _patterns-scores2_.
   _save-by-sender_
          Replaced by _saved-msg-name-rule._
   _show-all-characters_
          No replacement, it always works this way now.

Tokens for Index and Replying

   This set of special tokens may be used in the index-format option, in
   the reply-leadin option, in signature files, in template files used in
   roles, and in the folder name that is the target of a Filter Rule. Some
   of them aren't available in all situations.

   The tokens are used as they appear below for the _Index-Format_ option,
   but they must be surrounded by underscores for the _Reply-Leadin_
   option, in signature and template files, and in the target of Filter
   Rules.

  _Tokens Available for all Cases (except Filter Rules)_

   SUBJECT
          This token represents the Subject the sender gave the message.
          Alternatives for use in the index screen are SUBJKEY,
          SUBJKEYINIT, SUBJECTTEXT, SUBJKEYTEXT, and SUBJKEYINITTEXT. You
          may color the subject text in the MESSAGE INDEX screen
          differently by using the Index Subject Color and the Index
          Opening Color. options available from the Setup Kolor screen.

   FROM
          This token represents the personal name (or email address if the
          name is unavailable) of the person specified in the message's
          "From:" header field. You may color the from text in the MESSAGE
          INDEX screen differently by using the Index From Color option
          available from the Setup Kolor screen.

   ADDRESS
          This is similar to the "FROM" token, only it is always the email
          address, never the personal name. For example, "mailbox@domain".

   MAILBOX
          This is the same as the "ADDRESS" except that the domain part of
          the address is left off. For example, "mailbox".

   SENDER
          This token represents the personal name (or email address) of
          the person listed in the message's "Sender:" header field.

   TO
          This token represents the personal names (or email addresses if
          the names are unavailable) of the persons specified in the
          message's "To:" header field.

   NEWSANDTO
          This token represents the newsgroups from the message's
          "Newsgroups:" header field _and_ the personal names (or email
          addresses if the names are unavailable) of the persons specified
          in the message's "To:" header field.

   TOANDNEWS
          Same as "NEWSANDTO" except in the opposite order.

   NEWS
          This token represents the newsgroups from the message's
          "Newsgroups:" header field.

   CC
          This token represents the personal names (or email addresses if
          the names are unavailable) of the persons specified in the
          message's "Cc:" header field.

   RECIPS
          This token represents the personal names (or email addresses if
          the names are unavailable) of the persons specified in both the
          message's "To:" header field and the message's "Cc:" header
          field.

   NEWSANDRECIPS
          This token represents the newsgroups from the message's
          "Newsgroups:" header field _and_ the personal names (or email
          addresses if the names are unavailable) of the persons specified
          in the message's "To:" and "Cc:" header fields.

   RECIPSANDNEWS
          Same as "NEWSANDRECIPS" except in the opposite order.

   INIT
          This token represents the initials from the personal name of the
          person specified in the message's "From:" header field. If there
          is no personal name, it is blank.

   DATE
          This token represents the date on which the message was sent,
          according to the "Date" header field. It has the format MMM DD.
          For example, "Oct 23". The feature convert-dates-to-localtime,
          which adjusts for the timezone the message was sent from, may
          have an affect on the value of this token as well as the values
          of all of the other DATE or TIME tokens. Some of the DATE and
          TIME tokens are displayed in a locale-specific way unless the
          option Disable-Index-Locale-Dates is set.

   SMARTDATE
          This token represents the date on which the message was sent,
          according to the "Date" header field. It is "Today" if the
          message was sent today, "Yesterday" for yesterday, "Wednesday"
          if it was last Wednesday, and so on. If the message is from last
          year and is more than six months old it includes the year, as
          well. There is no adjustment made for different time zones, so
          you'll get the day the message was sent according to the time
          zone the sender was in. See the SMARTDATE alternatives below, as
          well.

   SMARTTIME
          This token represents the most relevant elements of the date on
          which the message was sent (according to the "Date" header
          field), in a compact form. If the message was sent today, only
          the time is used (e.g. "9:22am", "10:07pm"); if it was sent
          during the past week, the day of the week and the hour are used
          (e.g. "Wed09am", "Thu10pm"); other dates are given as date,
          month, and year (e.g. "23Aug00", "9Apr98"). There is no
          adjustment made for different time zones, so you'll get the
          day/time the message was sent according to the time zone the
          sender was in.

   SMARTDATETIME
          This is a combination of SMARTDATE and SMARTTIME. It is
          SMARTDATE unless the SMARTDATE value is "Today", in which case
          it is SMARTTIME. See the SMARTDATETIME alternatives below, as
          well.

   DATEISO
          This token represents the date on which the message was sent,
          according to the "Date" header field. It has the format
          YYYY-MM-DD. For example, "1998-10-23".

   SHORTDATEISO
          This token represents the date on which the message was sent,
          according to the "Date" header field. It has the format
          YY-MM-DD. For example, "98-10-23".

   SHORTDATE1
          This token represents the date on which the message was sent,
          according to the "Date" header field. It has the format
          MM/DD/YY. For example, "10/23/98".

   SHORTDATE2
          This token represents the date on which the message was sent,
          according to the "Date" header field. It has the format
          DD/MM/YY. For example, "23/10/98".

   SHORTDATE3
          This token represents the date on which the message was sent,
          according to the "Date" header field. It has the format
          DD.MM.YY. For example, "23.10.98".

   SHORTDATE4
          This token represents the date on which the message was sent,
          according to the "Date" header field. It has the format
          YY.MM.DD. For example, "98.10.23".

   LONGDATE
          This token represents the date on which the message was sent,
          according to the "Date" header field. It has the format MMM DD,
          YYYY. For example, "Oct 23, 1998".

   SMARTDATE alternatives
          There are several versions of SMARTDATE which are all the same
          except for the way they format dates far in the past. SMARTDATE
          formats the date using the information from your locale settings
          to format the date string. It may end up formatting dates so
          that they look like DATEISO tokens, or SHORTDATE2 tokens, or
          something else entirely. The feature convert-dates-to-localtime
          may have an affect on the values of these tokens. If you want
          more control you may use one of the following.

        SMARTDATE
                If the option Disable-Index-Locale-Dates is not set then
                this will be locale specific. Control this with the
                LC_TIME locale setting on a UNIX system. On Windows the
                Regional Options control panel may be used to set the
                Short date format. At the programming level, the strftime
                routine is what _Alpine_ uses to print the date. If the
                Disable-Index-Locale-Dates option is set then this is
                equivalent to SMARTDATES1.

        SMARTDATEISO
                DATEISO format. See text above.

        SMARTDATESHORTISO
                SHORTDATEISO format.

        SMARTDATES1
                SHORTDATE1 format.

        SMARTDATES2
                SHORTDATE2 format.

        SMARTDATES3
                SHORTDATE3 format.

        SMARTDATES4
                SHORTDATE4 format.

   SMARTDATETIME alternatives
          There are several versions of SMARTDATETIME which are all very
          similar. The ones which end in 24 use a 24-hour clock for
          Today's messages instead of a 12-hour clock. The other variation
          is for the way they format dates far in the past. SMARTDATETIME
          and SMARTDATETIME24 format the date using the information from
          your locale settings to format the date string. It may end up
          formatting dates so that they look like DATEISO tokens, or
          SHORTDATE2 tokens, or something else entirely. The feature
          convert-dates-to-localtime may have an affect on the values of
          these tokens. The possible choices are:

        SMARTDATETIME
                Locale specific. Control this with the LC_TIME locale
                setting on a UNIX system. On Windows the Regional Options
                control panel may be used to set the Short date format. At
                the programming level, the strftime routine is what
                _Alpine_ uses to print the date.

        SMARTDATETIME
                If the option Disable-Index-Locale-Dates is not set then
                this will be locale specific. Control this with the
                LC_TIME locale setting on a UNIX system. On Windows the
                Regional Options control panel may be used to set the
                Short date format. At the programming level, the strftime
                routine is what _Alpine_ uses to print the date. If the
                Disable-Index-Locale-Dates option is set then this is
                equivalent to SMARTDATETIMES1.

        SMARTDATETIME24
                Use TIME24 for Today

        SMARTDATETIMEISO
                DATEISO format. See text above.

        SMARTDATETIMEISO24
                Use TIME24 for Today

        SMARTDATETIMESHORTISO
                SHORTDATEISO format.

        SMARTDATETIMESHORTISO24
                Use TIME24 for Today

        SMARTDATETIMES1
                SHORTDATE1 format.

        SMARTDATETIMES124
                Use TIME24 for Today

        SMARTDATETIMES2
                SHORTDATE2 format.

        SMARTDATETIMES224
                Use TIME24 for Today

        SMARTDATETIMES3
                SHORTDATE3 format.

        SMARTDATETIMES324
                Use TIME24 for Today

        SMARTDATETIMES4
                SHORTDATE4 format.

        SMARTDATETIMES424
                Use TIME24 for Today

   DAYDATE
          This token represents the date on which the message was sent,
          according to the "Date" header field. It looks like "Sat, 23 Oct
          1998". This token is never converted in any locale-specific way.

   PREFDATE
          This token represents the date on which the message was sent,
          according to the "Date" header field. It is your operating
          system's idea of the preferred date representation for the
          current locale. Internally it uses the %x version of the date
          from the strftime routine.

   PREFTIME
          This token represents the time at which the message was sent,
          according to the "Date" header field. It is the preferred time
          representation for the current locale. Internally it uses the %X
          version of the time from the strftime routine.

   PREFDATETIME
          This token represents the date and time at which the message was
          sent, according to the "Date" header field. It is the preferred
          date and time representation for the current locale. Internally
          it uses the %c version of the time from the strftime routine.

   DAY
          This token represents the day of the month on which the message
          was sent, according to the "Date" header field. For example,
          "23" or "9".

   DAY2DIGIT
          This token represents the day of the month on which the message
          was sent, according to the "Date" header field. For example,
          "23" or "09". It is always 2 digits.

   DAYORDINAL
          This token represents the ordinal number which is the day of the
          month on which the message was sent, according to the "Date"
          header field. For example, "23rd" or "9th".

   DAYOFWEEK
          This token represents the day of the week on which the message
          was sent, according to the "Date" header field. For example,
          "Sunday" or "Wednesday".

   DAYOFWEEKABBREV
          This token represents the day of the week on which the message
          was sent, according to the "Date" header field. For example,
          "Sun" or "Wed".

   MONTHABBREV
          This token represents the month the message was sent, according
          to the "Date" header field. For example, "Oct".

   MONTHLONG
          This token represents the month in which the message was sent,
          according to the "Date" header field. For example, "October".

   MONTH
          This token represents the month in which the message was sent,
          according to the "Date" header field. For example, "10" or "9".

   MONTH2DIGIT
          This token represents the month in which the message was sent,
          according to the "Date" header field. For example, "10" or "09".
          It is always 2 digits.

   YEAR
          This token represents the year the message was sent, according
          to the "Date" header field. For example, "1998" or "2001".

   YEAR2DIGIT
          This token represents the year the message was sent, according
          to the "Date" header field. For example, "98" or "01". It is
          always 2 digits.

   TIME24
          This token represents the time at which the message was sent,
          according to the "Date" header field. There is no adjustment
          made for different time zones, so you'll get the time the
          message was sent according to the time zone the sender was in.
          It has the format HH:MM. For example, "17:28".

   TIME12
          This token represents the time at which the message was sent,
          according to the "Date" header field. This time is for a 12 hour
          clock. It has the format HH:MMpm. For example, "5:28pm" or
          "11:13am".

   TIMEZONE
          This token represents the numeric timezone from the "Date"
          header field. It has the format [+-]HHMM. For example, "-0800".

  _Tokens Available Only for Index-Format_

   MSGNO
          This token represents the message's current position in the
          folder which, of course, may change as the folder is sorted or
          new mail arrives.

   STATUS
          This token represents a three character wide field displaying
          various aspects of the message's state. The first character is
          either blank, a '*' for message marked Important, or a '+'
          indicating a message addressed directly to you (as opposed to
          your having received it via a mailing list, for example). When
          the feature mark-for-cc is set, if the first character would
          have been blank then it will instead be a '-' if the message is
          cc'd to you. The second character is typically blank, though the
          arrow cursor may occupy it if either the assume-slow-link or the
          force-arrow-cursor feature is set (or you actually are on a slow
          link). The third character is either D (Deleted), A (Answered),
          N (New), or blank.

          If you are using a threaded view of the index and this message
          is at the top of a collapsed portion of a thread, then this
          token refers to all of the messages in the collapsed portion of
          the thread instead of just the top message. The first character
          will be a '*' if _any_ of the messages in the thread are marked
          Important, else a '+' if any of the messages are addressed to
          you, else a '-' if any of the messages are cc'd to you. The
          third character will be a 'D' if _all_ of the messages in the
          collapsed thread are marked deleted, an 'A' if _all_ of the
          messages in the collapsed thread are marked answered, it will be
          an 'N' if any of the messages are undeleted and unseen, and it
          will be blank otherwise.

   FULLSTATUS
          This token represents a less abbreviated alternative to the
          "STATUS" token. It is six characters wide. The first character
          is '+', '-', or blank, the second blank, the third either '*' or
          blank, the fourth N or blank, the fifth A or blank, and the
          sixth character is either D or blank.

          If you are using a threaded view of the index and this message
          is at the top of a collapsed portion of a thread, then this
          token refers to all of the messages in the collapsed portion of
          the thread instead of just the top message. The first character
          is '+', '-', or blank depending on whether _any_ of the messages
          in the collapsed thread are addressed to you or cc'd to you. The
          third character will be '*' if any of the messages are marked
          Important. The fourth character will be 'N' if all of the
          messages in the thread are New, else 'n' if some of the messages
          in the thread are New, else blank. The fifth character will be
          'A' or 'a' or blank, and the sixth character will be 'D' or 'd'
          or blank.

   IMAPSTATUS
          This token represents an even less abbreviated alternative to
          the "STATUS" token. It differs from "FULLSTATUS" in only the
          fourth character which is an 'N' if the message is new to this
          folder since the last time it was opened _and_ it has not been
          viewed, an 'R' (Recent) if the message is new to the folder and
          has been viewed, a 'U' (Unseen) if the message is not new to the
          folder since it was last opened _but_ has not been viewed, or a
          blank if the message has been in the folder since it was last
          opened and has been viewed.

          If you are using a threaded view of the index and this message
          is at the top of a collapsed portion of a thread, then the
          fourth character will be 'N' if all of the messages in the
          thread are unseen and recent; else 'n' if some of the messages
          in the thread are unseen and recent; else 'U' if all of the
          messages in the thread are unseen and not recent; else 'u' if
          some of the messages in the thread are unseen and not recent;
          else 'R' if all of the messages in the thread are seen and
          recent; else 'r' if some of the messages in the thread are seen
          and recent; else blank.

   SHORTIMAPSTATUS
          This is the same as the last four of the six characters of
          IMAPSTATUS, so the '+' To Me information will be missing.

   SIZE
          This token represents the total size, in bytes, of the message.
          If a "K" (Kilobyte) follows the number, the size is
          approximately 1,000 times that many bytes (rounded to the
          nearest 1,000). If an "M" (Megabyte) follows the number, the
          size is approximately 1,000,000 times that many bytes. Commas
          are not used in this field. This field is seven characters wide,
          including the enclosing parentheses. Sizes are rounded when "K"
          or "M" is present. The progression of sizes used looks like:

           0 1 ... 9999 10K ... 999K 1.0M ... 99.9M 100M ... 2000M

   SIZECOMMA
          This token represents the total size, in bytes, of the message.
          If a "K" (Kilobyte) follows the number, the size is
          approximately 1,000 times that many bytes (rounded to the
          nearest 1,000). If an "M" (Megabyte) follows the number, the
          size is approximately 1,000,000 times that many bytes. Commas
          are used if the number shown is 1,000 or greater. The SIZECOMMA
          field is one character wider than the SIZE field. Sizes are
          rounded when "K" or "M" is present. The progression of sizes
          used looks like:

      0 1 ... 99,999 100K ... 9,999K 10.0M ... 999.9M 1,000M ... 2,000M

   KSIZE
          This token represents the total size of the message, expressed
          in kilobytes or megabytes, as most appropriate. These are 1,024
          byte kilobytes and 1,024 x 1,024 byte megabytes. The progression
          of sizes used looks like:

                0K 1K ... 1023K 1.0M ... 99.9M 100M ... 2047M

   SIZENARROW
          This token represents the total size, in bytes, of the message.
          If a "K" (Kilobyte) follows the number, the size is
          approximately 1,000 times that many bytes. If an "M" (Megabyte)
          follows the number, the size is approximately 1,000,000 times
          that many bytes. If a "G" (Gigabyte) follows the number, the
          size is approximately 1,000,000,000 times that many bytes. This
          field uses only five characters of screen width, including the
          enclosing parentheses. The progression of sizes used looks like:

       0 1 ... 999 1K ... 99K .1M ... .9M 1M ... 99M .1G ... .9G 1G 2G

   DESCRIPSIZE
          This token is intended to represent a more useful description of
          the message than just its size, but it isn't very useful at this
          point. The plus sign in this view means there are attachments.
          Note that including this token in the "Index-Format" could slow
          down the display a little while _Alpine_ collects the necessary
          information.

   SUBJKEY
          This token is the same as the SUBJECT token unless keywords are
          set for the message. In that case, a list of keywords enclosed
          in braces will be prepended to the subject of the message. Only
          those keywords that you have defined in your Keywords option in
          Setup/Config are considered in the list. In other words,
          keywords that have been set by some other means, perhaps by
          another email program, won't show up unless included in
          Keywords. Having this set in the Index-Format will also cause
          the keywords to be prepended to the subject in the MESSAGE TEXT
          screen. If you have given a keyword a nickname (keywords), that
          nickname is displayed instead of the actual keyword. The
          keyword-surrounding-chars option may be used to modify this
          token slightly. It is also possible to color keywords in the
          index using the Setup/Kolor screen.

   SUBJKEYINIT
          This token is the same as the SUBJKEY token except that instead
          of prepending a list of keywords to the subject, a list of first
          initials of keywords will be prepended instead. For example, if
          a message has the keywords _Work_ and _Now_ set (or Work and Now
          are the _Alpine_ nicknames of keywords which are set) then the
          SUBJKEY token would cause a result like

                          {Work Now} actual subject

          whereas the SUBJKEYINIT token would give

                             {WN} actual subject

          Only those keywords that you have defined in your Keywords
          option in Setup/Config are considered in the list. In other
          words, keywords that have been set by some other means, perhaps
          by another email program, won't show up unless included in
          Keywords. The keyword-surrounding-chars option may be used to
          modify this token slightly. It is also possible to color
          keywords in the index using the Setup/Kolor screen.

   SUBJECTTEXT
          Same as SUBJECT but if there is room in the Subject field for
          more text, the opening part of the text of the message is
          displayed after the subject. The time needed to fetch the text
          may cause a performance problem which can, of course, be avoided
          by using the SUBJECT version of the Subject instead. You may
          color this opening text differently by using the Index Opening
          Color option available from the Setup Kolor screen. You may
          adjust the characters that are displayed between the Subject and
          the opening text with the option Opening-Text-Separator-Chars.

   SUBJKEYTEXT
          Same as SUBJKEY but with the opening message text.

   SUBJKEYINITTEXT
          Same as SUBJKEYINIT but with the opening message text.

   OPENINGTEXT
          This is similar to SUBJECTTEXT. Instead of combining the Subject
          and the opening text in a single field in the index screen this
          token allows you to allocate a separate column just for the
          opening text of the message. The time needed to fetch this text
          may cause a performance problem. You may color this opening text
          differently by using the Index Opening Color option available
          from the Setup Kolor screen.

   OPENINGTEXTNQ
          This is very similar to OPENINGTEXT. The NQ stands for No
          Quotes. The only difference is that quoted text (lines beginning
          with >) is deleted. For some messages this may be confusing. For
          example, a message might have a line preceding some quoted text
          that reads something like "On May 8th person A said." That no
          longer makes sense after the quoted text is deleted and it will
          appear that person A said whatever the text after the quote is,
          even though that is really person B talking.

   KEY
          This is a space-delimited list of keywords that are set for the
          message. Only those keywords that you have defined in your
          Keywords option in Setup/Config are considered in the list. In
          other words, keywords that have been set by some other means,
          perhaps by another email program, won't show up unless included
          in Keywords. If you have given a keyword a nickname that
          nickname is displayed instead of the actual keyword. It is also
          possible to color keywords in the index using the Setup/Kolor
          screen. This token defaults to an arbitrary width of 5. You
          should set it to whatever width suits you using something like
          KEY(17) in the Index-Format.

   KEYINIT
          This is a list of keyword initials that are set for the message.
          If you have given a keyword a nickname the initial of that
          nickname is displayed instead of the initial of the actual
          keyword. It is also possible to color keyword initials in the
          index using the Setup/Kolor screen. This token defaults to an
          arbitrary width of 2. You should set it to whatever width suits
          you using something like KEYINIT(3) in the Index-Format.

   PRIORITY
          The X-Priority header is a non-standard header that is used in a
          somewhat standard way by many mail programs. _Alpine_ expects
          the value of this header to be a digit with a value from 1 to 5,
          with 1 being the highest priority and 5 the lowest priority.
          Since this priority is something that the sender sets it is only
          an indication of the priority that the sender attaches to the
          mail and it is therefore almost totally unreliable for use as a
          filtering criterion. This token will display the numeric value
          of the priority if it is between 1 and 5. It will be suppressed
          (blank) if the value is 3, which is normal priority. It is also
          possible to set the color of the PRIORITY field. By default the
          token is colored the same as the index line it is part of. You
          may set it to be another color with the Index Priority Colors
          options available from the Setup Kolor screen.

   PRIORITYALPHA
          This is a more verbose interpretation of the X-Priority field.
          Once again nothing is displayed unless the value of the field is
          1, 2, 4, or 5. The values displayed for those values are:

          1 Highest
          2 High
          4 Low
          5 Lowest

          You may color this token with the Index Priority Colors options.

   PRIORITY!
          This is a one character, non-numeric version of the X-Priority
          field. If the value of the X-Priority header is 1 or 2 an
          exclamation point is displayed. If the value is 4 or 5 a "v"
          (think down arrow) is displayed. You may color this token with
          the Index Priority Colors options.

   ATT
          This is a one column wide field which represents the number of
          attachments a message has. It will be blank if there are no
          attachments, a single digit for one to nine attachments, or an
          asterisk for more than nine. Note that including this token in
          the "Index-Format" could slow down the display a little while
          _Alpine_ collects the necessary information.

   FROMORTO
          This token represents _either_ the personal name (or email
          address) of the person listed in the message's "From:" header
          field, _or_, if that address is yours or one of your alternate
          addresses, the first person specified in the message's "To:"
          header field with the prefix "To: " prepended. If the from
          address is yours and there is also no "To" address, _Alpine_
          will use the address on the "Cc" line. If there is no address
          there, either, _Alpine_ will look for a newsgroup name from the
          "Newsgroups" header field and put that after the "To: " prefix.

   FROMORTONOTNEWS
          This is almost the same as _FROMORTO_. The difference is that
          newsgroups aren't considered. When a message is from you,
          doesn't have a To or Cc, and does have a Newsgroups header; this
          token will be your name instead of the name of the newsgroup
          (like it would be with FROMORTO).

   TEXT
          This is a different sort of token. It allows you to display a
          label within each index line. It will be the same fixed text for
          each line. It is different from all the other tokens in that
          there is no space column displayed after this token. Instead, it
          is butted up against the following field. It also has a
          different syntax. The text to display is given following a colon
          after the word "TEXT". For example,

                                  TEXT:abc=

          would insert the literal text "abc=" (without the quotes) into
          the index display line. You must quote the text if it includes
          space characters, like

                                TEXT:"abc = "

   HEADER
          This allows you to display the text from a particular header
          line in the message. The syntax for this token is substantially
          different from all the others in order that you might be able to
          display a portion of the text following a particular header. The
          header name you are interested in is given following a colon
          after the word "HEADER". For example,

                                HEADER:X-Spam

          would display the text of the X-Spam header, if any. Like for
          other index tokens a width field may (and probably should)
          follow this.

                              HEADER:X-Spam(10)

          displays the first ten characters of the X-Spam header. Unlike
          other index tokens, the syntax for HEADER is more flexible. An
          optional second argument comes after a comma inside the
          parentheses. It specifies the "field" number. By default, the
          field separator is a space character. No extra space characters
          are allowed in the argument list.

                             HEADER:X-Spam(10,2)

          would display the second field, left-justified, in a 10
          character wide field. The second field would consist of all the
          text after the first space up to the next space or the end of
          the header. The default field number is zero, which stands for
          the entire line. There is also an optional third argument which
          is a list of field separators. It defaults to a space character.
          The example

                           HEADER:X-Spam(10,2,:% )

          would cause the field separators to be any of colon, percent, or
          space (there is a space character between the percent and the
          right parenthesis). The first field runs from the start of the
          header value up to the first colon, percent, or space; the
          second goes from there to the next; and so on. In order to use a
          comma character as a field separator you must escape it by
          preceding it with a backslash (\). The same is true of the
          backslash character itself. There is one further optional
          argument. It is an R or an L to specify right or left adjustment
          of the text within the field. The default is to left justify,
          however if you are displaying numbers you might prefer to right
          justify.

          Here's an example of a SpamAssassin header. The exact look of
          the header will vary, but if your incoming mail contains headers
          that look like the following

       X-Spam-Status: Yes, hits=10.6 tagged_above=-999.0 required=7.0
                                tests=BAYE...

          you might want to display the hits value. The first field starts
          with the Y in Yes. To get what you're interested in you might
          use "=" and space as the field separators and display the third
          field, like

                        HEADER:X-Spam-Status(4,3,= )

          or maybe you would break at the dot instead

                       HEADER:X-Spam-Status(2,2,=.,R)

          Another example we've seen has headers that look like

              X-Spam: Gauge=IIIIIII, Probability=7%, Report=...

          Because there are two equals and a comma before the 7% and a
          comma after it, the token

                       HEADER:X-Spam-Status(3,4,=\,,R)

          should display the probability (for example 7% or 83%) right
          justified in a 3-wide field.

   ARROW
          This gives an alternative way to display the current message in
          the MESSAGE INDEX screen. Usually the current message is
          indicated by the line being shown in reverse video. Instead, if
          the ARROW token is included in your Index-Format, the current
          line will include an "arrow" that looks like

                                     ->

          in the ARROW token's field. For all of the non-current messages,
          the ARROW field will be filled with blanks. If you use the
          fixed-field width feature the length of the "arrow" may be
          adjusted. The arrow will be drawn as width-1 dashes followed by
          a greater than sign. For example, if you use ARROW(3) you will
          get

                                     -->

          and ARROW(1) will give you just

                                      >

          It is also possible to set the color of the ARROW field. By
          default (and for non-current messages) the arrow is colored the
          same as the index line it is part of. You may set it to be
          another color with the Index Arrow Color option available from
          the Setup Kolor screen.

   SCORE
          This gives the score of each message. This will be six columns
          wide to accommodate the widest possible score. You will probably
          want to use the Index-Format fixed-field width feature to limit
          the width of the field to the widest score that you use (e.g.
          SCORE(3) if your scores are always between 0 and 999). If you
          have not defined any score rules the scores will all be zero. If
          any of your score rules contain AllText or BodyText patterns
          then including SCORE in the Index-Format may slow down the
          display of the MESSAGE INDEX screen.

  _Tokens Available for all but Index-Format_

   CURNEWS
          This token represents the current newsgroup if there is one. For
          example, "comp.mail.pine".

   MSGID
          This token represents the message ID of the message. This token
          does not work with Filter Rule folder names.

   CURDATE
          This token represents the current date. It has the format MMM
          DD. For example, "Oct 23".

   CURDATEISO
          This token represents the current date. It has the format
          YYYY-MM-DD. For example, "1998-10-23".

   CURDATEISOS
          This token represents the current date. It has the format
          YY-MM-DD. For example, "98-10-23".

   CURPREFDATE
          This token represents the current date. It is your operating
          system's idea of the preferred date representation for the
          current locale. Internally it uses the %x version of the date
          from the strftime routine.

   CURPREFTIME
          This token represents the current time. It is the preferred time
          representation for the current locale. Internally it uses the %X
          version of the time from the strftime routine.

   CURPREFDATETIME
          This token represents the current date and time. It is the
          preferred date and time representation for the current locale.
          Internally it uses the %c version of the time from the strftime
          routine.

   CURTIME24
          This token represents the current time. It has the format HH:MM.
          For example, "17:28".

   CURTIME12
          This token represents the current time. This time is for a 12
          hour clock. It has the format HH:MMpm. For example, "5:28pm" or
          "11:13am".

   CURDAY
          This token represents the current day of the month. For example,
          "23" or "9".

   CURDAY2DIGIT
          This token represents the current day of the month. For example,
          "23" or "09". It is always 2 digits.

   CURDAYOFWEEK
          This token represents the current day of the week. For example,
          "Sunday" or "Wednesday".

   CURDAYOFWEEKABBREV
          This token represents the current day of the week. For example,
          "Sun" or "Wed".

   CURMONTH
          This token represents the current month. For example, "10" or
          "9".

   CURMONTH2DIGIT
          This token represents the current month. For example, "10" or
          "09". It is always 2 digits.

   CURMONTHLONG
          This token represents the current month. For example, "October".

   CURMONTHABBREV
          This token represents the current month. For example, "Oct".

   CURYEAR
          This token represents the current year. For example, "1998" or
          "2001".

   CURYEAR2DIGIT
          This token represents the current year. For example, "98" or
          "01". It is always 2 digits.

   LASTMONTH
          This token represents last month. For example, if this is
          November (the 11th month), it is equal to "10" or if this is
          October (the 10th month), it is "9". It is possible that this
          and the other tokens beginning with LASTMONTH below could be
          useful when used with a Filtering Rule that has the "Beginning
          of Month" option set.

   LASTMONTH2DIGIT
          This token represents last month. For example, if this is
          November (the 11th month), it is equal to "10" or if this is
          October (the 10th month), it is "09". It is always 2 digits.

   LASTMONTHLONG
          This token represents last month. For example, if this is
          November the value is "October".

   LASTMONTHABBREV
          This token represents last month. For example, if this is
          November the value is "Oct".

   LASTMONTHYEAR
          This token represents what the year was a month ago. For
          example, if this is October, 1998, it is "1998". If this is
          January, 1998, it is "1997".

   LASTMONTHYEAR2DIGIT
          This token represents what the year was a month ago. For
          example, if this is October, 1998, it is "98". If this is
          January, 1998, it is "97".

   LASTYEAR
          This token represents last year. For example, if this is 1998,
          it equals "1997". It is possible that this could be useful when
          used with a Filtering Rule that has the "Beginning of Year"
          option set.

   LASTYEAR2DIGIT
          This token represents last year. For example, if this is 1998,
          it equals "97". It is always 2 digits.

   ROLENICK
          This token represents the nickname of the role currently being
          used. If no role is being used, then no text will be printed for
          this token. This token does not work with Filter Rule folder
          names.

  _Token Available Only for Reply-Leadin_

   See the help for the Reply-Leadin option, to see why you might want to
   use this. Since the _Reply-Leadin_ contains free text this token must
   be surrounded by underscores when used.

   NEWLINE
          This is an end of line marker.

  _Token Available Only for Templates and Signatures_

   CURSORPOS
          This token is different from the others. When it is replaced it
          is replaced with nothing, but it sets a _Alpine_ internal
          variable which tells the composer to start with the cursor
          positioned at the position where this token was. If both the
          template file and the signature file contain a "CURSORPOS"
          token, then the position in the template file is used. If there
          is a template file and neither it nor the signature file
          contains a "CURSORPOS" token, then the cursor is positioned
          after the end of the contents of the template file when the
          composer starts up.

Conditional Inclusion of Text for Reply-Leadin, Signatures, and Templates

   Conditional text inclusion may be used with the Reply-Leadin option, in
   signature files, and in template files used in roles. It may _not_ be
   used with the _Index-Format_ option.

   There is a limited if-else capability for including text. The if-else
   condition is based on whether or not a given token would result in
   replacement text you specify. The syntax of this conditional inclusion
   is

            _token_(match_this, if_matched [ , if_not_matched ] )

   The left parenthesis must follow the underscore immediately, with no
   intervening space. It means the token is expanded and the results of
   that expansion are compared against the "match_this" argument. If there
   is an exact match, then the "if_matched" text is used as the
   replacement text. Otherwise, the "if_not_matched" text is used. One of
   the most useful values for the "match_this" argument is the empty
   string, "". In that case the expansion is compared against the empty
   string.

   Here's an example to make it clearer. This text could be included in
   one of your template files:

         _NEWS_("", "I'm replying to email","I'm replying to news")

   If that is included in a template file which you are using while
   replying to a message (because you chose to use the role it was part
   of), and that message has a newsgroup header and a newsgroup in that
   header, then the text

                            I'm replying to news

   will be included in the message you are about to compose. On the other
   hand, if the message you are replying to does not have a newsgroup,
   then the text

                            I'm replying to email

   would be included instead. This would also work in signature files and
   in the "Reply-Leadin" option. If the "match_this", "if_matched", or
   "if_not_matched" arguments contain spaces, parentheses, or commas; they
   have to be quoted with double quotation marks (like in the example
   above). If you want to include a literal quote in the text you must
   escape the quote by preceding it with a backslash character. If you
   want to include a literal backslash character you must escape it by
   preceding it with another backslash.

   The comma followed by "if_not_matched" is optional. If there is no
   "if_not_matched" present then no text is included if the not_matched
   case is true. Here's another example:

            _NEWS_("", "", "This msg was seen in group: _NEWS_.")

   Here you can see that tokens may appear in the arguments. The same is
   true for tokens with the conditional parentheses. They may appear in
   arguments, though you do have to be careful to get the quoting and
   escaping of nested double quotes correct. If this was in the signature
   file being used and you were replying to a message sent to
   comp.mail.pine the resulting text would be:

                 This msg was seen in group: comp.mail.pine.

   If you were replying to a message which wasn't sent to any newsgroup
   the resulting text would be a single blank line. The reason you'd get a
   blank line is because the end of the line is outside of the
   conditional, so is always included. If you wanted to get rid of that
   blank line you could do so by moving the end of line inside the
   conditional. In other words, it's ok to have multi-line "if_matched" or
   "if_not_matched" arguments. The text just continues until the next
   double quotation, even if it's not on the same line.

   Here's one more (contrived) example illustrating a matching argument
   which is not the empty string.

        _SMARTDATE_("Today", _SMARTDATE_, "On _DATE_") _FROM_ wrote:

   If this was the value of your "Reply-Leadin" option and you were
   replying to a message which was sent today, then the value of the
   "Reply-Leadin" would be

                        Today Fred Flintstone wrote:

   But if you were replying to a message sent on Oct. 27 (and that wasn't
   today) you would get

                      On Oct 27 Fred Flintstone wrote:

Per Server Directory Configuration

   This is only available if _Alpine_ was built with LDAP support. If
   that's the case, there will be a Directory option underneath the Setup
   command on the Main Menu. Each server that is defined there has several
   configuration variables which control the behavior when using it.
   _ldap-server_
          This is the name of the host where an LDAP server is running.
          To find out whether your organization has its own LDAP server,
          contact its computing support staff.
   _search-base_
          This is the search base to be used on this server. It functions
          as a filter by restricting your searches in the LDAP server
          database to the specified contents of the specified fields.
          Without it, searches submitted to this directory server may
          fail. It might be something like:
      O = <Your Organization Name>, C = US

          or it might be blank. (Some LDAP servers actually ignore
          anything specified here.)
          If in doubt what parameters you should specify here, contact the
          maintainers of the LDAP server.
   _port_
          This is the TCP port number to be used with this LDAP server. If
          you leave this blank port 389 will be used.
   _nickname_
          This is a nickname to be used in displays. If you don't supply a
          nickname the server name from "ldap-server" will be used
          instead. This option is strictly for your convenience.
   _use-implicitly-from-composer_
          Set this feature to have lookups done to this server implicitly
          from the composer. If an address doesn't look like a
          fully-qualified address, it will be looked up in your address
          books, and if it doesn't match a nickname there, then it will be
          looked up on the LDAP servers which have this feature set. The
          lookups will also be done when using the address completion
          feature (TAB command) in the composer if any of the serves have
          this feature set. Also see the LDAP feature
          lookup-addrbook-contents and the Setup/Config feature
          ldap-result-to-addrbook-add.
   _lookup-addrbook-contents_
          Normally implicit LDAP lookups from the composer are done only
          for the strings you type in from the composer screen. In other
          words, you type in something in the To or CC field and press
          return, then the string is looked up. First that string is
          looked up in your address books. If a match is found there, then
          the results of that match are looked up again. If you place a
          string in your address book that you want to have looked up on
          the LDAP directory server, you need to turn on this feature. If
          you set this feature for a server, you almost always will also
          want to set the use-implicitly-from-composer feature. An example
          might serve to best illustrate this feature.
          If an LDAP lookup of "William Clinton" normally returns an entry
          with an address of pres@whitehouse.gov, then you might put an
          entry in your address book that looks like:
    Nickname     Address
    bill         "William Clinton"

          Now, when you type "bill" into an address field in the composer
          _Alpine_ will find the "bill" entry in your address book. It will
          replace "bill" with "William Clinton". It will then search for
          an entry with that nickname in your address book and not find
          one. If this feature is set, _Alpine_ will then attempt to
          lookup "William Clinton" on the LDAP server and find the entry
          with address pres@whitehouse.gov.
          A better way to accomplish the same thing is probably to use the
          feature save-search-criteria-not-result.
   _save-search-criteria-not-result_
          Normally when you save the results of an LDAP directory lookup
          to your address book the _results_ of the lookup are saved. If
          this feature is set and the entry being saved was found on this
          directory server, then the search _criteria_ is saved instead of
          the _results_ of the search. When this address book entry is
          used in the future, instead of copying the results from the
          address book the directory lookup will be done again. This could
          be useful if the copied result might become stale because the
          data on the directory server changes (for example, the entry's
          email address changes). You probably don't want to set this
          feature if the server is at all slow or unreliable.
          The way this actually works is that instead of saving the email
          address in your address book, _Alpine_ saves enough information
          to look up the same directory entry again. In particular, it
          saves the server name and the distinguished name of the entry.
          It's possible that the server administrators might change the
          format of distinguished names on the server, or that the entry
          might be removed from the server. If _Alpine_ notices this, you
          will be warned and a backup copy of the email address will be
          used. You may want to create a new entry in this case, since you
          will get the annoying warning every time you use the old entry.
          You may do that by Saving the entry to a new nickname in the
          same address book. You will be asked whether or not you want to
          use the backup email address.
          A related feature in the Setup/Config screen is
          ldap-result-to-addrbook-add.
   _disable-ad-hoc-space-substitution_
          Spaces in your input are normally handled specially. Each space
          character is replaced by
     * <SPACE>

          in the search query (but not by "* <SPACE> *"). The reason this
          is done is so the input string
     Greg Donald

          (which is converted to "Greg* Donald") will match the names
          "Greg Donald", "Gregory Donald", "Greg F. Donald", and "Gregory
          F Donald"; but it won't match "Greg McDonald". If the
          "Search-Rule" you were using was "begins-with", then it would
          also match the name "Greg Donaldson".
          Turning on this feature will disable this substitution.
   _search-type_
          This affects the way that LDAP searches are done. In particular,
          this tells the server where to look for the string to be
          matched. If set to "name" then the string that is being searched
          for will be compared with the string in the "Name" field on the
          server (technically, it is the "commonname" field on the
          server). "Surname" means we're looking for a match in the
          "Surname" field on the server (actually the "sn" field).
          "Givenname" really is "givenname" and "email" is the electronic
          mail address (this is actually the field called "mail" or
          "electronicmail" on the server). The other three types are
          combinations of the types listed so far. "Name-or-email" means
          the string should appear in either the "name" field OR the
          "email" field. Likewise, "surname-or-givenname" means "surname"
          OR "givenname" and "sur-or-given-or-name-or-email" means the
          obvious thing.
          This search _type_ is combined with the search rule to form the
          actual search query.
          The usual default value for this option is
          "sur-or-given-or-name-or-email". This type of search may be slow
          on some servers. Try "name-or-email", which is often faster, or
          just "name" if the performance seems to be a problem.
          Some servers have been configured with different attribute names
          for these four fields. In other words, instead of using the
          attribute name "mail" for the email address field, the server
          might be configured to use something else, for example,
          "rfc822mail" or "internetemailaddress". _Alpine_ can be
          configured to use these different attribute names by using the
          four per-server configuration options:
          + email-attribute
          + name-attribute
          + surname-attribute
          + givenname-attribute
   _search-rule_
          This affects the way that LDAP searches are done. If set to
          "equals" then only exact matches count. "Contains" means that
          the string you type in is a substring of what you are matching
          against. "Begins-with" and "ends-with" mean that the string
          starts or ends with the string you type in.
          Spaces in your input are normally handled specially, but you can
          turn that special handling off with the
          disable-ad-hoc-space-substitution feature.
          The usual default value for this option is _begins-with_.
   _email-attribute_
          This is the name of the attribute which is searched for when
          looking for an email address. The default value for this option
          is "mail" or "electronicmail". If the server you are using uses
          a different attribute name for the email address, put that
          attribute name here.
          This will affect the search filter used if your Search-Type is
          one that contains a search for "email". It will also cause the
          attribute value matching this attribute name to be used as the
          email address when you look up an entry from the composer.
   _name-attribute_
          This is the name of the attribute which is searched for when
          looking for the name of the entry. The default value for this
          option is "cn", which stands for common name. If the server you
          are using uses a different attribute name for the name, put that
          attribute name here. This will affect the search filter used if
          your Search-Type is one that contains a search for "name".
   _surname-attribute_
          This is the name of the attribute which is searched for when
          looking for the surname of the entry. The default value for this
          option is "sn". If the server you are using uses a different
          attribute name for the surname, put that attribute name here.
          This will affect the search filter used if your Search-Type is
          one that contains a search for "surname".
   _givenname-attribute_
          This is the name of the attribute which is searched for when
          looking for the given name of the entry. The default value for
          this option is "givenname". If the server you are using uses a
          different attribute name for the given name, put that attribute
          name here. This will affect the search filter used if your
          Search-Type is one that contains a search for "givenname".
   _timelimit_
          This places a limit on the number of seconds the LDAP search
          will continue. The default is 30 seconds. A value of 0 means no
          limit. Note that some servers may place limits of their own on
          searches.
   _sizelimit_
          This places a limit on the number of entries returned by the
          LDAP server. A value of 0 means no limit. The default is 0. Note
          that some servers may place limits of their own on searches.
   _custom-search-filter_
          This one is for advanced users only! If you define this, then
          the search-type and search-rule defined are both ignored.
          However, the feature disable-ad-hoc-space-substitution is still
          in effect. That is, the space substitution will take place even
          in a custom filter unless you disable it.
          If your LDAP service stops working and you suspect it might be
          because of your custom filter, just delete this filter and try
          using the _search-type_ and _search-rule_ instead. Another
          option that sometimes causes trouble is the search-base option.
          This variable may be set to the string representation of an LDAP
          search filter (see RFC1960). In the places where you want the
          address string to be substituted in, put a '%s' in this filter
          string. Here are some examples:
          A "Search-Type" of "name" with "Search-Rule" of "begins-with" is
          equivalent to the "custom-search-filter"
     (cn=%s*)

          When you try to match against the string "string" the program
          replaces the "%s" with "string" (without the quotes). You may
          have multiple "%s"'s and they will all be replaced with the
          string. There is a limit of 10 "%s"'s.
          A "Search-Type" of "name-or-email" with "Search-Rule" of
          "contains" is equivalent to
     (|(cn=*%s*)(mail=*%s*))

          If your server uses a different attribute _name_ than _Alpine_
          uses by default, (for example, it uses "rfc822mail" instead of
          "mail"), then you may be able to use one or more of the four
          attribute configuration options instead of defining a custom
          filter:
          + email-attribute
          + name-attribute
          + surname-attribute
          + givenname-attribute

Color Configuration

   If the terminal or terminal emulator you are using is capable of using
   color (see color-style option), or if you are using _PC-Alpine_, then
   it is possible to set up _Alpine_ so that various parts of the display
   will be shown in colors you configure. This is done using the Setup
   Color screen. The Setup Color screen is divided into five broad
   sections: Options, General Colors, Index Colors, Header Colors, and
   Keyword Colors. In addition to these five categories you may also color
   lines in the MESSAGE INDEX screen by configuring the Index Line Color.

   Each color is defined as a foreground color (the color of the actual
   text) and a background color (the color of the area behind the text).

  Color Options

   _current-indexline-style_
          This option affects the colors used to display the current line
          in the MESSAGE INDEX screen. If you do not have Index Line
          Colors defined, then this option will have no effect in the
          index. Those Rules may be defined by going to the
          Setup/Rules/Indexcolor screen.

          If the option enable-incoming-folders-checking is turned on and
          the Incoming Unseen Color is set to something other than the
          default, then this option also affects the color used to display
          the current folder in the Incoming FOLDER LIST screen.

          The available options include:

        flip-colors
                This is the default. If an index line is colored because
                it matches one of your Index Color Rules, then its colors
                will be reversed when it is the currently highlighted
                line. For example, if the line is normally red text on a
                blue background, then when it is the current line it will
                be drawn as blue text on a red background.

                The rest of the option values all revert to this
                flip-colors behavior if there is no Reverse Color defined.

        reverse
                With this option the Reverse color is always used to
                highlight the current line.

        reverse-fg
                The foreground part of the Reverse Color is used to
                highlight the current line. If this would cause the text
                to be unreadable (because the foreground and background
                colors are the same) or if it would cause no change in the
                color of the index line, then the colors are flipped
                instead.

                Some people think this works particularly well if you use
                different background colors to emphasize "interesting"
                lines, but always with the same Normal foreground color,
                and you use a different foreground color for the Reverse
                Color.

        reverse-fg-no-ambiguity
                With the "reverse-fg" rule above, it is possible that the
                resulting color will be exactly the same as the regular
                Reverse Color. That can lead to some possible confusion
                because an "interesting" line which is the current line
                will be displayed exactly the same as a non-interesting
                line which is current. You can't tell whether the line is
                just a regular current line or if it is an "interesting"
                current line by looking at the color. Setting the option
                to this value removes that ambiguity. It is the same as
                the "reverse-fg" setting unless the resulting interesting
                current line would look just like a non-interesting
                current line. In that case, the interesting line's colors
                are simply flipped (like in the default behavior).

                As an alternative way to preserve the line's
                interestingness in this case, you may find that using both
                a different foreground and a different background color
                for the interesting line will help.

        reverse-bg
                The background part of the Reverse Color is used to
                highlight the current line. If this would cause the text
                to be unreadable (because the foreground and background
                colors are the same) or if it would cause no change in the
                color of the index line, then the colors are flipped
                instead.

                Some people think this works particularly well if you use
                different foreground colors to emphasize "interesting"
                lines, but always with the same Normal background color,
                and you use a different background color for the Reverse
                Color.

        reverse-bg-no-ambiguity
                As with the "reverse-fg" case, the "reverse-bg" rule may
                also result in a color which is exactly the same as the
                regular Reverse Color. Setting the option to this value
                removes that ambiguity. It is the same as the "reverse-bg"
                setting unless the resulting current line has the same
                color as the Reverse Color. In that case, the interesting
                line's colors are simply flipped (like in the default
                behavior).

   _titlebar-color-style_
          This option affects the colors used to display the titlebar (the
          top line on the screen) when viewing a message.

          The available options include:

        default
                The color of the titlebar will be the color you set for
                the Title Color. The Title Color may be set by using the

        indexline
                The color of the titlebar will be the same as the color of
                the index line corresponding to the message being viewed.
                The rules which determine what color the index line will
                be may be set up by going to the Setup/Rules/Indexcolor
                screen. If the index line for a message is not colored
                explicitly by the Indexcolor rules, then the titlebar will
                be colored the same as for the "default" option above
                (which is not the same color that the index line itself
                will have).

        reverse-indexline
                This is similar to the "indexline" option except the
                foreground and background colors from the corresponding
                index line will be reversed. For example, if the index
                line color is red letters on a white background, then the
                titlebar will be white letters on a red background. If the
                index line for a message is not colored explicitly by the
                Indexcolor rules, then the titlebar will be colored the
                same as for the "default" option above (which is not the
                same color that the index line itself will have).

  General Colors

   _Normal Color_
          This is the color which most of the screen is painted in. By
          default this color is black characters on a white background.
   _Reverse Color_
          The color _Alpine_ uses for reverse video characters. Actually,
          the name is misleading. This used to be reverse video and so the
          name remains. It is still used to highlight certain parts of the
          screen but the color may be set to whatever you'd like.
   _Title Color_
          The color _Alpine_ uses for the titlebar (the top line on the
          screen). By default, the Title Color is black characters on a
          yellow background. The actual titlebar color may be different
          from the Title Color if the option titlebar-color-style is set
          to some value other than the default. It may also be different
          if the current folder is closed and the Title Closed Color is
          set to something different from the Title Color.
   _Title-closed Color_
          The color _Alpine_ uses for the titlebar (the top line on the
          screen) when the current folder is closed. By default, the Title
          Color Closed Color is white characters on a red background.
   _Status Color_
          The color _Alpine_ uses for messages written to the status
          message line near the bottom of the screen. By default, the
          Status Color is the same as the Reverse Color.
   _KeyLabel Color_
          The color _Alpine_ uses for the labels of the commands in the
          two-line menu at the bottom of the screen. The label is the long
          name, for example, "PrevMsg". By default, the KeyLabel Color is
          the same as the Normal Color.
          WARNING: Some terminal emulators have the property that the
          screen will scroll down one line whenever a character is written
          to the character cell in the lower right corner of the screen.
          _Alpine_ can usually avoid writing a character in that corner of
          the screen. However, if you have defined a KeyLabel Color then
          _Alpine_ does have to write a character in that cell in order to
          color the cell correctly. If you find that your display
          sometimes scrolls up a line this could be the problem. The most
          obvious symptom is probably that the titlebar at the top of the
          screen scrolls off the screen. Try setting KeyLabel Color to
          Default to see if that fixes the problem.
   _KeyName Color_
          The color _Alpine_ uses for the names of the commands in the
          two-line menu at the bottom of the screen. The KeyName is the
          shorter name in the menu. For example, the "W" before the
          "WhereIs". By default, the KeyName Color is the same as the
          Normal Color.
   _Selectable-item Color_
          The color _Alpine_ uses for displaying selectable items, such as
          URLs. By default, the Selectable-item Color is the same as the
          Normal Color, except it is also Bold.
   _Meta-message Color_
          The color _Alpine_ uses in the MESSAGE TEXT screen for messages
          to you that aren't part of the message itself. By default, the
          Meta-Message Color is black characters on a yellow background.
   _Quote Colors_
          The colors _Alpine_ uses for coloring quoted text in the MESSAGE
          TEXT screen. If a line begins with a > character (or space
          followed by >) it is considered a quote. That line will be given
          the Quote1 Color (first level quote). If there is a second level
          of quoting then the Quote2 Color will be used. _Alpine_
          considers there to be a second level of quoting if that first >
          is followed by another > (or space followed by >). If there are
          characters other than whitespace and > signs, then it isn't
          considered another level of quoting. Similarly, if there is a
          third level of quoting the Quote3 Color will be used. If there
          are more levels after that the Quote Colors are reused. If you
          define all three colors then it would repeat like Color1,
          Color2, Color3, Color1, Color2, Color3, ... If you only define
          the first two it would be Color1, Color2, Color1, Color2, ... If
          you define only the Quote1 Color, then the entire quote would be
          that color regardless of the quoting levels. By default, the
          Quote1 Color is black characters on a greenish-blue background;
          the Quote2 Color is black characters on a dull yellow
          background; and the Quote3 Color is black characters on a green
          background.
   _Incoming Unseen Color_
          If the option enable-incoming-folders-checking is turned on it
          is possible to highlight the folders that contain unseen
          messages by coloring them with this color. By default, this is
          the same as the Normal Color and no highlighting is done.
          Usually the "current" folder (the folder the cursor is on) is
          highlighted using reverse video. If the current folder is
          colored because it contains unseen messages then the color used
          to show that it is also the current folder is controlled by the
          current-indexline-style feature at the top of the SETUP COLOR
          screen.
   _Signature Color_
          The color _Alpine_ uses for coloring the signature in the
          MESSAGE TEXT screen. According to USENET conventions, the
          signature is defined as the paragraph following the "sigdashes",
          that is, the special line consisting of the three characters
          "-- " (i.e., dash, dash, and space). _Alpine_ allows for one
          empty line right after the sigdashes to be considered as part of
          the signature. By default, the Signature Color is blue
          characters on a white background.
   _Prompt Color_
          The color _Alpine_ uses for confirmation prompts and questions
          which appear in the status message line near the bottom of the
          screen. By default, the Prompt Color is the same as the Reverse
          Color.

  Index Colors

   You may add color to the single character symbols which give the status
   of each message in the MESSAGE INDEX. By default the characters "+",
   "*", "D", "A", and "N" show up near the left hand side of the screen,
   depending on whether the message is addressed to you, and whether the
   message is marked Important, is Deleted, is Answered, or is New. You
   may set the color of those symbols. By default, all of these symbols
   are drawn with the same color as the rest of the index line they are a
   part of.

   Besides coloring the message status symbols, you may also color the
   entire index line. This is done by using the Index Line Color
   configuration screen. It is also possible to color (keywords in the
   index using the Setup/Kolor screen (Keyword Colors); the ARROW cursor;
   the Subject using Index Subject Color; the From using Index From Color;
   and the Index Opening text.

   _Index-to-me Symbol Color_
          The color used for drawing the "+" symbol which signifies a
          message is addressed directly to you.
   _Index-important Symbol Color_
          The color used for drawing the "*" symbol which signifies a
          message has been flagged Important.
   _Index-deleted Symbol Color_
          The color used for drawing the "D" symbol which signifies a
          message has been marked Deleted.
   _Index-answered Symbol Color_
          The color used for drawing the "A" symbol which signifies a
          message has been answered.
   _Index-new Symbol Color_
          The color used for drawing the "N" symbol which signifies a
          message is New.
   _Index-recent Symbol Color_
          The color used for drawing the "R" symbol which signifies a
          message is Recent (only visible if the "IMAPSTATUS" or
          "SHORTIMAPSTATUS" token is part of the index-format option).
   _Index-unseen Symbol Color_
          The color used for drawing the "U" symbol which signifies a
          message is Unseen (only visible if the "IMAPSTATUS" or
          "SHORTIMAPSTATUS" token is part of the Index-Format option).
   _Index-priority Symbol Colors_
          The colors used for drawing the tokens "PRIORITY",
          "PRIORITYALPHA", and "PRIORITY!" when these are configured as
          part of the Index-Format option. You may set the color used to
          draw these tokens by use of the colors Index High Priority
          Symbol Color and Index Low Priority Symbol Color. This coloring
          takes place for all but the current index line, and the Priority
          Color appears to be in front of any color from an Index Color
          Rule. If the priority has a value of 1 or 2 the High Priority
          color will be used, and if the value is 4 or 5 the Low Priority
          color will be used.
          If you don't set these colors the index line will be colored in
          the same color as the bulk of the index line.
   _Index-arrow Symbol Color_
          The color used for drawing the "ARROW" token when it is
          configured as part of the Index-Format option.
   _Index-subject Symbol Color_
          You may set the color used to draw the Subject part of the index
          line. This coloring takes place for all but the current index
          line, and the Subject Color appears to be in front of any color
          from an Index Color Rule.
          If you don't set this color it will be colored in the same color
          as the bulk of the index line.
   _Index-from Symbol Color_
          You may set the color used to draw the From part of the index
          line. This coloring takes place for all but the current index
          line, and the From Color appears to be in front of any color
          from an Index Color Rule.
          If you don't set this color it will be colored in the same color
          as the bulk of the index line.
   _Index-opening Symbol Color_
          It is possible to configure the Index-Format option so that it
          includes the subject followed by the "opening" text of the
          message if there is enough space. This is done by using one of
          the tokens SUBJECTTEXT, SUBJKEYTEXT, or SUBJKEYINITTEXT. The
          color used for drawing this opening text is given by this
          option. The coloring happens for all but the current index line,
          and this opening color appears to be in front of any color from
          an Index Color Rule.
          By default the Index Opening Color is gray characters on a white
          background.

   The default colors for these symbols are:

     Index-to-me     black on cyan
     Index-important white on bright red
     Index-deleted   same as Normal Color
     Index-answered  bright red on yellow
     Index-new       white on magenta
     Index-recent    same as Normal Color
     Index-unseen    same as Normal Color

  Header Colors

   You may add color to the header fields in the MESSAGE TEXT screen. The

   _Header-general Color_
          may be used to color all of the headers of the message.

   It is also possible to set the colors for specific header fields, for
   example for the Subject or From fields, using the viewer-hdr-colors
   option.

   For Header Colors, there is an additional line on the configuration
   screen labeled "Pattern to match". If you leave that blank, then the
   whole field for that header will always be colored. However, if you
   give a pattern to match, the coloring will only take place if there is
   a match for that pattern in the value of the field. For example, if you
   are working on a color for the Subject header and you fill in a pattern
   of "important", then only Subjects which contain the word "important"
   will be colored. For address fields like From or To, a pattern match
   will cause only the addresses which match the pattern to be colored.

   If the pattern you enter is a comma-separated list of patterns, then
   coloring happens if any of those patterns matches.

  Keyword Colors

   Sets the colors _Alpine_ uses for Keyword fields in the MESSAGE INDEX
   screen. Keywords may be displayed as part of the Subject of a message
   by using the "SUBJKEY" or "SUBJKEYINIT" tokens in the Index-Format
   option. Keywords may also be displayed in a column of their own in the
   MESSAGE INDEX screen by using the "KEY" or "KEYINIT" tokens.

   For example, you might have set up a Keyword "Work" using the Keywords
   option in the Setup/Config screen. You could cause that Keyword to show
   up as a special color by setting up the Keyword Color using this
   option, and then including it in the MESSAGE INDEX screen using one of
   the tokens listed above in the Index-Format.

  Index Line Colors

   You may color whole index lines by using roles. This isn't configured
   in the Setup Colors screen, but is configured in the Setup Rules
   IndexColor screen.

Index Line Color Configuration

   Index Line Color causes lines in the MESSAGE INDEX screen to be
   colored. This action is only available if your terminal is capable of
   displaying color and color display has been enabled with the
   Color-Style option. (In PC-Alpine, color is always enabled so there is
   no option to turn on.)

   Each rule has a "Pattern", which is used to decide which of the rules
   is used; and the color which is used if the Pattern matches a
   particular message.

  Rule Patterns

   In order to determine whether or not a message matches a rule the
   message is compared with the rule's Pattern. These Patterns are the
   same for use with Roles, Filtering, Index Coloring, Scoring, Other
   Rules, and Search Rules, so are described in only one place, "here".

  Index Line Color

   This is the color that index lines are colored when there is a matching
   Pattern. This colors the whole index line, except possibly the status
   letters which may be colored separately using the Setup Kolor screen.

Role Configuration

   You may play different roles depending on who you are replying to. For
   example, if you are replying to a message addressed to _help-desk_ you
   may be acting as a Help Desk Worker. That role may require that you use
   a different return address and/or a different signature.

   Roles are optional. If you set up roles they work like this: Each role
   has a set of "Uses", which indicate whether or not a role is eligible
   to be considered for a particular use; a "Pattern", which is used to
   decide which of the eligible roles is used; and a set of "Actions",
   which are taken when that role is used. When you reply to a message,
   the message you are replying to is compared with the Patterns of the
   roles marked as eligible for use when replying. The comparisons start
   with the first eligible role and keep going until there is a match. If
   a match is found, the matching role's Actions are taken.

   It is also possible to set a default role and to change that role
   during your _Alpine_ session. When you start _Alpine_ no default role
   will be set. You may set or change the current default role by using
   the "D" command in the role selection screen. You'll see that screen
   while composing a message and being asked to select a role. An easy way
   to get to that screen is to use the Role Command to compose a message.
   You may find a default role useful if you normally perform the duties
   of one of your roles for a while, then you switch to another role and
   stay in the new role for another period of time. It may be easier than
   using the Role Command to select the role each time you compose a
   message.

  Role Uses

   There are three types of use to be configured; one for Replying, one
   for Forwarding, and one for Composing. These indicate whether or not
   you want a role to be considered when you type the Reply, Forward, or
   Compose commands. (The Role command is an alternate form of the Compose
   command, and it is not affected by these settings.) Each of these Use
   types has three possible values. The value "Never" means that the role
   will never be considered as a candidate for use with the corresponding
   command. For example, if you set a role's Reply Use to Never, then when
   you Reply to a message, the role won't even be considered. (That isn't
   quite true. If the message you are replying to matches some other role
   which requires confirmation, then there will be a ^T command available
   which allows you to select a role from all of your roles, not just the
   reply-eligible roles.)

   The options "With confirmation" and "Without confirmation" both mean
   that you do want to consider this role when using the corresponding
   command. For either of these settings the role's Pattern will be
   checked to see if it matches the message. For Reply Use, the message
   used to compare the Patterns with is the message being replied to. For
   Forward Use, the message used to compare the Pattern with is the
   message being forwarded. For Compose Use, there is no message, so the
   parts of the Pattern which depend on a message (everything other than
   Current Folder Type) are ignored. In all cases, the Current Folder is
   checked if defined. If there is a match then this role will either be
   used without confirmation or will be the default when confirmation is
   asked for, depending on which of the two options is selected. If
   confirmation is requested, you will have a chance to choose No Role
   instead of the offered role, or to change the role to any one of your
   other roles (with the ^T command).

  Role Patterns

   In order to determine whether or not a message matches a role the
   message is compared with the Role Pattern. These Patterns are the same
   for use with Roles, Filtering, Index Coloring, Scoring, Other Rules,
   and Search Rules, so are described in only one place, "here".

   Since header patterns, AllText patterns, and BodyText patterns which
   are unset are ignored, a role which has all header patterns unset, the
   AllText pattern unset, the BodyText pattern unset, the Score Interval
   unset, and the Current Folder Type set to "Any" may be used as a
   default role. It should be put last in the list of roles since the
   matching starts at the beginning and proceeds until one of the roles is
   a match. If no roles at all match, then _Alpine_ will use its regular
   methods of defining the role. If you wanted to, you could define a
   different "default" role for Replying, Forwarding, and Composing by
   setting the "Use" fields appropriately.

  Role Actions

   Once a role match is found, the role's Actions are taken. For each role
   there are several possible actions that may be defined. They are
   actions to set the From address, the Reply-To address, the Fcc, the
   Signature file, and the Template file.

    Initialize Settings Using Role

   This is a power user feature. You will usually want to leave this field
   empty. The value of this field is the nickname of another one of your
   roles. The Action values from that other role are used as the initial
   values of the Action items for this role. If you put something in any
   of the action fields for this role, that will override whatever was in
   the corresponding field of the initializer role.

   You might use this field if the "Action" part of one of your roles is
   something you want to use in more than one role. Instead of filling in
   those action values again for each role, you may give the nickname of
   the role where the values are filled in. It's just a shortcut way to
   define Role Actions.

   Here's an example to help explain how this works. Suppose you have a
   role with nickname "role1" and role1 has (among other things)

               Set Reply-To = The Pres <president@example.com>

   set. If in "role2" you set "Initialize settings using role" to "role1",
   then role2 will inherit the Set Reply-To value from role1 by default
   (and any of the other inheritable action values that are set). So if
   role2 had

                        Set Reply-To = <No Value Set>

   defined, the Reply-To used with role2 would be "The Pres
   <president@example.com>" However, if role2 had

                Set Reply-To = VP <vicepresident@example.com>

   defined, then the Reply-To used with role2 would be "VP
   <vicepresident@example.com>" instead.

   If you wish, you may choose a nickname from your list of roles by using
   the "T" command. If the role you are using to initialize also has a
   role it initializes from, then that initialization happens first. That
   is, inheritance works as expected with the grandparent and
   great-grandparent (and so on) roles having the expected effect.

    Set From

   This field consists of a single address which will be used as the From
   address on the message you are sending. This should be a
   fully-qualified address like

                           Full Name <user@domain>

   or just

                                 user@domain

   If this is left blank, then the normal From address will be used.

    Set Reply-To

   The Reply-To address is the address used on the Reply-To line of the
   message you are sending. You don't need a Reply-To address unless it is
   different from the From address. This should be a fully-qualified
   address like

                           Full Name <user@domain>

   or just

                                 user@domain

   If this is left blank, then there won't be a Reply-To address unless
   you have configured one specially with the customized-hdrs
   configuration option.

    Set Other-Hdrs

   This field gives you a way to set values for headers besides "From" and
   "Reply-To". If you want to set either of those, use the specific "Set
   From" and "Set Reply-To" settings.

   This field is similar to the customized-hdrs option. Each header you
   specify here must include the header tag ("To:", "Approved:", etc.) and
   may optionally include a value for that header. In order to see these
   headers when you compose using this role you must use the rich header
   command. Here's an example which shows how you might set the To
   address.

                Set Other Hdrs = To: Full Name <user@domain>

   Headers set in this way are different from headers set with the
   customized-hdrs option in that the value you give for a header here
   will replace any value that already exists. For example, if you are
   Replying to a message there will already be at least one address in the
   To header (the address you are Replying to). However, if you Reply
   using a role which sets the To header, that role's To header value will
   be used instead. The customized-hdrs headers are defaults.

   Limitation: Because commas are used to separate the list of Other
   Headers, it is not possible to have the value of a header contain a
   comma; nor is there currently an "escape" mechanism provided to make
   this work.

    Set Fcc

   This field consists of a single folder name which will be used in the
   Fcc field of the message you are sending. You may put anything here
   that you would normally type into the Fcc field from the composer.

   In addition, an fcc of "" (two double quotation marks) means no Fcc.

   A blank field here means that _Alpine_ will use its normal rules for
   deciding the default value of the Fcc field. For many roles, perhaps
   most, it may make more sense for you to use the other _Alpine_
   facilities for setting the Fcc. In particular, if you want the Fcc to
   depend on who you are sending the message to then the fcc-name-rule is
   probably more useful. In that case, you would want to leave the Fcc
   field here blank. However, if you have a role that depends on who the
   message you are replying to was From, or what address that message was
   sent to; then it might make sense to set the Fcc for that role here.

    Set LiteralSig

   This field contains the actual text for your signature, as opposed to
   the name of a file containing your signature. If this is defined it
   takes precedence over any value set in the _Set Signature_ field.

   This is simply a different way to store the signature. The signature is
   stored inside your Alpine configuration file instead of in a separate
   signature file. Tokens work the same way they do with _Set Signature_.

   The two character sequence \n (backslash followed by the character n)
   will be used to signify a line-break in your signature. You don't have
   to enter the \n, but it will be visible in the CHANGE THIS ROLE RULE
   window after you are done editing the signature.

    Set Signature

   The Signature is the name of a file to be used as the signature file
   when this role is being used. If the filename is followed by a vertical
   bar (|) then instead of reading the contents of the file the file is
   assumed to be a program which will produce the text to be used on its
   standard output. The program can't have any arguments and doesn't
   receive any input from _Alpine_, but the rest of the processing works
   as if the contents came from a file.

   Signature files may be stored remotely on an IMAP server. In order to
   do that you just give the file a remote name. This works just like the
   regular signature-file option which is configured from the
   Setup/Configuration screen. A remote signature file name might look
   like:

                  {myimaphost.myschool.k12.wa.us}mail/sig3

   or, if you have an SSL-capable version of _Alpine_, you might try

         {myimaphost.myschool.k12.wa.us/user=loginname/ssl}mail/sig3

   Once you have named the remote signature file you create its contents
   by using the "F" "editFile" command when the cursor is on the "Set
   Signature" line of the role editor.

   Besides containing regular text, a signature file may also contain (or
   a signature program may produce) tokens which are replaced with text
   which depends on the message you are replying to or forwarding. The
   tokens all look like _word_ (a word surrounded by underscores). For
   example, if the token

                                   _DATE_

   is included in the text of the signature file, then when you reply to
   or forward a message, the token will be replaced with the actual date
   the message you are replying to or forwarding was sent.

   If you use a role which has a signature file for a plain composition
   (that is, not a reply or forward) then there is no original message, so
   any tokens which depend on the message will be replaced with nothing.
   So if you want a signature file to be useful for new compositions it
   shouldn't include any of the tokens which depend on the message being
   replied to or forwarded.

   The list of available tokens is here.

   Actually, for the adventurous, there is a way to conditionally include
   text based on whether or not a token would result in specific
   replacement text. For example, you could include some text based on
   whether or not the _NEWS_ token would result in any newsgroups if it
   was used. It's explained in detail here.

   In the very unlikely event that you want to include a literal token in
   a signature file, you must precede it with a backslash character. For
   example, to include the literal text _DATE_ you must actually use
   \_DATE_. It is not possible to have a literal backslash followed by an
   expanded token.

   A blank field here means that _Alpine_ will use its normal rules for
   deciding which file (if any) to use for the signature file.

    Set Template

   A Template is the name of a file to be included in the message when
   this role is being used. The template file is a file which is included
   at the top of the message you are composing.

   If the filename is followed by a vertical bar (|) then instead of
   reading the contents of the file the file is assumed to be a program
   which will produce the text to be used on its standard output. The
   program can't have any arguments and doesn't receive any input from
   _Alpine_, but the rest of the processing works as if the contents came
   from a file.

   Template files may be stored remotely on an IMAP server. In order to do
   that you just give the file a remote name. This works just like the
   regular signature-file option which is configured from the
   Setup/Configuration screen. A remote template file name might look
   like:

                 {myimaphost.myschool.k12.wa.us}mail/templ3

   or, if you have an SSL-capable version of _Alpine_, you might try

        {myimaphost.myschool.k12.wa.us/user=loginname/ssl}mail/templ3

   Once you have named the remote template file you create its contents by
   using the "F" "editFile" command when the cursor is on the "Set
   Template" line of the role editor.

   Besides containing regular text, a template file may also contain (or a
   template file program may produce) tokens which are replaced with text
   which depends on the message you are replying to or forwarding. The
   tokens all look like _word_ (a word surrounded by underscores). For
   example, if the token

                                   _DATE_

   is included in the text of the template file, then when you reply to or
   forward a message, the token will be replaced with the actual date the
   message you are replying to or forwarding was sent.

   If you use a role which has a template file for a plain composition
   (that is, not a reply or forward) then there is no original message, so
   any tokens which depend on the message will be replaced with nothing.
   So if you want a template file to be useful for new compositions it
   shouldn't include any of the tokens which depend on the message being
   replied to or forwarded.

   The list of available tokens is here.

   Actually, for the adventurous, there is a way to conditionally include
   text based on whether or not a token would result in specific
   replacement text. For example, you could include some text based on
   whether or not the _NEWS_ token would result in any newsgroups if it
   was used. It's explained in detail here.

   In the very unlikely event that you want to include a literal token in
   a template file, you must precede it with a backslash character. For
   example, to include the literal text _DATE_ you must actually use
   \_DATE_. It is not possible to have a literal backslash followed by an
   expanded token.

   A blank field here means that _Alpine_ will not use a template file
   when this role is being used.

    Use SMTP Server

   If this field has a value, then it will be used as the SMTP server to
   send mail when this role is being used (unless the SMTP server variable
   is set in the system-wide fixed configuration file). It has the same
   semantics as the smtp-server variable in the Setup/Config screen. When
   you postpone the composition this SMTP server list will be saved with
   the postponed composition and it cannot be changed later. Because of
   that, you may want to make this a list of SMTP servers with the
   preferred server at the front of the list and alternate servers later
   in the list.

   If any of the actions are left unset, then the action depends on what
   is present in the "Initialize settings using role" field. If you've
   listed the nickname of another one of your roles there, then the
   corresponding action from that role will be used here. If that action
   is also blank, or if there is no nickname specified, then _Alpine_ will
   do whatever it normally does to set these actions. This depends on
   other configuration options and features you've set.

Filtering Configuration

   The software which actually delivers mail (the stuff that happens
   before _Alpine_ is involved) for you is in a better position to do mail
   filtering than _Alpine_ itself. If possible, you may want to look into
   using that sort of mail filtering to deliver mail to different folders,
   delete it, or forward it. However, if you'd like _Alpine_ to help with
   this, _Alpine_'s filtering is for you.

   Filtering is a way to automatically move certain messages from one
   folder to another or to delete messages. It can also be used to set
   message status bits (Important, Deleted, New, Answered). _Alpine_
   doesn't have the ability to forward mail to another address.

   Each filtering rule has a "Pattern" and a "Filter Action". When a
   folder is opened, when new mail arrives in an open folder, or when mail
   is Expunged from a folder; each message is compared with the Patterns
   of your filtering rules. The comparisons start with the first rule and
   keep going until there is a match. If a match is found, the message may
   be deleted or moved, depending on the setting of the Filter Action. If
   the message is not deleted, it may have its status altered.

   For efficiency, each message is usually only checked once. When new
   mail arrives, the new messages are checked but not the old. There are
   some exceptions to this rule. The expunge command will cause all
   messages to be rechecked, as will editing of the filtering rules.

   _NOTE:_ When setting up a Pattern used to delete messages, it is
   recommended that you test the Pattern first with a "Move" folder
   specified in case unintended matches occur. Messages that are deleted
   will be removed from the folder and _unrecoverable_ from within _Alpine_
   after the next Expunge command or once the folder being filtered has
   been closed.

  Filter Patterns

   In order to determine whether or not a message matches a filter the
   message is compared with the Filter's Pattern. These Patterns are the
   same for use with Roles, Filtering, Index Coloring, Scoring, Other
   Rules, and Search Rules, so are described in only one place, "here".

   Since filtering is a potentially destructive action, if you have a
   filtering Pattern with nothing other than Current Folder Type set, that
   filtering rule is ignored.

  Filter Actions

   Once a filter match is found for a particular message, there are some
   actions which may be taken. First, the message may have its status
   changed. This is the same message status that you can manipulate
   manually using the Flag Command. There are four elements of message
   status that you can control. You can set or clear the Important status,
   the New status, the Deleted status, and the Answered status. Of course,
   if the filter is going to delete the message, then there is no point in
   setting message status. You may also set or clear user-defined keywords
   for a message.

   Second, the filter may delete or move the message. Deleting the message
   marks it Deleted and removes it from view. It is effectively gone
   forever (though it technically is still there until the next expunge
   command, which may happen implicitly). Moving the message moves it from
   the open folder into the folder listed on the "Folder List" line of the
   filter configuration. If you list more than one folder name (separated
   by commas) then the message will be copied to each of those folders. In
   any case, if "Delete" or "Move" is set then the message is removed from
   the current folder. If you just want to set the messages status without
   deleting it from the folder, then set the filter action to "Just Set
   Message Status".

   (There is no way to do a Copy instead of a Move, due to the
   difficulties involved in keeping track of whether or not a message has
   already been copied by a previous _Alpine_ session.)

    Move-only-if-not-deleted option

   If you have specified a Move to Folder to filter messages into, then
   this option has an effect. If this option is set then messages will
   only be moved into the specified folder if they aren't already marked
   deleted. This might be useful if you have more than one _Alpine_
   session running simultaneously and you don't want messages to be
   filtered into a folder more than once. This method is not foolproof.
   There may be cases where a message gets marked deleted and so it is
   never filtered into the folder. For example, if you deleted it in
   another _Alpine_ or another mail program that didn't know about the
   filtering rule.

   This option has no effect if the Filter Action is not set to Move.

    Dont-quit-even-if-rule-matches option

   If this option is set then this is a non-terminating rule. Usually, for
   each message, _Alpine_ searches through the filter rules until a match
   is found and then it performs the action associated with that rule.
   Rules following the match are not considered. If this option is set
   then the search for matches will continue at the next rule.

   If a non-terminating rule matches then the actions associated with that
   rule, except for any implied deletion of the message, are performed
   before the match for the next rule is checked. For example, if the
   non-terminating rule sets the Important status, then that status will
   be set when the next rule is considered. However, if the
   non-terminating rule Moves the message, the message will actually be
   copied instead of copied and deleted so that it is still there for the
   next rule. A moved message is deleted after all the relevant rules have
   been checked. The name of the "Move" action is confusing in this case
   because a single message can be moved to more than one folder. It turns
   the Move into a Copy instead, but it is still followed by a deletion at
   the end.

   This option may be useful if you want to have a single message filtered
   to two different folders because it matches two different Patterns. For
   example, suppose you normally filter messages to a particular mailing
   list into one folder, and messages addressed directly to you into a
   second folder. If a message is sent to both you and the list (and you
   can tell that by looking at the headers of the message) this option may
   give you a convenient way to capture a copy to each folder. (It may
   also cause you to capture two copies to each folder, depending on
   whether your mail system delivers one or two copies of the message to
   you and on how the list works.)

Scoring Configuration

   Most people will not use scores at all, but if you do use them, here's
   how they work in Alpine. Using this screen, you may define Scoring
   rules. The score for a message is calculated by looking at every Score
   rule defined and adding up the Score Values for the ones which match
   the message. If there are no matches for a message, it has a score of
   zero. Message scores may be used a couple of ways in Alpine.

  Sorting by Score

   One of the methods you may use to sort message indexes is to sort by
   score. The scores of all the messages in a folder will be calculated
   and then the index will be ordered by placing the messages in order of
   ascending or descending score.

  Scores for use in Patterns

   The Patterns used for Roles, Index Line Coloring, and Filtering have a
   category labeled "Score Interval". When a message is being compared
   with a Pattern to check for a match, if the Score Interval is set only
   messages which have a score somewhere in the interval are a match.

  Scoring Rule Patterns

   In order to determine whether or not a message matches a scoring rule
   the message is compared with the rule's Pattern. These Patterns are the
   same for use with Roles, Filtering, Index Coloring, Scoring, Other
   Rules, and Search Rules, so are described in only one place, "here".

   Actually, Scoring rule Patterns are slightly different from the other
   types of Patterns because Scoring rule Patterns don't contain a Score
   Interval. In other words, when calculating the score for a message,
   which is done by looking at the Scoring rule Patterns, scores aren't
   used.

  Score Value

   This is the value that will be added to the score for a message if the
   rule's Pattern is a match. Each individual Score Value is an integer
   between -100 and 100, and the values from matching rules are added
   together to get a message's score. There is also a way to extract the
   value from a particular header of each message. See the help text for
   Score Value for further information.

Other Rules Configuration

   Using this screen, you may define configuration Rules which don't fit
   nicely into the other Rules categories.

  Other Rule Patterns

   Other Rules are a little different from the rest of the Rules because
   they depend only on the current folder, and not on a particular
   message. In order to determine whether or not a rule's actions should
   be applied the current folder is compared with the rule's Pattern,
   which consists of only the Current Folder Type. Current Folder Type
   works the same for Other Rules as it does for Roles, Filtering, Index
   Coloring, and Scoring. Keep in mind that the only part of the Pattern
   which applies to Other Rules is the Current Folder Type when looking at
   the description of Patterns given "here".

  Other Rule Actions

   Once a pattern match is found, the rule's Actions are taken. Neither of
   the following two rule's depends on a message for its match. That means
   that all the parts of the Pattern which depend on matching an attribute
   of a message are ignored. So the only part of the Pattern that matters
   for these Actions is the Current Folder Type.

    Set Sort Order

   When you enter a new folder, these rules will be checked to see if you
   have set a sort order which is different from your default sort order.
   The default is set in the Setup/Config screen with the Sort-Key option.
   If the Sort Order action is set, then the folder will be displayed
   sorted in that sort order instead of in the default order.

   A possible point of confusion arises when you change the configuration
   of the Sort Order for the currently open folder. The folder will
   normally be re-sorted when you go back to viewing the index. However,
   if you have manually sorted the folder with the Sort command, it will
   not be re-sorted.

    Set Index Format

   When you enter a new folder, these rules will be checked to see if you
   have set an Index Format which is different from your default Index
   Format, which is set with the Index-Format option. If so, the index
   will be displayed with this format instead of the default.

    Set Startup Rule

   When you enter a new folder, these rules will be checked to see if you
   have set a startup rule which is different from the default startup
   rule. The default for incoming folders is set in the Setup/Config
   screen with the "incoming-startup-rule" option. The default for folders
   other than INBOX that are not part of your incoming collection (see
   enable-incoming-folders feature) is to start with the last message in
   the folder. If the Startup Rule is set to something other than
   "default", then the rule will determine which message will be the
   current message when the folder is first opened.

   The various startup rule possibilities work the same here as they do in
   the incoming collection, except that the folder can be any specific
   folder or any folder type.

Search Rules Configuration

   One of the commands that becomes available when that feature is turned
   on is the "; Select" command, which is used in the MESSAGE INDEX screen
   to select a set of messages. One way of selecting messages is to use a
   Rule. All of the messages which match (or don't match if you wish) a
   Rule's Pattern will be selected.

   Any of your Rules may be used for this purpose. You might already have
   Rules set up for filtering, index line color, scores, or roles; and you
   may use any of those Rules with the Select command. However, you might
   find it more convenient to set up a separate set of Rules just for this
   purpose without having to worry about what other effects they may
   cause. That is the purpose of these Select Rules.

  Rule Patterns

   In order to determine whether or not a message is selected by a rule
   the message is compared with the rule's Pattern. These Patterns are the
   same for use with Roles, Filtering, Index Coloring, Scoring, Other
   Rules, and Search Rules, so are described in only one place, "here".

   There is no action associated with these Search Rules. Only their
   Patterns are used.

Patterns

   Patterns are used with Roles, Filtering, Index Coloring, Scoring, Other
   Rules, and Search Rules. Patterns are compared with a message to see if
   there is a match. For Filtering, the messages being checked are all the
   messages in the folder, one at a time. For Index Line Coloring, each
   message that is visible on the screen is checked for matches with the
   Index Coloring Patterns. Roles are used with the Reply, Forward, and
   Compose commands. For Reply, the message used to compare the Pattern
   with is the message being replied to; for Forward, the message used to
   compare the Pattern with is the message being forwarded; and for
   Compose, there is no message, so the parts of the Pattern which depend
   on a message (everything other than Current Folder Type and the
   Beginning of Month and Year) are not used. Only the Current Folder Type
   matters for Compose (plus the Beginning of Month or Year, which you
   wouldn't usually use for a Role). For Scoring, the message being scored
   is compared with all of the Score Patterns, and the Score Values from
   the ones that match are added together to get the message's score. For
   Other Rules, there is no message. Only the Current Folder Type is
   checked for Other Rules.

   Each Pattern has several possible parts, all of which are optional. In
   order for there to be a match, _ALL_ of the _defined_ parts of the
   Pattern must match the message. If a part is not defined it is
   considered a match. For example, if the To pattern is not defined it
   will be displayed as

                         To pattern = <No Value Set>

   That is considered a match because it is not defined. This means that
   the Pattern with nothing defined is a match if the Current Folder Type
   matches, but there is an exception. Because filtering is a potentially
   destructive action, filtering Patterns with nothing other than Current
   Folder Type defined are ignored. If you really want a filtering Pattern
   to match all messages (subject to Current Folder Type) the best way to
   do it is to define a Score interval which includes all possible scores.
   This would be the score interval (-INF,INF). This can be used even if
   you haven't defined any rules to Set Scores.

   There are six predefined header patterns called the To, From, Sender,
   Cc, News, and Subject patterns. Besides those six predefined header
   patterns, you may add additional header patterns with header fieldnames
   of your choosing. You add an extra header pattern by placing the cursor
   on one of the patterns while in the role editor and using the
   "eXtraHdr" command. The Recip pattern is a header pattern which stands
   for Recipient (To OR Cc) and the Partic pattern is a header pattern
   which stands for Participant (From OR To OR Cc). (Defining the Recip
   pattern does not have the same effect as defining both the To and Cc
   patterns. Recip is To _OR_ Cc, not To _AND_ Cc.) Similar to the header
   patterns are the AllText pattern and the BodyText pattern. Instead of
   comparing this pattern's text against only the contents of a particular
   header field, the text for the AllText pattern is compared with text
   anywhere in the message's header or body, and the text for the BodyText
   pattern is compared with text anywhere in the message's body.

   Any of the header patterns, the AllText pattern, or the BodyText
   pattern may be negated with the "!" "toggle NOT" command. You can tell
   that _NOT_ has been turned on by looking for the character "!" at the
   beginning of the pattern line. When the "!" is present, it reverses the
   meaning of the match. That is, if the pattern matches then it is
   considered to NOT be a match, and if it does not match it is considered
   to be a match.

   Don't make the mistake of putting the "!" in the data field for a
   pattern. For example, if you type the characters "!urgent" into the
   Subject pattern, the pattern will look like:

 Subject pattern = !urgent

   This means you want to match the 7 character sequence "!urgent". In
   order to match messages which do not have "urgent" in their Subject
   field, first type the characters "urgent" followed by carriage return
   for the value of the Subject pattern, then negate it by typing the "!"
   command. It should look like

 ! Subject pattern = urgent

   The contents of each of these header patterns (or the AllText or
   BodyText patterns) may be a complete email address, part of an address,
   or a random set of characters to match against. It may also be a list
   of such patterns, which means you are looking for a match against the
   first pattern in the list _OR_ the second pattern _OR_ the third and so
   on. For example, a Subject pattern equal to

 Subject pattern = urgent
                   emergency
                   alert

   would match all messages with a subject which contained at least one of
   those words. It would also match subjects containing the words "alerts"
   or "Urgently".

   The same example with "NOT" turned on would be

 ! Subject pattern = urgent
                     emergency
                     alert

   which would match all messages with a subject which did NOT contain any
   of those words. You can use the "Add Value" command to add new words to
   the list, or you can enter them as a comma-separated list.

   (It is not possible to specify two patterns which must _BOTH_ be
   present for a match. It is only possible to specify that _EITHER_
   pattern1 _OR_ pattern2 must be present, and that is exactly what using
   a list does.)

   The "Current Folder Type" and the "Score Interval" are also part of the
   Pattern, although the "Score Interval" is not used when checking for
   matches for Scoring. There are five similar settings which relate to
   the status of the message. These settings rely on the message being New
   or not, Deleted or not, Answered or not, Important or not, and Recent
   or not. There are also some other miscellaneous settings. The first is
   the Age of the message in days. Another is the Size of the message in
   bytes. The third is a setting which detects whether or not the Subject
   of a message contains raw 8-bit characters (unencoded characters with
   the most significant bit set). There is a setting which detects whether
   or not this is the first time _Alpine_ has been run this month (doesn't
   depend on individual messages), and another which detects whether or
   not this is the first time _Alpine_ has been run this year. Other parts
   of the Pattern detect whether or not the From address of a message
   appears in your address book, whether or not certain keywords are set
   for a message, and whether or not certain character sets are used in a
   message.

  Parts of a Pattern

    Header patterns

   A header pattern is simply text which is searched for in the
   corresponding header field. For example, if a Pattern has a From header
   pattern with the value "@company.com", then only messages which have a
   From header which contains the text "@company.com" will be possible
   matches. Matches don't have to be exact. For example, if the relevant
   field of a message contains the text "mailbox@domain" somewhere in it,
   then header patterns of "box", or "x@d", or "mailbox@domain" are all
   matches.

   All parts of the Pattern must match so, for example, if a message
   matches a defined From pattern, it still must be checked against the
   other parts of the Pattern which have been defined. The To header
   pattern is a slightly special case. If the message being checked has a
   Resent-To header and the feature Use-Resent-To-in-Rules is turned on,
   the addresses there are used in place of the addresses in the To
   header. This is only true for the To header. Resent-cc and Resent-From
   headers are never used unless you add them with the eXtraHdrs command.

   The meaning of a header pattern may be negated with the "!" "toggle
   NOT" command. You can tell that _NOT_ has been turned on by looking for
   the character "!" at the beginning of the pattern line. It would look
   something like

 ! From pattern = susan@example.com

   When the "!" is present, it reverses the meaning of the match.

   If you want to check for the presence of a header field but don't care
   about its value, then the empty pattern which you get by entering a
   pair of double quotes ("") should match any message which has the
   corresponding header field.

    AllText patterns

   AllText patterns are just like header patterns except that the text is
   searched for anywhere in the message's headers or body, not just in the
   contents of a particular header field.

    BodyText patterns

   BodyText patterns are just like header patterns except that the text is
   searched for anywhere in the message's body, not just in the contents
   of a particular header field.

   If there is more than one header pattern or AllText pattern or BodyText
   pattern for which you want to take the same action there is a shorthand
   notation which may be used. Any of these patterns may be a list of
   patterns instead of just a single pattern. If any one of the patterns
   in the list matches the message then it is considered a match. For
   example, if "company1" and "company2" both required you to use the same
   role when replying to messages, you might have a To pattern which looks
   like

 To pattern = company1.com
              company2.com

   This means that if the mail you are replying to was addressed to either
   "anything@company1.com" or "anything@company2.com", then this Pattern
   is a match and the same actions will be taken.

   The meaning of an AllText or BodyText pattern may be negated with the
   "!" "toggle NOT" command. You can tell that _NOT_ has been turned on by
   looking for the character "!" at the beginning of the pattern line.
   When the "!" is present, it reverses the meaning of the match.

   A technicality: Since comma is the character used to separate multiple
   values in any of the fields which may have multiple values (such as
   header patterns, AllText patterns, BodyText patterns, keywords, folder
   lists, and so on), you must escape comma with a backslash (\) if you
   want to include a literal comma in one of those fields. In other words,
   if you type a backslash followed by a comma it will be interpreted as a
   comma by _Alpine_, instead of as a separator between pattern values.
   All other backslashes (those not followed by a comma) are literal
   backslashes and should not be escaped. It's unlikely you'll ever need
   to enter a literal comma or backslash in any of the patterns.

    Current Folder Type

   The "Current Folder Type" may be set to one of four different values:
   "Any", "News", "Email", or "Specific". If the value is set to "News",
   then the Pattern will only match if the currently open folder is a
   newsgroup. The value "Email" only matches if the current folder is not
   news and the value "Any" causes any folder to match. If the value of
   "Current Folder Type" is set to "Specific", then you must fill in a
   value for "Folder", which is on the line below the "Specific" line. In
   this case you will only get a match if the currently open folder is the
   specific folder you list. You may give a list of folders instead of
   just a single folder name, in which case the Pattern will match if the
   open folder is any one of the folders in the list. The name of each
   folder in the list may be either "INBOX", the technical specification
   of the folder (like what appears in your configuration file) or, if the
   folder is one of your incoming folders, it may be the nickname you've
   given the folder. Here are some samples of specific folder names:

                    {monet.art.example.com}mail/art-class

                 {news.example.com/nntp}#news.comp.mail.pine

                              mail/local-folder

   The easiest way to fill in the "Folder" field is to use the "T" command
   which is available when the "Folder" line is highlighted, or to use the
   "Take" command with the configuration feature "enable-rules-under-take"
   turned on.

   When reading a newsgroup, there may be a performance penalty incurred
   when collecting the information necessary to check whether or not a
   Pattern matches a message. For this reason, the default Current Folder
   Type is set to "Email". If you have Patterns with a Current Folder Type
   of either "Any" or "News" and those Patterns are used for Index Line
   Coloring or Scoring, you may experience slower screen redrawing in the
   MESSAGE INDEX screen when in a newsgroup.

    Age Interval

   The "Age Interval" may be set to an interval of message ages which
   should be considered a match. Like the other parts of the Pattern, if
   it is unset it will be ignored. The Age Interval looks like

                              (min_age,max_age)

   where "min_age" and "max_age" are integers greater than or equal to
   zero. The special value "INF" may be used for the max value. It
   represents infinity.

   Actually, this option may be defined as a list of intervals instead of
   just a single interval. The list is separated by commas. It can look
   like

                 (min_age1,max_age1),(min_age2,max_age2),...

   When there is an Age Interval defined, it is a match if the age, in
   days, of the message is contained in any of the intervals. The
   intervals include both endpoints.

   Even though this option is called Age, it isn't actually the _age_ of
   the message. Instead, it is how many days ago the message arrived in
   one of your folders. If the current time is a little past midnight,
   then a message that arrived just before midnight arrived yesterday,
   even though the message is only a few minutes old. By default, the date
   being used is not the date in the Date header of the message. It is the
   date that the message arrived in one of your folders. When you Save a
   message from one folder to another that arrival date is preserved. If
   you would like to use the date in the Date header that is possible.
   Turn on the option _use-date-header-for-age_ near the bottom of the
   rule definition.

   A value of 0 is today, 1 is yesterday, 2 is the day before yesterday,
   and so on.

    Size Interval

   The "Size Interval" may be set to an interval of message sizes which
   should be considered a match. Like the other parts of the Pattern, if
   it is unset it will be ignored. The Size Interval looks like

                             (min_size,max_size)

   where "min_size" and "max_size" are integers greater than or equal to
   zero. The special value "INF" may be used for the max value. It
   represents infinity.

   Actually, this option may be defined as a list of intervals instead of
   just a single interval. The list is separated by commas. It can look
   like

               (min_size1,max_size1),(min_size2,max_size2),...

   When there is a Size Interval defined, it is a match if the size, in
   bytes, of the message is contained in any of the intervals. The
   intervals include both endpoints.

    Score Interval

   The "Score Interval" may be set to an interval of message scores which
   should be considered a match. Like the other parts of the Pattern, if
   it is unset it will be ignored. The Score Interval looks like

                            (min_score,max_score)

   where "min_score" and "max_score" are integers between -32000 and
   32000. The special values "-INF" and "INF" may be used for the min and
   max values to represent negative and positive infinity.

   Actually, a list of intervals may be used if you wish. A list would
   look like

             (min_score1,max_score1),(min_score2,max_score2),...

   When there is a Score Interval defined, it is a match if the score for
   the message is contained in any of the intervals in the list. The
   intervals include the endpoints. The score for a message is calculated
   by looking at every Score rule defined and adding up the Score Values
   for the ones which match the message. When deciding whether or not a
   Pattern matches a message for purposes of calculating the score, the
   Score Interval is ignored.

    Message Status

   There are five separate message status settings. By default, all five
   are set to the value "Don't care", which will match any message. The
   value "Yes" means that the particular status must be true for a match,
   and the value "No" means that the particular status must not be true
   for a match. For example, one of the five Message Status settings is
   whether a message is marked Important or not. A "Yes" means that the
   message must be Important to be considered a match and "No" means that
   the message must not be Important to be considered a match. The same is
   true of the other four message status settings which depend on whether
   or not the message is New; whether the message has been Answered or
   not; whether the message has been Deleted or not, and whether the
   message is Recent or not.

   The nomenclature for New and Recent is a bit confusing:

   New means that the message is Unseen. It could have been in your
   mailbox for a long time but if you haven't looked at it, it is still
   considered New. That matches the default _Alpine_ index display that
   shows an N for such a message.

   Recent means that the message was added to this folder since the last
   time you opened the folder. _Alpine_ also shows an N by default for
   these types of messages. If you were to run two copies of _Alpine_ that
   opened a folder one right after the other, a message would only show up
   as Recent in (at most) the first _Alpine_ session.

    Message Keywords

   Keywords are similar to Message Status, but they are chosen by the
   user. Provided the mail server allows for it, you may add a set of
   possible keywords to a folder and then you may set those keywords or
   not for each message in the folder. The syntax of this part of the
   Pattern is similar to the header patterns. It is a list of keywords.
   The Keyword part of the Pattern is a match if the message has any of
   the keywords in the list set. Like other parts of the Pattern, if this
   is unset it will be ignored.

    Message Character Set

   A message may use one or more character sets. This part of the Pattern
   matches messages which make use of one or more of the character sets
   specified in the pattern. It will be considered a match if a message
   uses any of the character sets in the list you give here. The syntax of
   this part of the Pattern is similar to the header patterns and the
   Message Keywords pattern. It is a list of character sets.

   Besides actual character set names (for example, ISO-8859-7, KOI8-R, or
   GB2312) you may also use some shorthand names that _Alpine_ provides.
   These names are more understandable shorthand names for sets of
   character set names. Two examples are "Cyrillic" and "Greek". Selecting
   one of these shorthand names is equivalent to selecting all of the
   character sets that make up the set. You can see all of these shorthand
   names and the lists of character sets they stand for by typing the "T"
   command with the Character Set pattern highlighted. The Character Set
   part of the Pattern is a match if the message uses any of the character
   sets in the list. Like other parts of the Pattern, if this is unset it
   will be ignored.

    Raw 8-bit in Subject

   It seems that lots of unwanted email contains unencoded 8-bit
   characters in the Subject. Normally, characters with the 8th bit set
   are not allowed in the Subject header unless they are MIME-encoded.
   This option gives you a way to match messages which have Subjects which
   contain unencoded 8-bit characters. Setting this option will affect
   performance in large folders because the subject of each message in the
   folder has to be checked.

    Beginning of Month

   This option gives you a way to take some action once per month. The
   value "Yes" means that this must be the first time _Alpine_ has been
   run this month in order to count as a match,

    Beginning of Year

   This option gives you a way to take some action once per year. The
   value "Yes" means that this must be the first time _Alpine_ has been
   run this year in order to count as a match,

    From or Reply-To address in Address Books

   This option gives you a way to match messages which have a From or a
   Reply-To address which is in one of your address books. Only the simple
   entries in your address books are searched. Address book distribution
   lists are ignored! Setting this option will affect performance in large
   folders because the From and Reply-To of each message in the folder
   have to be checked.

    Categorizer Command

   This is a command that is run with its standard input set to the
   message being checked and its standard output discarded. The full
   directory path should be specified. The command will be run and then
   its exit status will be checked against the Exit Status Interval, which
   defaults to just the value zero. If the exit status of the command
   falls in the interval, it is considered a match, otherwise it is not a
   match.

   This option may actually be a list of commands. The first one that
   exists and is executable is used. That makes it possible to use the
   same configuration with Unix _Alpine_ and _PC-Alpine_.

   If none of the commands in the list exists and is executable then the
   rule is _not_ a match. If it is possible that the command may not
   exist, you should be careful to structure your rules so that nothing
   destructive happens when the command does not exist. For example, you
   might have a filter that filters away spam when there is a match but
   does nothing when there is not a match. That would continue to work
   correctly if the command didn't exist. However, if you have a filter
   which filters away spam when there is not a match and keeps it when
   there is a match, that would filter everything if the categorizer
   command didn't exist.

  Help Configuring Pattern Fields

   _Nickname_
          This is a nickname to help you. You should have a different
          nickname for each role you define. The nickname will be used in
          the SETUP ROLE RULES screen to allow you to pick a role to edit.
          It will also be used when you send a message to let you know you
          are sending with a different role than you use by default, and
          it will be useful for choosing a role when composing with the
          Role command or when composing with one of the Role Uses set to
          With Confirmation. This field is not used in the outgoing
          message.
   _Comment_
          This is a comment to help you. This comment does not play any
          functional role, it is simply an optional comment to help you
          remember what the rule is for.
   _To pattern_
          If this pattern is non-blank, then for this role to be
          considered a match, at least one of the recipients from the To
          line of the message being replied to or forwarded must match
          this pattern. In the case of the Compose command, this pattern
          and the other header patterns are ignored. If this pattern is a
          list of patterns, then at least one of the recipients must match
          at least one of the patterns. (Any other non-blank parts of the
          Pattern must match, too.) If the message being replied to or
          forwarded has a Resent-To header line, then that is used in
          place of the To line. (Note that this special Resent rule only
          applies to the To header. The Resent-From, Resent-Subject, and
          so on are not consulted.)
          It is possible to add a _NOT_ to the To Pattern meaning with the
          "!" "toggle NOT" command. This changes the meaning of the To
          pattern so that it has the opposite meaning. It will be
          considered a match if there are no matches between the addresses
          in the To: line and the list of To patterns.
          Don't make the mistake of putting the "!" in the data field for
          the pattern. For example, if you type the characters "!frizzle"
          into the To pattern, the pattern will look like:
 To pattern = !frizzle

          This means you want to match the 8 character sequence
          "!frizzle". In order to match messages which do not have
          "frizzle" in their To field, first type the characters "frizzle"
          followed by carriage return for the value of the To pattern,
          then negate it by typing the "!" command. It should end up
          looking like
 ! To pattern = frizzle

   _From pattern_
          This is just like the To pattern except that it is compared with
          the address from the From header of the message being replied to
          or forwarded instead of the addresses from the To header.
   _Sender pattern_
          This is just like the To pattern except that it is compared with
          the address from the Sender header of the message being replied
          to or forwarded instead of the addresses from the To header. If
          there is no Sender header, then the From header is used instead.
   _Cc pattern_
          This is just like the To pattern except that it is compared with
          the address from the CC header of the message being replied to
          or forwarded instead of the addresses from the To header.
   _News pattern_
          If this pattern is non-blank, then for this role to be
          considered a match, at least one of the newsgroups from the
          Newsgroups line of the message must match this pattern. If this
          pattern is a list of patterns, then at least one of the
          newsgroups must match at least one of the patterns. (Any other
          non-blank parts of the Pattern must match, too.)
   _Subject pattern_
          This is similar to the other header patterns. It is compared
          with the contents from the Subject of the message being replied
          to or forwarded.
          If you enter non-ascii characters in this field then the search
          will be done using the character set you have defined with the
          Character-Set configuration variable. (The truly sophisticated
          may use an alternate character set for a search by entering the
          MIME encoding of the header string here.)
   _Extra header patterns_
          There isn't actually a field called Extra header patterns, but
          you may add extra header patterns by moving the cursor to one of
          the header patterns and using the "eXtraHdr" command to add a
          new header pattern. You would do this if the six predefined
          header patterns don't cover the header you want to use for
          pattern matching. Once you've added an extra header pattern, you
          use it just like the Subject pattern. Of course, it is compared
          with the contents from the particular header field of the
          message being replied to or forwarded rather than the contents
          from the subject field. To remove an extra header pattern from a
          role, use the &quotRemoveHdr" command on the highlighted extra
          header.
          If you enter non-ascii characters in this field then the search
          will be done using the character set you have defined with the
          Character-Set configuration variable. (The truly sophisticated
          may use an alternate character set for a search by entering the
          MIME encoding of the header string here.)
   _Recipient pattern_
          This is just like the To pattern except that it is compared with
          the addresses from both the To header and the Cc header instead
          of just the addresses from the To header. It's equivalent to
          having two different rules; one with a To pattern and the other
          with the same Cc pattern.
   _Participant pattern_
          This is just like the To pattern except that it is compared with
          the addresses from the To header, the Cc header, and the From
          header instead of just the addresses from the To header. It's
          equivalent to having three different rules; one with a To
          pattern, another with the same Cc pattern, and another with the
          same From pattern.
   _AllText pattern_
          This is similar to the header patterns. Instead of comparing
          with text in a particular header field it is compared with all
          of the text in the message header and body.
          If you enter non-ascii characters in this field then the search
          will be done using the character set you have defined with the
          Character-Set configuration variable. (The truly sophisticated
          may use an alternate character set for a search by entering the
          MIME encoding of the header string here.)
   _BodyText pattern_
          Just like AllText, except it is compared only with the body of
          the message, not the body and header.
          If you enter non-ascii characters in this field then the search
          will be done using the character set you have defined with the
          Character-Set configuration variable. (The truly sophisticated
          may use an alternate character set for a search by entering the
          MIME encoding of the header string here.)
   _Age Interval_
          The Age Interval, if defined, is part of the Pattern. If you use
          this, it should be set to something like:

                              (min_age,max_age)
          where "min_age" and "max_age" are non-negative integers. The
          special value "INF" may be used for the max value. It represents
          infinity.
          In rare cases it may be useful to use the more general form of
          the value, which is a comma-separated list of intervals. It
          would look something like:

                 (min_age1,max_age1),(min_age2,max_age2),...
          When there is an Age Interval defined, it is a match if the age,
          in days, of the message is contained in the interval. The
          interval includes both endpoints. If the option is set to a list
          of intervals then it is a match if the age of the message is
          contained in any of the intervals.
          Even though this option is called Age, it isn't actually the
          _age_ of the message. Instead, it is how many days ago the
          message arrived in one of your folders. If the current time is a
          little past midnight, then a message that arrived just before
          midnight arrived yesterday, even though the message is only a
          few minutes old. By default, the date being used is not the date
          in the Date header of the message. It is the date that the
          message arrived in one of your folders. When you Save a message
          from one folder to another that arrival date is preserved. If
          you would like to use the date in the Date header that is
          possible. Turn on the option _use-date-header-for-age_ near the
          bottom of the rule definition.
          A value of 0 is today, 1 is yesterday, 2 is the day before
          yesterday, and so on. The age interval

                                    (2,2)
          matches all messages that arrived on the day before yesterday.
          The interval

                                  (180,INF)
          matches all messages that arrived at least 180 days before
          today. The interval

                                    (0,1)
          matches all messages that arrived today or yesterday.
   _Score Interval_
          The Score Interval, if defined, is part of the Pattern. If you
          use this, it should be set to something like:

                            (min_score,max_score)
          where "min_score" and "max_score" are integers between -32000
          and 32000. The special values "-INF" and "INF" can be used for
          the min and max values. These represent negative and positive
          infinity.
          Actually, the value may be a list of intervals rather than just
          a single interval if that is useful. The elements of the list
          are separated by commas like:

             (min_score1,max_score1),(min_score2,max_score2),...
          When there is a Score Interval defined, it is a match if the
          score for the message is contained in any of the intervals. The
          intervals include both endpoints. The score for a message is
          calculated by looking at every scoring rule defined and adding
          up the Score Values for the rules which match the message.
   _Keyword pattern_
          A folder may have user-defined keywords. These are similar to
          the Important flag which the user may set using the Flag
          command. The difference is that the Important flag is always
          present for each folder. User-defined keywords are picked by the
          user. You may add new keywords by defining them in the Keywords
          option in the Setup/Config screen. After you have added a
          potential keyword with the Keywords option, the Flag command may
          be used to set or clear the keyword on individual messages. If
          you have given a keyword a nickname when configuring it, that
          nickname may be used instead of the actual keyword.
          When filling in a value for this field, it may be easiest to use
          the "T" command, which presents you with a list of the keywords
          you have defined to choose from.
          This part of the Pattern matches messages with certain keywords
          set. It will be considered a match if a message has any of the
          keywords in the list set.
          It is possible to add a _NOT_ to the Keyword Pattern meaning
          with the "!" "toggle NOT" command. This changes the meaning of
          the Keyword pattern so that it has the opposite meaning. It will
          be considered a match if none of the keywords in the list are
          set for a message.
          Don't make the mistake of putting the "!" in the data field for
          the pattern. For example, if you type the characters "!frizzle"
          into the Keyword pattern, the pattern will look like:
 Keyword pattern = !frizzle

          This means you want to match the 8 character sequence
          "!frizzle". In order to match messages which do not have the
          keyword "frizzle" set, first type the characters "frizzle"
          followed by carriage return for the value of the Keyword
          pattern, then negate it by typing the "!" command. It should end
          up looking like
 ! Keyword pattern = frizzle

   _Character Set pattern_
          A message may use one or more character sets. This part of the
          Pattern matches messages which make use of certain specified
          character sets. It will be considered a match if a message uses
          any of the character sets in the list you give here.
          When filling in a value for this field, you may use the "T"
          command, which presents you with a large list of possible
          character sets to choose from. You may also just type in the
          name of a character set, and it need not be one that Alpine
          knows about.
          Besides actual character set names (for example, ISO-8859-7,
          KOI8-R, or GB2312) you may also use some shorthand names that
          Alpine provides. These names are more understandable shorthand
          names for sets of character set names. Two examples are
          "Cyrillic" and "Greek". Selecting one of these shorthand names
          is equivalent to selecting all of the character sets that make
          up the set. You can see all of these shorthand names and the
          lists of character sets they stand for by typing the "T"
          command.
          For the purposes of this Pattern, _Alpine_ will search through a
          message for all of the text parts and collect the character sets
          declared for each part. It will also look in the Subject line
          for a character set used there. _Alpine_ does not actually look
          at the text of the message or the text of the Subject to
          determine if a declared character set is actually used, it looks
          only at the declarations themselves in the MIME part headers and
          in the Subject.
          It is possible to add a _NOT_ to the Character Set Pattern
          meaning with the "!" "toggle NOT" command. This changes the
          meaning of the Character Set pattern so that it has the opposite
          meaning. It will be considered a match if none of the character
          sets in the list are used in a message.
          Don't make the mistake of putting the "!" in the data field for
          the pattern. For example, if you type the characters "!GB2312"
          into the Character Set pattern, the pattern will look like:
 Charset pattern = !GB2312

          This means you want to match the 7 character sequence "!GB2312".
          In order to match messages which do not have the character set
          "GB2312" set, first type the characters "GB2312" followed by
          carriage return for the value of the Character Set pattern, then
          negate it by typing the "!" command. It should end up looking
          like
 ! Charset pattern = GB2312

          A technicality: Since comma is the character used to separate
          multiple values in a pattern field, you have to escape comma
          with a backslash (\) if you want to include a literal comma in
          the field. In other words, if you type a backslash followed by a
          comma it will be interpreted as a comma by _Alpine_, instead of
          as a separator between pattern values. All other backslashes are
          literal backslashes and should not be escaped.
   _Current Folder Type_
          The Current Folder Type is part of the Pattern. It refers to the
          type of the currently open folder, which is the folder you were
          last looking at from the MESSAGE INDEX or MESSAGE TEXT screen.
          In order for a pattern to be considered a match, the current
          folder must be of the type you set here. The three types "Any",
          "News", and "Email" are all what you might think.
          If the Current Folder Type for a Pattern is set to "News", for
          example, then that will only be a match if the current folder is
          a newsgroup and the rest of the Pattern matches. The value
          "Specific" may be used when you want to limit the match to a
          specific folder (not just a specific type of folder), or to a
          list of specific folders. In order to match a specific folder
          you must Select the "Specific" button _AND_ you must fill in the
          name (or list of names) of the folder in the "Folder" field. If
          the current folder is any of the folders in the list, that is
          considered a match. The name of each folder in the list may be
          either "INBOX", the technical specification of the folder (like
          what appears in your configuration file) or, if the folder is
          one of your incoming folders, it may be the nickname you've
          given the folder. Here are a couple samples of specific folder
          names:

                    {monet.art.example.com}mail/art-class

                 {news.example.com/nntp}#news.comp.mail.pine
          The easiest way to fill in the "Folder" field is to use the T
          command which is available when the "Folder" line is
          highlighted. Note that you won't be able to edit the "Folder"
          line unless the Current Folder Type is set to "Specific", and
          any value that "Folder" has is ignored unless the type is set to
          "Specific".
          When reading a newsgroup, there may be a performance penalty
          incurred when collecting the information necessary to check a
          Pattern. For this reason, the default Current Folder Type is set
          to "Email". For example, a role with a non-Normal Index Line
          Color and a Current Folder Type of "Any" or "News" may cause the
          MESSAGE INDEX screen to draw more slowly when in a newsgroup.
   _Message Status Important_
          This part of the Pattern may have one of three possible values.
          The default value is "Don't care", which matches any message.
          The other two values are "Yes", which means the message must be
          flagged "Important" in order to be a match; or "No", which means
          the message must _not_ be flagged "Important" in order to be
          considered a match.
   _Message Status New_
          This part of the Pattern may have one of three possible values.
          The default value is "Don't care", which matches any message.
          The other two values are "Yes", which means the message must be
          "New" in order to be a match; or "No", which means the message
          must _not_ be "New" in order to be a match. "New" is the same as
          _Unseen_ and not "New" is the same as _Seen_.
          The nomenclature for New and Recent is a bit confusing:
          New means that the message is Unseen. It could have been in your
          mailbox for a long time but if you haven't looked at it, it is
          still considered New. That matches the default _Alpine_ index
          display that shows an N for such a message.
          Recent means that the message was added to this folder since the
          last time you opened the folder. _Alpine_ also shows an N by
          default for these types of messages. If you were to run two
          copies of _Alpine_ that opened a folder one right after the
          other, a message would only show up as Recent in (at most) the
          first _Alpine_ session.
   _Message Status Recent_
          This part of the Pattern may have one of three possible values.
          The default value is "Don't care", which matches any message.
          The other two values are "Yes", which means the message must be
          "Recent" in order to be a match; or "No", which means the
          message must _not_ be "Recent" in order to be a match. "Recent"
          means that the message was added to the folder since the last
          time the folder was opened. If more than one mail client has the
          folder opened, the message will appear to be "Recent" to only
          one of the clients.
          The nomenclature for New and Recent is a bit confusing:
          New means that the message is Unseen. It could have been in your
          mailbox for a long time but if you haven't looked at it, it is
          still considered New. That matches the default _Alpine_ index
          display that shows an N for such a message.
          Recent means that the message was added to this folder since the
          last time you opened the folder. _Alpine_ also shows an N by
          default for these types of messages. If you were to run two
          copies of _Alpine_ that opened a folder one right after the
          other, a message would only show up as Recent in (at most) the
          first _Alpine_ session.
   _Message Status Deleted_
          This part of the Pattern may have one of three possible values.
          The default value is "Don't care", which matches any message.
          The other two values are "Yes", which means the message must be
          marked "Deleted" in order to be a match; or "No", which means
          the message must _not_ be marked "Deleted" in order to be a
          match.
          If you are thinking of using this part of the Pattern as a way
          to prevent messages from being filtered more than once in a
          Filter Pattern, take a look at the Filter Option
          "move-only-if-not-deleted" instead. It should work better than
          using this field since it will hide the filtered messages even
          if they are already Deleted.
   _Message Status Answered_
          This part of the Pattern may have one of three possible values.
          The default value is "Don't care", which matches any message.
          The other two values are "Yes", which means the message must be
          marked "Answered" in order to be a match; or "No", which means
          the message must _not_ be marked "Answered" in order to be a
          match.
   _Subject Contains Raw 8-bit_
          This part of the Pattern may have one of three possible values.
          The default value is "Don't care", which matches any message.
          The other two values are "Yes", which means the Subject of the
          message must contain unencoded 8-bit characters (characters with
          the most significant bit set) in order to be a match; or "No",
          which means the Subject must _not_ contain unencoded 8-bit
          characters in order to be a match.
   _Beginning of Month_
          This part of the Pattern may have one of three possible values.
          The default value is "Don't care", which matches any message.
          The other two values are "Yes", which means this is the first
          time _Alpine_ has been run this month; or "No", which means this
          is _not_ the first time _Alpine_ has been run this month. The
          way that _Alpine_ decides if it is the beginning of the month or
          not is to compare today's date with the date stored in the
          Last-Time-Prune-Questioned variable in the config file. If the
          month of today's date is later than the month stored in the
          variable, then this is considered to be the first time you have
          run Alpine this month, and that turns the Beginning of the Month
          option on.
   _Beginning of Year_
          This part of the Pattern may have one of three possible values.
          The default value is "Don't care", which matches any message.
          The other two values are "Yes", which means this is the first
          time _Alpine_ has been run this year; or "No", which means this
          is _not_ the first time _Alpine_ has been run this year. The way
          that _Alpine_ decides if it is the beginning of the year or not
          is to compare today's date with the date stored in the
          Last-Time-Prune-Questioned variable in the config file. If the
          year of today's date is later than the year stored in the
          variable, then this is considered to be the first time you have
          run Alpine this year, and that turns the Beginning of the Year
          option on.
   _From or Reply-To in Address Book_
          This part of the Pattern may have one of five possible values.
          The default value is "Don't care", which matches any message.
          The value "Yes, in any address book" means either the From
          address or the Reply-To address of the message must be in at
          least one of your address books in order to be a match. The
          value "No, not in any address book" means neither the From nor
          the Reply-To addresses may be in any of your address books in
          order to be a match.
          The values "Yes, in specific address books" and "No, not in any
          of specific address books" are similar but instead of depending
          on all address books you are allowed to give a list of address
          books to look in. Usually this would be a single address book
          but it may be a list of address books as well. For each of these
          "specific" address book options you Select which of the Specific
          options you want (Yes or No) _AND_ fill in the name (or list of
          names) of the address book in the "Abook List" field. The names
          to be used are those that appear in the ADDRESS BOOK LIST
          screen. The easiest way to fill in the Abook List field it to
          use the "T" command which is available when the "Abook List"
          line is highlighted. Note that you won't be able to edit the
          "Abook List" line unless the option is set to one of the two
          "Specific", values.
   _Categorizer Command_
          This is a command that is run with its standard input set to the
          message being checked and its standard output discarded. The
          full directory path should be specified. The command will be run
          and then its exit status will be checked against the _Exit
          Status Interval_, which defaults to just the value zero. If the
          exit status of the command falls in the interval, it is
          considered a match, otherwise it is not a match.
          This option may actually be a list of commands. The first one
          that exists and is executable is used. That makes it possible to
          use the same configuration with Unix _Alpine_ and _PC-Alpine_.
          If none of the commands in the list exists and is executable
          then the rule is _not_ a match. If it is possible that the
          command may not exist, you should be careful to structure your
          rules so that nothing destructive happens when the command does
          not exist. For example, you might have a filter that filters
          away spam when there is a match but does nothing when there is
          not a match. That would continue to work correctly if the
          command didn't exist. However, if you have a filter which
          filters away spam when there is not a match and keeps it when
          there is a match, that would filter everything if the
          categorizer command didn't exist.
          The categorizer command is run and the result is the exit status
          of that command. If that exit status falls in the _Exit Status
          Interval_ then it is considered a match, otherwise it is not a
          match. Of course for the entire rule to match, it must also be
          checked against the other defined parts of the Pattern.
          The _Exit Status Interval_ defaults to the single value 0
          (zero). If you define it, it should be set to something like:

                       (min_exit_value,max_exit_value)
          where "min_exit_value" and "max_exit_value" are integers. The
          special values "INF" and "-INF" may be used for large positive
          and negative integers.
          Actually, a list of intervals may be used if you wish. A list
          would look like

   (min_exit_value1,max_exit_value1),(min_exit_value2,max_exit_value2),...
          When there is an _Exit Status Interval_ defined, it is a match
          if the exit status of the categorizer command is contained in
          any of the intervals. The intervals include both endpoints.
          The default interval is

                                    (0,0)
          and it matches only if the command exits with exit status equal
          to zero.
          It is also possible to set a _Character Limit_ for the
          categorizer command. Setting this option makes it possible to
          limit how much of the message is made available to the
          categorizer command as input. The default value (-1) means that
          the entire message is fed to the command. A value of 0 (zero)
          means that only the headers of the message are made available. A
          positive integer means that the headers plus that many
          characters from the body of the message are passed to the
          categorizer.

Configuring News

   _Alpine_ can access news folders in any one of three different ways:

   REMOTE NNTP
          Using the Network News Transport Protocol (NNTP) to access news
          on a remote news server. In this case the newsrc file is stored
          on the machine where _Alpine_ is running.

          To specify a remote news-collection accessed via NNTP use the
          SETUP/collectionList screen's "Add" command. Set the Server:
          value to the NNTP server's hostname appended with the
          communication method "/service=NNTP", and set the Path: value to
          the "#news." namespace (without the quotes).

          Instead of specifying a news-collection, you may simply set the
          nntp-server option, which will cause _Alpine_ to create a
          default news-collection for you. Another NNTP option which may
          be of interest is nntp-range.

   REMOTE IMAP
          Using the Internet Message Access Protocol (IMAP) to access news
          on a remote news server. In this case, your newsrc file is
          stored on the news server, in your home directory, so you must
          have an account on the news server, but you would be running
          _Alpine_ on a different machine. The news server must be running
          an IMAPd server process.

          To specify a remote news-collection accessed via IMAP use the
          SETUP/collectionList screen's "Add" command. Set the Server:
          value to the IMAP server's hostname, and set the Path: value to
          the "#news." namespace (without the quotes).

   LOCAL
          Using local file access to the news database. In this case, your
          newsrc file is stored on the news server, in your home
          directory, so you must have an account on the news server, and
          you would be running _Alpine_ on the same machine.

          To specify a local news-collection use the SETUP/collectionList
          screen's "Add" command. Leave the Server: value blank, and set
          the Path: value to the "#news." namespace (without the quotes).

   NOTE: Should no news-collection be defined as above, _Alpine_ will
   automatically create one using the Setup/Config screen's "nntp-server"
   variable's value if defined. The collection will be created as a
   "Remote NNTP" as described above.

   If you are a _PC-Alpine_ user, either option 1 (NNTP) or option 2
   (IMAP) is possible. If you don't have an account on the news server, or
   if the news server is not running an IMAP daemon, then you must use
   NNTP. (If you are not sure, ask your service provider, university, or
   company for help.) In this case, your Unix .newsrc file can be
   transferred to your PC. A good place to put it would be in the same
   directory as your PINERC file, under the name NEWSRC, but you can
   specify a different location.

   Other configuration features related to news are
   Enable-8bit-Nntp-Posting. Compose-Sets-Newsgroup-Without-Confirm,
   News-Approximates-New-Status, News-Deletes-Across-Groups,
   News-Offers-Catchup-On-Close, News-Post-Without-Validation,
   News-Read-in-Newsrc-Order, and Quell-Extra-Post-Prompt.
     __________________________________________________________________

                     Notes on Configuration and Preferences

Alpine in Function Key Mode

   The standard _Alpine_ uses alphabetic keys for most commands, and
   control keys in the composer. Despite possible appearances, the current
   bindings are the result of much discussion and thought. All the
   commands in the composer are single control characters. This keeps
   things very neat and simple for users. Two character commands in the
   composer are a possibility, but we're trying to avoid them because of
   the added complexity for the user.

   _Alpine_ can also operate in a function-key mode. To go into this mode
   invoke _alpine -k_ or (on some UNIX systems) _alpinef._ On a UNIX
   system, you can link or copy the _Alpine_ executable to _alpinef_ to
   install _alpinef._ Alternatively, users and systems administrators can
   set the _use-function-keys_ feature in the personal or system-wide
   _Alpine_ configuration file. The command menus at the bottom of the
   screen will show _F1-F12 _instead of the alphabetic commands. In
   addition, the help screens will be written in terms of function keys
   and not alphabetic keys.

   One of the results of using _Alpine_ in function-key mode is that users
   can only choose from twelve commands at any given time. In
   alphabetic-key mode, a user can press a key for a command (say, q to
   quit) and that command can be fulfilled. In function-key mode, the
   command must be visible on the bottom key-menu in order to be used.
   There are some screens where four screens of commands are operational;
   function-key users can get to all of them, just not all at once.
     __________________________________________________________________

Domain Settings

   _Alpine_ uses the default domain for a few different tasks. First, it
   is tacked onto the user-id for outgoing email. Second, it is tacked
   onto all "local" (unqualified) addresses in the "To:" or "Cc:" fields
   of messages being composed (unless they are found in the address book
   or on an LDAP server). The domain name is also used to generate
   message-id lines for each outgoing message and to allow _Alpine_ to
   check if an address is that of the current _Alpine_ user.

   _Alpine_ determines the domain name according to whichever of these it
   finds. The list here is in decreasing order of precedence.
    1. Value of the variable user-domain in the system fixed configuration
       file
    2. Value of the variable _user-domain_ in the personal configuration
       file
    3. Value of the variable _user-domain_ in the system-wide
       configuration file
    4. Value from an external database (DNS, /etc/hosts, NIS) as modified
       by a system fixed configuration file if use-only-domain-name set to
       _yes_
    5. Value from an external database (DNS, /etc/hosts, NIS) as modified
       by a personal configuration file if _use-only-domain-name_ set to
       _yes_
    6. Value from an external database (DNS, /etc/hosts, NIS) as modified
       by a system configuration file if _use-only-domain-name_ set to
       _yes_
    7. Unmodified value (host name) from an external database

   The easiest way for this system to work is for _PC-Alpine_ users and
   UNIX _Alpine_ system administrators to set the _user-domain_ variable.
   The variable _use-only-domain-name_ is helpful if your site
   supports/requires hostless addressing, but for some reason you don't
   want to use the _user-domain_ variable.
     __________________________________________________________________

Syntax for Collections

   In many environments, it is quite common to have collections of
   archived mail on various hosts around the network. Using the folder
   collections facility in _Alpine_, access to these archives is just as
   simple as access to folders on _Alpine_'s local disk.

   "Collection" is the word we use in _Alpine_ to describe a set of
   folders. A collection corresponds loosely to a "directory" containing
   mail folders. Folders within a defined collection can be manipulated
   (opened, saved-to, etc) using just their simple name. Any number of
   folder collections can be defined, and _Alpine_ will adjust its menus
   and prompts to help navigate them.

   The way collections are defined in _Alpine_ is with the
   folder-collections variable in the _Alpine_ configuration file.
   _Folder-collections_ takes a list of one or more collections, each
   (optionally) preceded by a user-defined logical name (label). Once
   collections are defined, _Alpine_ adjusts its menus and behavior to
   allow choosing files by their simple name within the collection.

   Consider the following:
   folder-collections=  Local-Mail      C:\MAIL\[],
                        Remote-Mail     {imap.u.example.edu}mail/[]

   The example shows two collections defined (a comma separated list;
   newlines in the list are OK if there's one or more spaces before the
   next entry), one local and one remote. Each collection is a
   space-delimited pair of elements-first an optional logical-name and
   second the collection specifier. The logical-name can have spaces if it
   has quotes around it (but keeping the logical name short and
   descriptive works best). _Alpine_ will use the logical-name (if
   provided) to reference all folders in the collection, so the user never
   has to see the ugliness of the collection specifier.

   The collection specifier can be thought of as an extended IMAP format
   (see the Remote Folders section for a description of IMAP format
   names). Basically, a pair of square-brackets are placed in the fully
   qualified IMAP path where the simple folder name (the part without the
   host name and path) would appear. Like IMAP, the path can be either
   fully qualified (i.e., with a leading '/') or relative to your home
   directory.

   An advanced feature of this notation is that a pattern within the
   square brackets allows the user to define a collection to be a subset
   of a directory. For example, a collection defined with the specifier:
        M-Mail          C:MAIL/[m*]


   will provide a view in the folder lister of all folders in the PC's
   "C:MAIL" directory that start with the letter 'm' (case insensitive
   under DOS, of course). Further, the wildcard matching will honor
   characters trailing the '*' in the pattern.

   From within _Alpine_, the "Folder List" display will be adjusted to
   allow browsing of the folders in any defined collection. Even more,
   you'll notice in the _Goto_ and _Save_ commands a pair of sub-commands
   to rotate through the list of logical collection names, so only a
   simple name need be input in order to operate on a folder in any
   collection.

   The first collection specified in the _folder-collections_ has special
   significance. That folder is the "default collection for saves". By
   default, in cases where the user does not specify which collection
   should be used to _Save_ a message, the default collection for saves
   will be used. Also, if the default-fcc is a relative file name, then it
   is relative to the default collection for saves. (See also
   saved-msg-name-rule.

   The notion of collections encompasses both email folders and news
   reading. The variable news-collections uses nearly the same format as
   _folder-collections_. Newsgroups can be defined for convenient access
   via either IMAP or NNTP. There are advantages and disadvantages to both
   access methods. In the IMAP case, your news environment state is
   maintained on the server and, thus, will be seen by any client. The
   downside is that, at the moment, you must have an account on the
   server. In the NNTP case, server access is mostly anonymous and no
   state/accounting need be maintained on it. The downside is that each
   client, for now, must individually maintain news environment state.

   An example pinerc entry might be:
     news-collections=  Remote-State    {news.u.example.edu}#news.[],
                        Local-State     {news.u.example.edu/nntp}#news.[]

   Only newsgroups to which you are subscribed are included in the
   collection.

   The pattern matching facility can be applied so as to define a news
   collection which is a subset of all the newsgroups you subscribe to.
   For example, this could be a valid collection:
                        Newsfeed-News   {news.u.example.edu/nntp}#news.[clari.*]

   Collection handling is a tough problem to solve in a general way, and
   the explanation of the syntax is a bit ugly. The upside is, hopefully,
   that for a little complexity in the _Alpine_ configuration file you get
   simple management of multiple folders in diverse locations.

   Collection setup is handled by the _Setup/collectionList_ screen.
     __________________________________________________________________

Syntax for Folder Names

   Remote folders are distinguished from local folders by a leading host
   name bracketed by '{' and '}'. The path and folder name immediately
   following the closing bracket, '}', is interpreted by the remote server
   and is in a form compatible with that server (i.e., path delimiters and
   naming syntax relative to that server).

   The full syntax for a _Alpine_ folder name looks like

      [{<remote-specification>}][#<namespace>]<namespace-specific-part>

   The square brackets ([]) mean that the part is optional.

   If there is no remote-specification, then the folder name is
   interpreted locally on the computer running _Alpine_. Local folder
   names depend on the operating system used by the computer running
   _Alpine_, as well as the configuration of that system. For example,
   "C:\ALPINE\FOLDERS\OCT-94" might exist on a PC, and
   "~/mail/september-1994" might be a reasonable folder name on a system
   running Unix.

   _Alpine_ users have the option of using folders which are stored on
   some other computer. _Alpine_ accesses remote folders via IMAP (the
   Internet Message Access Protocol), or in the case of news, via NNTP
   (the Network News Transport Protocol). To be able to access remote
   folders in _Alpine_, the remote host must be running the appropriate
   server software (imapd or nntpd) and you must correctly specify the
   name of the folder to _Alpine_, including the domain name of the remote
   machine. For example,

                        {monet.art.example.com}INBOX

   could be a remote folder specification, and so could

               {unixhost.art.example.com}~/mail/september-1994

   and

                   {winhost.art.example.com}\mymail\SEP-94

   Note that in the case of remote folders, the directory/file path in the
   specification is determined by the operating system of the remote
   computer, _not_ by the operating system of the computer on which you
   are running _Alpine_.

   As you can tell, the name of the computer is in {} brackets followed
   immediately by the name of the folder. (In each of these cases the
   optional namespace is missing.) If, as in these examples, there is no
   remote access protocol specified, then IMAP is assumed. Check Server
   Name Syntax for a more detailed look at what options can be placed
   between the brackets. If there are no brackets at all, then the folder
   name is interpreted locally on the computer on which you are running
   _Alpine_.

   To the right of the brackets when a server name is present, or at the
   start of the foldername if no server is present, the sharp sign, "#",
   holds special meaning. It indicates a folder name outside the area
   reserved for your personal folders. In fact, it's used to indicate both
   the name of the folder, and a special phrase telling _Alpine_ how to
   interpret the name that follows.

   So, for example, _Alpine_ can be used to access a newsgroup that might
   be available on your computer using:

                            #news.comp.mail.pine

   The sharp sign indicates the folder name is outside your personal
   folder area. The "news." phrase after it tells _Alpine_ to interpret
   the remainder of the name as a newsgroup.

   Similarly, to access a newsgroup on your IMAP server, you might use
   something like:

                {wharhol.art.example.com}#news.comp.mail.misc

   There are a number of such special phrases (or "namespaces") available.
   For a more detailed explanation read about Namespaces.

   Note that "INBOX" has special meaning in both local and remote folder
   names. The name INBOX refers to your "principal incoming message
   folder" and will be mapped to the actual file name used for your INBOX
   on any given host. Therefore, a name like "{xxx.art.example.com}INBOX"
   refers to whatever file is used to store incoming mail for you on that
   particular host.
     __________________________________________________________________

Server Name Syntax

   This section describes the syntax which may be used for server names
   which may be associated with remote folders or SMTP servers.

   A server name is the hostname of the server. It's a good idea to use
   the host's fully-qualified network name.

                               foo.example.com

   However, IP addresses are allowed if surrounded with square-brackets.

                                 [127.0.0.1]

   An optional network port number may be supplied by appending a colon
   (:) followed by the port number to the server name. By default, the
   IMAP port number, 143, is used.

                            foo.example.com:port

   Besides server name and optional port number, various other optional
   parameters may be supplied that alter _Alpine_'s interaction with the
   server. A parameter is supplied by appending a slash (/) character
   followed by the parameter's name and, depending on the particular
   parameter, the value assigned to that name, to the server name (and
   optional port number). Parameter names are _not_ case sensitive.
   Currently supported parameters include:

   User
          This parameter requires an associated value, and is intended to
          provide the username identifier with which to establish the
          server connection. If your SMTP server offers SMTP AUTH
          authentication, adding this parameter to the SMTP-Server option
          will cause _Alpine_ to attempt to authenticate to the server
          using the supplied username. Similarly, if your NNTP server
          offers NNTP "AUTHINFO SASL" or "AUTHINFO USER" authentication,
          adding this parameter to the NNTP-Server option (or to the
          server name for any folder collection using NNTP) will cause
          _Alpine_ to attempt to authenticate to the server using the
          supplied username. An example might be:

                                 /user=katie

   TLS
          Normally, when a new connection is made an attempt is made to
          negotiate a secure (encrypted) session using Transport Layer
          Security (TLS). If that fails then a non-encrypted connection
          will be attempted instead. This is a unary parameter indicating
          communication with the server must take place over a TLS
          connection. If the attempt to use TLS fails then this parameter
          will cause the connection to fail instead of falling back to an
          unsecure connection.

                                    /tls

   SSL
          This is a unary parameter indicating communication with the
          server should take place over a Secure Socket Layer connection.
          The server must support this method, and be prepared to accept
          connections on the appropriate port (993 by default). _Alpine_
          must be linked with an SSL library for this option to be
          operational.

                                    /ssl

   NoValidate-Cert
          Do not validate certificates (for TLS or SSL connections) from
          the server. This is needed if the server uses self-signed
          certificates or if _Alpine_ cannot validate the certificate for
          some other known reason.

   Anonymous
          This is a unary parameter (that means it does not have a value)
          indicating that the connection be logged in as "anonymous"
          rather than a specific user. Not all servers offer anonymous
          access; those which do generally only offer read-only access to
          certain "public" folders.

                                 /anonymous

   Secure
          This is a unary parameter indicating that the connection use the
          most secure authentication method mutually supported by _Alpine_
          and the server. _Alpine_ is capable of authenticating
          connections to the server using several methods. By default,
          _Alpine_ will attempt each method until either a connection is
          established or the list of methods is exhausted. This parameter
          causes _Alpine_ to instead fail the connection if the first
          (generally most "secure") method fails.

                                   /secure

   Submit
          This is a unary parameter for use with the "SMTP-Server" option.
          It indicates that the connection should be made to the Submit
          server (RFC 3676) (port 587) instead of the SMTP port (25). At
          the time this help was written the submit option was equivalent
          to specifying port 587.

                                   /submit

          or

                                  host:587

   Debug
          This is a unary parameter indicating that the connection be
          established in a verbose mode. Basically, it causes _Alpine_ to
          log the communication with the server in _Alpine_'s debug file.
          Normally, the alpine -d command-line flag would be used instead.

   NoRsh
          By default, _Alpine_ attempts to login using "rsh", the UNIX
          remote shell program. Including "NoRsh" will cause connections
          to this server to skip the "rsh" attempt. This might be useful
          to avoid long timeouts caused by rsh firewalls, for example.

   Service
          This parameter requires an associated value. The default value
          is "IMAP" which indicates communication with the server based on
          the IMAP4rev1 protocol (defined in RFC 3501 -- see
          http://www.imap.org/docs/rfc3501.html). Other service values
          include:

        NNTP
                This value indicates communication with the server takes
                place via the Network News Transfer Protocol. Use this to
                define a collection of newsgroups on a remote news server.
                So

                                /service=NNTP

                or just

                                    /NNTP

                is the way to specify NNTP access.

        POP3
                This value indicates communication with the server takes
                place via the Post Office Protocol 3 protocol.

                                /service=POP3

                or just

                                    /POP3

                Note that there are several important issues to consider
                when selecting this option:

              1. POP3 provides access to only your INBOX. In other words,
                 secondary folders such as your "saved-messages" are
                 inaccessible.
              2. _Alpine_'s implementation of POP3 does not follow the
                 traditional POP model and will leave your mail on the
                 server. Refer to the Mail Drop functionality for a
                 possible way around this problem.
              3. See the discussion about new-mail checking in
                 Folder-Reopen-Rule.

   Note that it is possible to include more than one parameter in a server
   specification by concatenating the parameters. For example:

            foo.example.com:port/user=katie/novalidate-cert/debug
     __________________________________________________________________

Folder Namespaces

   A _Alpine_ folder name looks like

     [{<remote-specification>}][#<namespace>][<namespace-specific-part>]

   The local part of a folder name has an optional "Namespace" which tells
   _Alpine_ how to interpret the rest of the name.

   By default the folder name is interpreted as defining a section of your
   personal folder area. This area and how you specify it are defined by
   the server, if one is specified, or, typically, the home directory, if
   no server is defined.

   If a namespace is specified, it begins with the sharp, "#", character
   followed by the name of the namespace and then the namespace's
   path-element-delimiter. Aside from the path's format, namespaces can
   also imply access rights, content policy, audience, location, and,
   occasionally, access methods.

   Each server exports its own set (possibly of size one) of namespaces.
   Hence, it's likely communication with your server's administrator will
   be required for specific configurations. Some of the more common
   namespaces, however, include:

   #news.
          This specifies a set of folders in the newsgroup namespace.
          Newsgroup names are hierarchically defined with each level
          delimited by a period.

                            #news.comp.mail.pine

   #public/
          This specifies a folder area that the server may export to the
          general public.

   #shared/
          This specifies a folder area that the folder may export to
          groups of users.

   #ftp/
          This specifies a folder area that is the same as that it may
          have exported via the "File Transfer Protocol".

   #mh/
          This specifies the personal folder area associated with folders
          and directories that were created using the MH message handling
          system.

   #move/
          This namespace is interpreted locally by _Alpine_. It has an
          unusual interpretation and format.

           #move<DELIM><MailDropFolder><DELIM><DestinationFolder>

          The #move namespace is followed by two folder names separated by
          a delimiter character. The delimiter character may be any
          character which does not appear in the MailDropFolder name. The
          meaning of #move is that mail will be copied from the
          MailDropFolder to the DestinationFolder and then deleted (if
          possible) from the MailDropFolder. Periodic checks at frequency
          Mail-Check-Interval, but with a minimum time between checks set
          by MailDrop-Check-Minimum, are made for new mail arriving in the
          MailDropFolder. An example which copies mail from a POP inbox to
          a local folder follows

          #move+{popserver.example.com/pop3/ssl}inbox+local folder

          To you it appears that mail is being delivered to the local
          folder when it is copied from the MailDropFolder, and you read
          mail from the local folder.

          Note that if the DestinationFolder does not exist then the
          messages are not copied from the MailDropFolder. A #move folder
          may only be used as an Incoming folder or an Inbox. When you are
          in the FOLDER LIST of Incoming Message Folders (after turning on
          the enable-incoming-folders option) the Add command has a
          subcommand "Use Mail Drop" which may be helpful for defining the
          folder in your _Alpine_ configuration. The same is true when you
          edit the Inbox-Path option in Setup/Config. Each of these
          configuration methods will also create the DestinationFolder if
          it doesn't already exist. If you are having problems, make sure
          the DestinationFolder exists.

   In addition, the server may support access to other user's folders,
   provided you have suitable permissions. Common methods use a prefix of
   either "~user/", or "/user/" to indicate the root of the other user's
   folder area.
     __________________________________________________________________

What is a Mail Drop?

   In some situaions it may make sense to have your mail delivered to one
   folder (the Mail Drop) and then when you want to read mail that has
   been delivered to the Mail Drop folder _Alpine_ will move it to another
   destination folder. Often the Mail Drop will be a remote folder and
   messages will be moved from there to a local destination folder.

   One example where this might make sense is if the Mail Drop folder is
   accessible only with the POP protocol. You could designate your POP
   inbox as the Mail Drop folder and have _Alpine_ move mail from there to
   a local (on the same machine _Alpine_ is running on) destination
   folder, where you'll read it.

   A Mail Drop may only be used as your Inbox or as an Incoming folder.

   There is no attempt to synchronize the contents of the destination
   folder with the contents of the Mail Drop folder. All that happens is
   that all of the messages in the Mail Drop folder are copied to the
   destination folder and then they are deleted and expunged (if possible)
   from the Mail Drop folder. The next time a check for new mail is made,
   any messages in the Mail Drop folder are once again copied to the
   destination folder and deleted and expunged from the Mail Drop folder.
   (If the Mail Drop folder is a news group, then the messages can't be
   expunged from the newsgroup. Instead, only Recent messages are copied
   from the newsgroup to the destination folder.)

   Configuration of a Mail Drop is a little different from configuration
   of a folder which does not use a Mail Drop because you have to specify
   two folder names instead of one. The two folders may be any types of
   folders that _Alpine_ can normally use. They don't have to be a remote
   folder and a local folder, that is simply the most common usage. When
   you use a Mail Drop folder _Alpine_ will periodically re-open the Mail
   Drop to check for new mail. The new-mail checks will happen at the
   frequency set with the Mail-Check-Interval option, but with a minimum
   time (MailDrop-Check-Minimum) between checks. Because of this minimum
   you may notice that new mail does not appear promptly when you expect
   it. The reason for this is to protect the server from over-zealous
   opening and closing of the Mail Drop folder. If the user initiates the
   check by typing ^L (Ctrl-L) or the Next command when at the end of the
   folder index, then the check will happen, regardless of how long it has
   been since the previous check.

   If there is new mail, that mail will be copied to the destination
   folder and then will be deleted from the Mail Drop. Note that using a
   Mail Drop with a local destination folder does not make sense if you
   read mail from more than one machine, because the mail is downloaded to
   the destination folder (which is accessible from only one machine) and
   deleted from the Mail Drop.

   The feature Maildrops-Preserve-State modifies the operation of Mail
   Drops.

   The actual syntax used by _Alpine_ for a folder that uses a Mail Drop
   is:

           #move<DELIM><MailDropFolder><DELIM><DestinationFolder>

   The brackets are not literal.

                                   <DELIM>

   is a single character which does not appear in the MailDropFolder name.
   If the name doesn't contain spaces then it can be a space character.
   The two folder names are full technical folder names as used by
   _Alpine_. Here are a couple examples to give you an idea what is being
   talked about:

             #move {popserver.example.com/pop3}inbox localfolder

    #move+{nntpserver.example.com/nntp}#news.comp.mail.pine+local folder

   A #move folder may only be used as an Incoming folder or an Inbox. When
   you are in the FOLDER LIST of Incoming Message Folders (after turning
   on the Enable-Incoming-Folders option) the Add command has a subcommand
   "Use Mail Drop" which may be helpful for defining the folder in your
   _Alpine_ configuration. The same is true when you edit the Inbox-Path
   option in Setup/Config.
   if it doesn't already exist. If you are having problems, make sure the
   DestinationFolder exists.
     __________________________________________________________________

Sorting a Folder

   The mail index may be sorted by arrival, date, subject, from, size,
   score, to, or cc order. Each sort order can also be reversed. The _$_
   command will prompt the user for the sort order. The sort order can
   also be specified on the command line with the _-sort_ flag or
   (equivalently) with the sort-key variable in the _pinerc_ file. When a
   user changes folders, the sort order will go back to the original sort
   order. The command line (_-sort_) or configuration file sort
   specification (_sort-key_) changes the original sort order.

   When a folder is sorted and new mail arrives in the folder it will be
   inserted in its properly sorted place. This can be a little odd when
   the folder is sorted by something like the subject. It can also be a
   little slow if you are viewing a large, sorted _INBOX_, since the
   _INBOX_ will have to be re-sorted whenever new mail arrives.

   The sorts are all independent of case and ignore leading or trailing
   white space. There are actually two forms of subject sort. One called
   _Subject_ and the other called _OrderedSubj_. They both ignore "Re:" at
   the beginning and "(fwd)" at the end of the subjects. _Subject_ sorts
   all the subjects alphabetically. _OrderedSubj_ sorts by subjects
   alphabetically, groups messages with the same subject (pseudo-threads),
   then sorts the groups by the date of the first message of the group.
   Sorting by _Thread_ was added after _OrderedSubj_ and is usually a
   better method. Thread sorting uses information in the message headers
   References, Message-ID, and Subject. It is possible the sort will be
   slightly slower with a Thread sort than with an OrderedSubj sort. The
   sort by sender sorts by the user-id (part before the "@"), not the full
   name. The arrival sort is no sort at all and the date sort depends on
   the format of the date. Some dates are in strange formats and are
   unparsable. The time zone is also taken into account.

   Sorting large mail folders can be very slow since it requires fetching
   all the headers of the mail messages. With UNIX _Alpine_, only the
   first sort is slow since _Alpine_ keeps a copy of all the headers. One
   exception is sorting in reverse arrival order. This is fast because no
   headers have to be examined. _Alpine_ will show progress as it is
   sorting.
     __________________________________________________________________

Alternate Editor

   In the _Alpine_ composer you can use any text editor, such as _vi_ or
   _emacs,_ for composing the message text. The addresses and subject still
   must be edited using the standard _Alpine_ composer. If you include the
   feature enable-alternate-editor-cmd in your _pinerc_ you can type _^__
   while in the body of the message in the composer and be prompted for
   the editor. If you also set the editor variable in your _pinerc_ then
   _^__ will invoke the configured editor when you type it.

   Turning on the feature enable-alternate-editor-implicitly will
   automatically invoke the editor you have defined with the _editor_
   variable whenever you enter the body of a message you are composing.
   For example, when you move out of the last header line and into the
   body of the message, the alternate editor will be automatically
   invoked.

   We know that many people would like to use the alternate editor to edit
   the mail header as well. We considered several designs for this and
   didn't come up with one that we liked and that was easy to implement.
   One of the main problems is that you lose access to the address book.
     __________________________________________________________________

Signatures and Signature Placement

   If the file _~/.signature_ (UNIX) or _<PINERC_directory>\PINE.SIG (PC)
   exists, it will be included in all outgoing messages. It is included
   before composition starts so that the user has a chance to edit it out
   if he or she likes. The file name for the signature can be changed by
   setting the signature-file variable in the _pinerc_. If the feature
   enable-sigdashes is turned on then the line consisting of the three
   characters "-- " is prepended to the signature file. When Replying or
   Forwarding a message different signatures my be automatically included
   by configuring them in the Roles setup screen. It's easy to include
   different signatures by hand, by having multiple signature files
   (_.sig1, .sig2, .sig3, etc_) and choosing to include (^R in the
   composer) the correct one for the message being sent.

   _Alpine_'s default behavior encourages a user to put his or her
   contribution before the inclusion of the original text of the message
   being forwarded or replied to, This is contrary to some conventions,
   but makes the conversation more readable when a long original message
   is included in a reply for context. The reader doesn't have to scroll
   through the original text that he or she has probably already seen to
   find the new text. If the reader wishes to see the old message(s), the
   reader can scroll further into the message. Users who prefer to add
   their input at the end of a message should set the signature-at-bottom
   feature. The signature will then be appended to the end of the message
   after any included text. This feature applies when _Reply_ing, not when
   _Forward_ing.
     __________________________________________________________________

Feature List Variable

   _Alpine_ used to have _feature levels_ for users with different amounts
   of experience. We found that this was too restrictive. _Alpine_ now has
   a feature-list instead. Each user may pick and choose which features
   they would like enabled (simple to do in the _Setup/Config_ screen).
   There is a short description of each in Configuration Features. There
   is also a short on-line help explaining the effect of each of the
   features in the _Setup/Config_ screen. When the cursor is highlighting
   a feature, the _?_ command will show the help text for that feature.
   Features don't have values, they are just turned on or off. They are
   all off by default.

   The _feature-list_ variable is different from all other configuration
   variables in that its value is additive. That is, the system-wide
   configuration file can have some features turned on by default. The
   user can select other features in their personal configuration file and
   those features will be _added_ to the set of features turned on in the
   system-wide configuration file. (With all other configuration
   variables, the user's values _replace_ the system-wide values.)
   Likewise, additional features may be set on the command-line with the
   argument "-feature-list=". These will be added to the others.

   The treatment of _feature-list_ in the system-wide _fixed_
   configuration file is also different from other variables. The system
   management can fix the value of individual features by placing them in
   the fixed configuration file. Users will not be able to alter those
   features, but will still be able to set the other non-restricted
   features the way they like.

   Because _feature-list_ is additive, there is a way to turn features off
   as well as on. Prepending the prefix "no-" to any feature sets it to
   off. This is useful for over-riding the system-wide default in the
   personal configuration file or for over-riding the system-wide default
   or the personal configuration value on the command line. For example,
   if the system-wide default configuration has the _quit-without-confirm_
   feature set, the user can over-ride that (and turn it off) by including
   _no-quit-without-confirm_ in the personal configuration file or by
   giving the command line argument
   _-feature-list=no-quit-without-confirm._ More features (options) will no
   doubt continue to be added.
     __________________________________________________________________

Configuration Inheritance

   We start with an explanation of how configuration works in hopes of
   making it easier to describe how inheritance works.

   _Alpine_ uses a hierarchy of configuration values from different
   locations. There are five ways in which each configuration option
   (configuration variable) can be set. In increasing order of precedence
   they are:

    1. the system-wide configuration file.
    2. the personal configuration file
    3. the personal exceptions file
    4. a command line argument
    5. the system-wide _fixed_ configuration file (Unix _Alpine_ only)

   The fixed configuration file is normally
   /usr/local/lib/pine.conf.fixed.

   The system-wide configuration file is normally /usr/local/lib/pine.conf
   for Unix _Alpine_ and is normally not set for _PC-Alpine_. For
   _PC-Alpine_, if the environment variable _$PINECONF_ is set, that is
   used for the system-wide configuration. This location can be set or
   changed on the command line with the -P flag. The system-wide
   configuration file can be either a local file or a remote configuration
   folder.

   For Unix _Alpine_, the personal configuration file is normally the file
   .pinerc in the user's home directory. This can be changed with the -p
   command line flag. For _PC-Alpine_, the personal configuration file is
   in $PINERC or <PineRC registry value> or ${HOME}\ALPINE\PINERC or
   <ALPINE.EXE dir>\PINERC. This can be changed with the -p command line
   flag. If -p or $PINERC is used, the configuration data may be in a
   local file or a remote config folder.

   For Unix _Alpine_, the personal exceptions configuration file is
   specified with the "-x exceptions_config" command line argument.
   "Exceptions_config" may be either a local file or a remote
   configuration folder. If there is no "-x" command line option, _Alpine_
   will look for the file ".pinercex" in the same local directory that the
   regular config file is located in. If the regular config file is remote
   then Unix _Alpine_ looks in the home directory for ".pinercex".

   For _PC-Alpine_, the personal exceptions configuration file is
   specified with the "-x exceptions_config" command line argument. If
   there is no "-x" command line argument the environment variable
   $PINERCEX may be set to the name of the "exceptions_config" instead.
   "Exceptions_config" may be either a local file or a remote
   configuration folder. If there is no "-x" command line option and
   $PINERCEX is not set, _PC-Alpine_ will look for the file "PINERCEX" in
   the same local directory that the regular config file is located in. If
   the regular config file is remote then _PC-Alpine_ looks in the local
   directory specified by the "-aux local_directory" command line
   argument, or the directory ${HOME}\ALPINE, or in <ALPINE.EXE directory>
   for a file named "PINERCEX".

   To reiterate, the value of a configuration option is taken from the
   last location in the list above in which it is set. Or, thinking about
   it slightly differently, a default value for an option is established
   in the system-wide configuration file (or in the source code if there
   is no value in the system-wide file). That default remains in effect
   until and unless it is overridden by a value in a location further down
   the list, in which case a new "default" value is established. As we
   continue down the list of locations we either retain the value at each
   step or establish a new value. The value that is still set after going
   through the whole list of configuration locations is the one that is
   used.

   So, for example, if an option is set in the system-wide configuration
   file and in the personal configuration file, but is not set in the
   exceptions, on the command line, or in the fixed file; then the value
   from the personal configuration file is the one that is used. Or, if it
   is set in the system-wide config, in the personal config, not in the
   exceptions, but is set on the command line; then the value on the
   command line is used.

   Finally we get to inheritance. For configuration options which are
   lists, like "smtp-server" or "incoming-folders", the inheritance
   mechanism makes it possible to _combine_ the values from different
   locations instead of _replacing_ the value. This is true of all
   configuration lists other than the "feature-list", for which you may
   already set whatever you want at any configuration location (by using
   the "no-" prefix if necessary).

   To use inheritance, set the first item in a configuration list to the
   token "INHERIT". If the first item is "INHERIT", then instead of
   replacing the default value established so far, the rest of the list is
   appended to the default value established so far and that is the new
   value.

   Here is an example which may make it clearer. Suppose we have:

 System-wide config :   smtp-server = smtp1.corp.com, smtp2.corp.com
 Personal config    :   smtp-server = INHERIT, mysmtp.home
 Exceptions config  :   smtp-server = <No Value Set>
 Command line       :   smtp-server = <No Value Set>
 Fixed config       :   smtp-server = <No Value Set>

   This would result in an effective smtp-server option of

 smtp-server = smtp1.corp.com, smtp2.corp.com, mysmtp.home

   The "INHERIT" token can be used in any of the configuration files and
   the effect cascades. For example, if we change the above example to:

 System-wide config :   smtp-server = smtp1.corp.com, smtp2.corp.com
 Personal config    :   smtp-server = INHERIT, mysmtp.home
 Exceptions config  :   smtp-server = INHERIT, yoursmtp.org
 Command line       :   smtp-server = <No Value Set>
 Fixed config       :   smtp-server = <No Value Set>

   This would result in:

 smtp-server = smtp1.corp.com, smtp2.corp.com, mysmtp.home, yoursmtp.org

   Unset variables are skipped over (the default value is carried forward)
   so that, for example:

 System-wide config :   smtp-server = smtp1.corp.com, smtp2.corp.com
 Personal config    :   smtp-server = <No Value Set>
 Exceptions config  :   smtp-server = INHERIT, yoursmtp.org
 Command line       :   smtp-server = <No Value Set>
 Fixed config       :   smtp-server = <No Value Set>

   produces:

 smtp-server = smtp1.corp.com, smtp2.corp.com, yoursmtp.org

   If any later configuration location has a value set (for a particular
   list option) which does _not_ begin with "INHERIT", then that value
   replaces whatever value has been defined up to that point. In other
   words, that cancels out any previous inheritance.

 System-wide config :   smtp-server = smtp1.corp.com, smtp2.corp.com
 Personal config    :   smtp-server = INHERIT, mysmtp.org
 Exceptions config  :   smtp-server = yoursmtp.org
 Command line       :   smtp-server = <No Value Set>
 Fixed config       :   smtp-server = <No Value Set>

   results in:

 smtp-server = yoursmtp.org

   For some configuration options, like "viewer-hdr-colors" or
   "patterns-roles", it is difficult to insert the value "INHERIT" into
   the list of values for the option using the normal Setup tools. In
   other words, the color setting screen (for example) does not provide a
   way to input the text "INHERIT" as the first item in the
   viewer-hdr-colors option. The way to do this is to either edit the
   pinerc file directly and manually insert it, or turn on the
   "expose-hidden-config" feature and insert it using the Setup/Config
   screen.
     __________________________________________________________________

Using Environment Variables

   The values of _Alpine_ configuration options may include environment
   variables which are replaced by the value of the variable at the time
   _Alpine_ is run (and also at the time the config option is changed). The
   syntax to use environment variables is a subset of the common Unix
   shell dollar-syntax. For example, if

                                    $VAR

   appears in the value of a _Alpine_ configuration option it is looked up
   in the environment (using getenv("VAR")) and its looked-up value
   replaces the $VAR part of the option value. To include a literal dollar
   sign you may precede the dollar sign with another dollar sign. In other
   words, if the text

                                   $$text

   is the value of a configuration option, it will be expanded to

                                    $text

   and no environment lookup will be done. For Unix _Alpine_ it will also
   work to use a backslash character to escape the special meaning of the
   dollar sign, but $$ is preferable since it works for both _PC-Alpine_
   and Unix _Alpine_, allowing the configuration option to be in a shared
   configuration file.

   This all sounds more complicated than it actually is. An example may
   make it clearer. Unfortunately, the way in which environment variables
   are set is OS-dependent and command shell-dependent. In some Unix
   command shells you may use

                         PERSNAME="Fred Flintstone"

                               export PERSNAME

   Now, if you use _Alpine_'s Setup/Config screen to set

                           personal-name=$PERSNAME

   the $PERSNAME would be replaced by Fred Flintstone so that this would
   be equivalent to

                        personal-name=Fred Flintstone

   Note, environment variable substitution happens after configuration
   options which are lists are split into the separate elements of the
   list, so a single environment variable can't contain a list of values.

   The environment variable doesn't have to be the only thing after the
   equal sign. However, if the name of the variable is not at the end of
   the line or followed by a space (so that you can tell where the
   variable name ends), it must be enclosed in curly braces like

                                   ${VAR}

   It is always ok to use the braces even if you don't need to.

   It is also possible to set a default value for an environment variable.
   This default value will be used if the environment variable is not set
   (that is, if getenv("VAR") returns NULL). The syntax used to set a
   default value is

                            ${VAR:-default value}

   If the config file contains

                    personal-name=${VAR:-Fred Flintstone}

   then when _Alpine_ is run VAR will be looked up in the environment. If
   VAR is found then personal-name will have the value that VAR was set
   to, otherwise, personal-name will be set to Fred Flintstone, the
   default value.

   An example where an environment variable might be useful is the
   variable inbox-path in the global configuration file. Suppose most
   users used the server

                           imapserver.example.com

   but that there were some exceptions who used

                          altimapserver.example.com

   In this case, the system manager might include the following line in
   the systemwide default _Alpine_ configuration file

              inbox-path=${IMAPSERVER:-imapserver.example.com}

   For the exceptional users adding

                    IMAPSERVER=altimapserver.example.com

   to their environment should work.

   Another example might be the case where a user has to use a different
   SMTP server from work and from home. The setup might be something as
   simple as

                              smtp-server=$SMTP

   or perhaps a default value could be given. Note that, as mentioned
   above, the variable SMTP cannot contain a list of SMTP servers.
     __________________________________________________________________

SMTP Servers

   It is sometimes desirable to set smtp-server=localhost instead of
   setting sendmail-path to overcome the inability to negotiate ESMTP
   options when _sendmail_ is invoked with the _-t_ option. Sendmail can
   also be subject to unacceptable delays due to slow DNS lookups and
   other problems.

   It is sometimes desirable to configure an SMTP server on a port other
   than the default port 25. This may be used to provide an alternate
   service that is optimized for a particular environment or provides
   different features from the port 25 server. An example would be a
   program that negotiates ESMTP options and queues a message, but does
   not attempt to deliver messages. This would avoid delays frequently
   encountered when invoking _sendmail_ directly.

   A typical configuration would consist of
     * A program that implements the SMTP or ESMTP protocol via stdio.
     * An entry in /etc/services for the alternate service.
     * An entry in /etc/inetd.conf for the alternate service.
     * An entry in /usr/local/lib/pine.conf,
       /usr/local/lib/pine.conf.fixed or ~/.pinerc.
     __________________________________________________________________

MIME.Types file

   _Alpine_'s MIME-TYPE support is based on code contributed by Hans
   Drexler &LT;drexler@mpi.nl&GT;. _Alpine_ assigns MIME Content-Types
   according to file name extensions found in the system-wide files
   /usr/local/lib/mime.types and /etc/mime.types, and a user specific
   ~/.mime.types file.

   In Windows, _Alpine_ looks in the same directory as the PINERC file and
   the same dir as ALPINE.EXE. This is similar to the UNIX situation with
   personal config info coming before potentially shared config data. An
   alternate search path can be specified by setting the
   mimetype-search-path variable in the user or system-wide configuration
   or by setting the MIMETYPES environment variable.

   These files specify file extensions that will be connected to a mime
   type. Lines beginning with a '#' character are treated as comments and
   ignored. All other lines are treated as a mime type definition. The
   first word is a _type/subtype_ specification. All following words are
   file _extensions_ belonging to that type/subtype. Words are separated
   by whitespace characters. If a file extension occurs more than once,
   then the first definition determines the file type and subtype. A
   couple sample lines from a mime.types file follow:

image/gif         gif
text/html         html htm
video/mpeg        mpeg mpg mpe

     __________________________________________________________________

Color Details

   UNIX _Alpine_ may display color if the terminal or terminal emulator
   you are using is capable of displaying colors. If the terminal supports
   ANSI color escape sequences you will be able to turn color on using the
   color-style option and setting it to the value _force-ansi-8color_ or
   _force-ansi-16color_. If instead you'd like _Alpine_ to automatically
   detect whether or not you are on a color terminal, set _color-style_ to
   _use-termdef_ _and_ configure the termcap entry to describe your
   terminal's color capabilities.

   If the _color-style_ option is set to _use-termdef_, _Alpine_ looks in
   the terminal capabilities database, TERMINFO or TERMCAP, depending on
   how _Alpine_ was compiled, to decide whether or not your terminal is
   capable of color. For TERMINFO compiled _Alpine_s, the capabilities
   that are used for color are "colors", "setaf", "setab", "op", and
   "bce". If you have a terminal with color capabilities described by the
   "scp" capability, _Alpine_ does not support it. The capabilities "setf"
   and "setb" may be used instead of "setaf" and "setab". The capability
   "bce" is optional and is used as an optimization, the other
   capabilities are required. For TERMCAP compiled _Alpine_s, the
   capabilities that are used for color are "Co", "AF", "AB", "op", and
   "ut". The capabilities "Sf" and "Sb" may be used instead of "AF" and
   "AB", though this isn't a useful feature.

   Here are some short descriptions of the capabilities listed above. The
   TERMINFO name is listed, followed by the TERMCAP name in parentheses.
   _colors_ (_Co_)
          The number of different colors.
   _setaf_ (_AF_)
          Set ANSI foreground color.
   _setab_ (_AB_)
          Set ANSI background color.
   _setf_ (_Sf_)
          Set foreground color. Alternate form of _setaf_.
   _setb_ (_Sb_)
          Set background color. Alternate form of _setab_.
   _op_ (_op_)
          Set default pair to its original value.
   _bce_ (_ut_)
          Screen is erased with current background color instead of
          default background.

   A standard ANSI terminal which supports color will have a TERMINFO
   entry which contains:
  colors#8
  setaf=\E[3%p1%dm
  setab=\E[4%p1%dm
  op=\E[39;49m
  bce

   or the TERMCAP equivalent:
  Co#8
  AF=\E[3%dm
  AB=\E[4%dm
  op=\E[39;49m
  ut

   If there are eight colors, the program uses colors 0, 1, ..., 7. For an
   ANSI terminal, the foreground color is set by sending the escape
   sequence "Escape LeftBracket 3 color_number m" to the terminal. The
   background color is set by sending the sequence "Escape LeftBracket 4
   color_number m". ANSI colors zero through seven are defined to be
   "black", "red", "green", "yellow", "blue", "magenta", "cyan", and
   "white". Some terminal emulators will swap blue and red and swap yellow
   and cyan. The capabilities "setf" and "setb" are usually designed for
   those terminals so that they will flip the color numbers 1 and 4 and
   the numbers 3 and 6 to compensate for this. _Alpine_ will use the ANSI
   versions of the capabilities if they exist, and will use the non-ANSI
   versions (setf and setb) if the ANSI versions don't exist. Here's a
   version which does the flipping. This can only be used with TERMINFO
   _Alpine_s, because of the arithmetic, which is not supported by TERMCAP.
  colors#8
  setf=\E[3%?%p1%{1}%=%t4%e%p1%{3}%=%t6%e%p1%{4}%=%t1%e%p1%{6}%=%t3%e%p1%d%;m
  setb=\E[4%?%p1%{1}%=%t4%e%p1%{3}%=%t6%e%p1%{4}%=%t1%e%p1%{6}%=%t3%e%p1%d%;m
  op=\E[39;49m
  bce

   Some terminal emulators are capable of displaying eight more colors
   when the foreground colors 30-37 are replaced with 90-97 and the
   background colors 40-47 are replaced with 100-107. These terminals
   require a fancy termcap entry which can take foreground colors 0, 1,
   ..., 15 and map that into 30, 31, ..., 37, 90, 91, ..., 97, and
   similarly for the background colors. Here is a terminfo entry which
   will do just that:
  colors#16
  setaf=%p1%{8}%/%{6}%*%{3}%+\E[%d%p1%{8}%m%dm
  setab=%p1%{8}%/%{6}%*%{4}%+\E[%d%p1%{8}%m%dm
  op=\E[39;49m
  bce

   and here is the termcap equivalent:
  Co#16
  AF=\E[%i%i%>\001\034%>\045\064%dm
  AB=\E[%i%i%>\001\046%>\057\064%dm
  op=\E[39;49m
  ut

   This is a terminfo entry for 16 colors that also does the color
   flipping:
  colors#16
  setf=%p1%{8}%/%{6}%*%{3}%+\E[%d%p1%{8}%m%Pa%?%ga%{1}%=%t4%e%ga%{3}%=%t6%e%ga%{
4}%=%t1%e%ga%{6}%=%t3%e%ga%d%;m
  setb=%p1%{8}%/%{6}%*%{4}%+\E[%d%p1%{8}%m%Pa%?%ga%{1}%=%t4%e%ga%{3}%=%t6%e%ga%{
4}%=%t1%e%ga%{6}%=%t3%e%ga%d%;m
  op=\E[39;49m
  bce

   If you are always using the same display it probably won't matter to
   you if the color pairs red/blue and cyan/yellow are flipped, since
   you'll always be seeing them flipped. You will get different defaults
   than on a display with them not flipped, but that's about all. If you
   are trying to use the same pinerc file from displays with different
   color characteristics, or from _Alpine_ and _PC-Alpine_, you will have
   to be more careful. The colors numbered 0 through 7 may be used
   portably between different systems if you are careful to make them
   correspond to the ANSI order mentioned above. You can check this by
   looking at a color configuration screen for one of the colors. The
   first eight colors should be in the order above. If they aren't, you
   could fix that by modifying your termcap entry on the UNIX system. This
   is not possible if your system uses TERMCAP instead of TERMINFO.
     __________________________________________________________________

S/MIME Overview

   UNIX _Alpine_ only.

   S/MIME is a standard for the public key encryption and signing of
   email. UNIX _Alpine_ contains a basic implementation of S/MIME based on
   the OpenSSL libraries.

   Some limitations:
     * There is no _PC-Alpine_ implementation.
     * There is no provision for checking for CRLs (Certificate Revocation
       Lists) in _Alpine_.
     * This built-in S/MIME implementation is not compatible with and does
       not help with PGP.
     * There is no mechanism available for feeding either an entire
       incoming or an entire outgoing message to an external filter and
       using that external filter to do S/MIME or PGP processing.
     * Because the implementation currently uses OpenSSL, there is only a
       very limited integration with the Mac OS Keychain (the storing and
       access of public certificates).
     * There is no way to view or manipulate the lists of certificates
       from within _Alpine_.

   The S/MIME configuration screen is reached by going to the Main Menu
   and typing the "S Setup" command followed by "M S/MIME".

  S/MIME BASICS

   In order to digitally sign messages you send you must have a
   public/private key-pair. This may be obtained from a public Certificate
   Authority (CA) such as Thawte, Verisign, Comodo, or GoDaddy; or from a
   smaller CA such as a university which provides certificates for its
   users or a company which provides certificates for its workers. These
   certificates are bound to an email address, so the identity being
   verified is the email address not a person's name.

   Mail is signed by using the sender's private key, which only the owner
   of the private key has access to. The signature is verified using the
   signer's public key, which anyone can have access to. With _Alpine_,
   the first time you receive a signed message the public key of the
   sender will be stored for future use.

   Mail is encrypted using the recipient's public key and decrypted by the
   recipient with their private key.

   You need a key of your own in order to sign outgoing messages and to
   have others encrypt messages sent to you. You do not need a key of your
   own to verify signed messages sent by others or to encrypt messages
   sent to others.

  ALPINE S/MIME CERTIFICATE STORAGE

   By default UNIX _Alpine_ stores the certificates it uses in a directory
   in your home directory. The directory name is

                                .alpine-smime

   Within that directory are three subdirectories. Each of the three
   subdirectories contains files with PEM-encoded contents, the default
   format for OpenSSL. The "public" directory contains public
   certificates. The files within that directory have names that are email
   addresses with the suffix ".crt" appended. An example filename is

                            user@example.com.crt

   The "private" directory contains private keys, probably just one for
   your private key. These are also email addresses but with the suffix
   ".key" instead. The third directory is "ca" and it contains
   certificates for any Certificate Authorities that you want to trust but
   that aren't contained in the set of system CAs. Those files may have
   arbitrary names as long as they end with the suffix ".crt".

  HOW TO SIGN AND ENCRYPT

   If you have a certificate you may sign outgoing messages. After typing
   the Ctrl-X command to send a message you will see the prompt

                                Send message?

   Available subcommands include "G Sign" and "E Encrypt". Typing the "G"
   command will change the prompt to

                           Send message (Signed)?

   Typing the "E" command will change the prompt to

                          Send message (Encrypted)?

   You may even type both to get

                      Send message (Encrypted, Signed)?

  HOW TO READ SIGNED OR ENCRYPTED MESSAGES

   The reading of a signed message should not require any special action
   on your part. There should be an editorial addition at the start of the
   message which says either

                 This message was cryptographically signed.

   or

    This message was cryptographically signed but the signature could not
                                be verified.

   If an encrypted message is sent to you the encrypted text will not be
   shown. You will have to type the "Ctrl-D Decrypt" command (from the
   screen where you are viewing the message) and supply your passphrase
   when asked.

   For a signed or encrypted message there is also a "Ctrl-E Security"
   command which gives you some information about the certificate used to
   sign or encrypt the message.

  MISCELLANEOUS

   You may have access to a private certificate in the PKCS12 format,
   which would sometimes be in a file with a ".p12" suffix. The UNIX shell
   command

                  openssl pkcs12 -in file.p12 -out file.pem

   may work to convert that from the PKCS12 format to the PEM format. Then
   that file could be placed in the "private" directory with a filename of
   your email address followed by the suffix ".key".
     __________________________________________________________________

Additional Notes on PC-Alpine

   Below are a few odds and ends worth mentioning about _PC-Alpine_. They
   have to do with DOS-specific behavior that is either necessary or
   useful (and sometimes both!).

   As _PC-Alpine_ runs in an environment with limited access control,
   accounting or auditing, an additional line is automatically inserted
   into the header of mail messages generated by _PC-Alpine_:
        X-Sender: <userid>@<imap.host>


   By popular demand of system administrators, _PC-Alpine_ has been
   modified to prevent sending messages until the user has successfully
   logged into a remote mail server. Even though _PC-Alpine_ cannot
   prevent users from changing the apparent identity of the sender of a
   message, the IMAP server login name and host name included in the
   _X-Sender_ line provide some level of traceability by the recipient.
   However, this should not be considered a rigorous form of
   authentication. It is extremely lightweight, and is not a replacement
   for true authentication.

   Hand in hand with authentication and accounting is user information.
   Since _PC-Alpine_ has no user database to consult for _user-id_,
   _personal-name_, etc., necessary information must be provided by the
   user/installer before _PC-Alpine_ can properly construct the "From"
   address required for outbound messages. _PC-Alpine_ will, by default,
   prompt for the requisite pieces as they are needed. This information
   corresponds to the _PINERC_ variables user-id, personal-name,
   user-domain, and smtp-server.

   The user is then asked whether or not this information should
   automatically be saved to the _PINERC_. This is useful behavior in
   general, but can lead to problems in a lab or other shared environment.
   Hence, these prompts and automatic saving of configuration can be
   turned off on an entry by entry basis by setting any of the above
   values in the _PINERC_ to the null string (i.e., a pair of double
   quotes). This means that the user will be prompted for the information
   once during each _Alpine_ session, and no opportunity to save them in
   the _PINERC_ will be offered.

   Another feature of DOS is the lack of standard scratch area for
   temporary files. During the course of a session, _PC-Alpine_ may
   require numerous temporary files (large message texts, various caches,
   etc.). Where to create them can be a problem, particularly when running
   under certain network operating systems. _PC-Alpine_ observes the
   _TMPDIR_, _TMP_, and _TEMP_ environment variables, and creates temporary
   files in the directory specified by either. In their absence,
   _PC-Alpine_ creates these files in the root of the current working
   drive. Some temporary files have to be created in the same directory as
   the file they are a temporary copy of. For example, a pinerc file or a
   address book file.

                               Behind the Scenes

   Many people ask how certain _Alpine_ features are implemented. This
   section outlines some of the details.

Address Books

   There are two types of address book storage. There are _local_ address
   books, which are the address books that are stored in a local file; and
   there are _remote_ address books, which are stored on an IMAP server.

    Information About Remote Address Books

     NOTE: The remote address book capability does not allow you to
     access an existing local address book from a remote system! That is,
     you can't set the remote address book to something like
     {remote.host}.addressbook and expect to access the existing
     .addressbook _file_ on remote.host. Instead, you need to create a
     new remote address book in a new, previously unused remote mail
     _folder_. Then you can use the _Select_ and _Apply Save_ commands in
     the address book screen to _Save_ all of the entries from an
     existing local address book to the new remote address book.

   A remote address book is stored in a mail folder on an IMAP server. An
   _Alpine_ remote address book is just like an _Alpine_ local address book
   in that it is not interoperable with other email clients. The folder is
   a regular folder containing mail messages but those messages are
   special. The first message must be an alpine remote address book header
   message which contains the header _x-pine-addrbook_. The last message
   in the folder contains the address book data. In between the first and
   the last message are old versions of the address book data. The address
   book data is simply stored in the message as it would be on disk, with
   no MIME encoding. When it is used the data from the last message in the
   folder is copied to a local file and then that file is used exactly
   like a local address book file is used. When a change is made the
   modified local file is appended to the remote folder in a new message.
   In other words, the local file is just a cache copy of the data in the
   remote folder. Each client which uses the remote address book will have
   its own cache copy of the data. Whenever a copy is done the entire
   address book is copied, not just the entries which have changed.

   _Alpine_ can tell that the remote data has changed by one of several
   methods. If the date contained in the Date header of the last message
   has changed then it knows it has changed. If the UID of the last
   message has changed, or the number of messages in the folder has
   changed, it knows that it has changed. When _Alpine_ discovers the
   folder has changed it gets a new copy and puts it in the local cache
   file.

   There is a configuration file variable for remote address books called
   remote-abook-metafile. The variable is the name of a file in which
   information about remote address books is stored. There is one line in
   the metafile for each remote address book. The information stored there
   is the name of the cache file and information to help figure out when
   the remote folder was last changed. If the metafile or any of the cache
   files is deleted then _Alpine_ will rebuild them the next time it runs.

   Remote address books have names that look just like regular remote mail
   folder names. For example:

     {host.domain}foldername

   _Alpine_ decides whether or not an address book is remote simply by
   looking at the first character of the address book name and comparing
   it to '{'.

    Information About All Address Books

   The address book is named, by default, .addressbook in the user's Unix
   home directory, or in the case of _PC-Alpine_, ADDRBOOK, in the same
   directory as the PINERC file. There may be more than one address book,
   and the default name can be overridden via an entry in any of the
   _Alpine_ configuration files. The two configuration variables
   address-book and global-address-book are used to specify the names of
   the address books. Each of these variables is a list variable. The
   total set of address books for a user is the combination of all the
   address books specified in these two lists. Each entry in the list is
   an optional nickname followed by an address book name. The nickname is
   everything up to the last space before the file name. The
   _global-address-book_ list will typically be configured in the
   system-wide configuration file, though a user may override it like most
   other variables. Address books which are listed in the
   _global-address-book_ variable are forced read-only, and are typically
   shared among multiple users.

   Local address books (or local cache files for remote address books) are
   simple text files with lines in the format:

     <nickname>TAB<fullname>TAB<address>TAB<fcc>TAB<comments>

   The last two fields are optional. A "line" may be made up of multiple
   actual lines in the file by using continuation lines, which are lines
   beginning with SPACE characters. The line breaks may be after TABs or
   in between addresses in a distribution list. Each _actual_ line in the
   file must be less than 1000 characters in length.

   Nicknames (the first field) are short names that the user types instead
   of typing in the full address. There are several characters which
   aren't allowed in nicknames in order to avoid ambiguity when parsing
   the address (SPACE, COMMA, @, ", ;, :, (, ), [, ], <, >, \). Nicknames
   aren't required. In fact, none of the fields is required.

   The _fullname_ field is usually stored as Last_name, First_name, in
   order that a sort on the fullname field comes out sorted by Last_name.
   If there is an unquoted comma in the fullname, _Alpine_ will flip the
   first and last name around and get rid of the comma when using the
   entry in a composition. It isn't required that there be a comma, that's
   only useful if the user wants the entries to sort on last names.

   The _address_ field takes one of two forms, depending on whether the
   entry is a single (simple) address or a distribution list. For a simple
   entry, the address field is an RFC 2822 address. This could be either
   the email-address part of the address, i.e., the part that goes inside
   the brackets (<>), or it could be a full RFC 2822 address. The phrase
   part of the address (the fullname) is used unless there is a fullname
   present in the fullname field of the address book entry. In that case,
   the fullname of the address book entry replaces the fullname of the
   address. For a distribution list, the <address> is in the format:

     "(" <address>, <address>, <address>, ... ")"

   The only purpose for the parentheses around the list of addresses is to
   make it easier for the parsing routines to tell that it is a simple
   entry instead of a list. The two are displayed differently and treated
   slightly differently in some cases, though most of the distinction has
   disappeared. Each of the addresses in a list can be a full RFC 2822
   address with fullname included, or it may be just the simple
   email-address part of the address. This allows the user to have a list
   which includes the fullnames of all the list members. In both the
   simple and list cases, addresses may also be other nicknames which
   appear in this address book or in one of the other address books.
   (Those nicknames are searched for by looking through the address books
   in the order they appear in the address book screen, with the first
   match winning.) Lists may be nested. If addresses refer to each other
   in a loop (for example, list A includes list B which includes list A
   again) this is detected and flagged. In that case, the address will be
   changed to "**** address loop ****".

   The optional _fcc_ field is a folder name, just like the fcc field in
   the composer headers. If the first address in the To field of a
   composition comes from an address book entry with an fcc field, then
   that fcc is placed in the fcc header in the composer.

   The _comments_ field is just a free text field for storing comments
   about an entry. By default, neither the fcc nor the comments field is
   shown on the screen in the address book screen. You may make those
   fields visible by configuring the variable addressbook-formats. They
   are also searched when you use the _WhereIs_ command in the address
   book screen and are visible when you _View_ or _Update_ an entry.

   The address book is displayed in the order that it is stored. When the
   user chooses a different sorting criterion, the data is actually sorted
   and stored, as opposed to showing a sorted view of the data.

   When the address book is written out, it is first written to a
   temporary file and if that write is successful it is renamed. This
   guards against errors writing the file that might destroy the whole
   address book. The address book is re-written after each change. If the
   address book is a remote address book, the file is then appended to the
   remote mail folder using IMAP.

   The end-of-line character(s) in the address book file are those native
   to the system writing it. So it is <LF> on Unix and <CR><LF> on PC's.
   However, both Unix and PC versions of _Alpine_ can read either format,
   so it should be possible to share a read-only address book among the
   two populations (using NFS, for example).
     __________________________________________________________________

  Address Book Lookup File

   _Pine_ used an additional file for each address book, called the LookUp
   file. It had the same name as the address book file with the suffix
   ".lu" appended. _Alpine_ no longer uses a lookup file.

    Validity Checking of Address Books

   There is no file locking done on _Alpine_ address books, however, there
   is considerable validity checking done to make sure that the address
   book hasn't changed unexpectedly. Whenever the address book is about to
   be changed, a check is made to see if the file is newer than when we
   read it or the remote address book folder has changed since we last
   copied it. If either of these is true, the change is aborted.

   There is an automatic, behind-the-scene check that happens every so
   often, also. For example, if someone else changes one of the address
   books that you have configured, your _Alpine_'s copy of the address
   book will usually be updated automatically without you noticing. This
   checking happens at the same time as new mail checking takes place,
   unless you are actively using the address book, in which case it
   happens more frequently.
     __________________________________________________________________

Remote Configuration

   Configuration information may be stored remotely. Remote configuration
   information is stored in a folder on an IMAP server. This should be a
   folder which is used only for storing the configuration information. In
   other words, it should be a folder which didn't exist before.

   Remote configuration folders are very similar to remote address book
   folders. They both consist of a header message, which serves to
   identify the type of folder; the last message, which contains the data;
   and intermediate messages, which contain old versions of the data. The
   first message must contain the header _x-pine-pinerc_.

   When a remote configuration is being used, the folder is checked to
   make sure it is a remote configuration folder, then the data contained
   in the last message is copied to a temporary file. That file is treated
   just like any regular local configuration file from that point on.
   Whenever a configuration change is made, the entire file is copied back
   to the IMAP server and is appended to the folder as a new message.

   Because remote configuration folders are so similar to remote address
   books, the configuration variable remote-abook-metafile is used by
   both.

   Remote configuration folders have names that look just like regular
   remote mail folder names. For example:

     {host.domain}mypinerc

   _Alpine_ decides whether or not a configuration file is remote simply
   by looking at the first character of the name and comparing it to '{'.
     __________________________________________________________________

Checkpointing

   Periodically _Alpine_ will save the whole mail folder to disk to
   prevent loss of any mail or mail status in the case that it gets
   interrupted, disconnected, or crashes. The period of time _Alpine_
   waits to do the checkpoint is calculated to be minimally intrusive. The
   timing can be changed (but usually isn't) at compile time. Folder
   checkpointing happens for both local folders and those being accessed
   with IMAP. The delays are divided into three categories:

     The exact algorithm given below is no longer correct. It has gotten
     more complicated over time. However, this gives the general idea
     _Alpine_ uses when deciding whether or not to do a checkpoint.

   Good Time:
          This occurs when _Alpine_ has been idle for more than 30
          seconds. In this case _Alpine_ will checkpoint if 12 changes to
          the file have been made or at least one change has been made and
          a checkpoint hasn't been done for five minutes.
   Bad Time:
          This occurs just after _Alpine_ has executed some command.
          _Alpine_ will checkpoint if there are 36 outstanding changes to
          the mail file or at least one change and no checkpoint for ten
          minutes.
   Very Bad Time:
          Done when composing a message. In this case, _Alpine_ will only
          checkpoint if at least 48 changes have been made or at least one
          change has been made in the last twenty minutes with no
          checkpoint.
     __________________________________________________________________

Debug Files

   If UNIX _Alpine_ is compiled with the compiler _DEBUG_ option on (the
   default), then _Alpine_ will produce debugging output to a file. This
   can be disabled at compile-time with the --disable-debug configure
   option, or at run-time with the command line flag -d0. The file is
   normally .pine-debugX in the user's home directory where _X_ goes from
   1 to 4. Number 1 is always the most recent session and 4 the oldest.
   Four are saved because often the user has gone in and out of _Alpine_ a
   few times after a problem has occurred before the expert actually gets
   to look at it. The amount of output in the debug files varies with the
   debug level set when _Alpine_ is compiled and/or as a command line
   flag. The default is level 2. This shows very general things and
   records errors. Level 9 produces copious amounts of output for each
   keystroke.

   Similarly, _PC-Alpine_ creates debug files named pinedebg.txtX in the
   same directory as the PINERC file.
     __________________________________________________________________

INBOX and Special Folders

   The _INBOX_ folder is treated specially. It is normally kept open
   constantly so that the arrival of new mail can be detected. The name
   _INBOX_ refers to wherever new mail is retrieved on the system. If the
   inbox-path variable is set, then _INBOX_ refers to that. IMAP servers
   understand the concept of _INBOX_, so specifying the folder
   _{imap.u.example.edu}INBOX_ is meaningful. The case of the word _INBOX_
   is not important, but _Alpine_ tends to display it in all capital
   letters.

   The folders for sent mail and saved messages folders are also somewhat
   special. They are automatically created if they are absent and
   recreated if they are deleted.
     __________________________________________________________________

Internal Help Files

   The file pine.hlp in the alpine subdirectory of the distribution
   contains all the help text for _Alpine_. It is compiled right into the
   _Alpine_ binary as strings. This is done to simplify installation and
   configuration. The pine.hlp file is in a special format that is
   documented at the beginning of the file. It is divided into sections,
   each with a name that winds up being referenced as a global variable.
   This file is processed during the build process and turned into a C
   file that is compiled into _Alpine_.
     __________________________________________________________________

International Character Sets

   _Alpine_ uses Unicode characters internally and it is a goal for
   _Alpine_ to handle email in many different languages. _Alpine_ will
   properly display only left-to-right character sets in a fixed-width
   font. Specifically, _Alpine_ assumes that a fixed-width font is in use,
   in the sense that characters are assumed to take up zero, one, or two
   character cell widths from left to right on the screen. This is true
   even in _PC-Alpine_.

   _Alpine_ recognizes some local character sets which are right-to-left
   (Arabic, Hebrew, and Thai) or not representable in a fixed-width font
   (Arabic) and properly converts texts in these character sets to/from
   Unicode; however, there are known display bugs with these character
   sets.

   There are three possible configuration character settings and some
   environment variable settings which can affect how _Alpine_ handles
   international characters. The first two of these are only available in
   UNIX _Alpine_. The three configuration options are
   _display-character-set_, _keyboard-character-set_, and
   _posting-character-set_. The _keyboard-character-set_ defaults to being
   the same value as the _display-character-set_, and that is usually
   correct, because the keyboard almost always produces characters in the
   same character set as the display displays. The _display-character-set_
   is the character set that _Alpine_ will attempt to use when sending
   characters to the display.

   Besides those variables there is also use-system-translation which can
   be used instead of these. That usage is only lightly tested and is not
   recommended.

   By default, the _display-character-set_ variable is not set and UNIX
   _Alpine_ will attempt to get this information from the environment. In
   particular, the nl_langinfo(CODESET) call is used. This usually depends
   on the setting of the environment variables LANG or LC_CTYPE. An
   explicit configuration setting for _display-character-set_ will, of
   course, override any default setting.

   For _PC-Alpine_ the _display-character-set_ and the
   _keyboard-character-set_ are always equivalent to UTF-8 and this is not
   settable.

   It is probably best to use UNIX _Alpine_ in a terminal emulator capable
   of displaying UTF-8 characters, since that will allow you to view just
   about any received text that is correctly formatted (note, however, the
   above comments about known index display bugs with certain character
   sets). You'll need to have an emulator which uses a UTF-8 font and
   you'll need to set up your environment to use a UTF-8 charmap. For
   example, on a Linux system you might include

                           setenv LANG en_US.UTF-8

   or something similar in your UNIX startup files. You'd also have to
   select a UTF-8 font in your terminal emulator.

   The types of values that the character set variables may be set to are
   UTF-8, ISO-8859-1, or EUC-JP. The ISO-2022 character sets are not
   supported for input or for display, but as a special case, ISO-2022-JP
   is supported for use only as a _posting-character-set_. In the
   Setup/Config screen you may choose from a list of all the character
   sets _Alpine_ knows about by using the "T" ToCharsets command. Here is
   a list of many of the possible character sets:

   UTF-8        Unicode
   US-ASCII     7 bit American English characters
   ISO-8859-1   8 bit European "Latin 1" character set
   ISO-8859-2   8 bit European "Latin 2" character set
   ISO-8859-3   8 bit European "Latin 3" character set
   ISO-8859-4   8 bit European "Latin 4" character set
   ISO-8859-5   8 bit Latin and Cyrillic
   ISO-8859-6   8 bit Latin and Arabic
   ISO-8859-7   8 bit Latin and Greek
   ISO-8859-8   8 bit Latin and Hebrew
   ISO-8859-9   8 bit European "Latin 5" character set
   ISO-8859-10  8 bit European "Latin 6" character set
   ISO-8859-11  Latin and Thai
   ISO-8859-12  Reserved
   ISO-8859-13  8 bit European "Latin 7" character set
   ISO-8859-14  8 bit European "Latin 8" character set
   ISO-8859-15  8 bit European "Latin 9" character set
   ISO-8859-16  8 bit European "Latin 10" character set
   KOI8-R       8 bit Latin and Russian
   KOI8-U       8 bit Latin and Ukrainian
   WINDOWS-1251 8 bit Latin and Russian
   TIS-620      8 bit Latin and Thai
   VISCII       8 bit Latin and Vietnamese
   GBK          Latin and Chinese Simplified
   GB2312       Latin and Chinese Simplified
   CN-GB        Latin and Chinese Simplified
   BIG5         Latin and Chinese Traditional
   BIG-5        Latin and Chinese Traditional
   EUC-JP       Latin and Japanese
   SHIFT-JIS    Latin and Japanese
   EUC-KR       Latin and Korean
   KSC5601      Latin and Korean

   When reading incoming email, _Alpine_ understands many different
   character sets and is able to convert the incoming mail into Unicode.
   The Unicode will be converted to the _display-character-set_ for
   display on your terminal. Characters typed at the keyboard will be
   converted from the _keyboard-character-set_ to Unicode for _Alpine_'s
   internal use. You may find that you can read some malformed messages
   that do not contain a character set label by setting the option
   unknown-character-set.

   The _posting-character-set_ is used when sending messages. The default
   behavior obtained by leaving this variable unset is usually what is
   wanted. In that default case, _Alpine_ will attempt to label the
   message with the most specific character set from the rather arbitrary
   set

   US-ASCII, ISO-8859-15, ISO-8859-1, ISO-8859-2, VISCII, KOI8-R, KOI8-U,
   ISO-8859-7, ISO-8859-6, ISO-8859-8, TIS-620, ISO-2022-JP, GB2312, BIG5,
   EUC-KR, and UTF-8.

   For example, if the message is made up of only US-ASCII characters, it
   will be labeled US-ASCII. Otherwise, if it is all ISO-8859-15
   characters, that will be the label. If that doesn't work the same is
   tried for the remaining members of the list.

   It might make sense to set _posting-character-set_ to an explicit value
   instead. For example, if you usually send messages in Greek, setting
   this option to ISO-8859-7 will result in messages being labeled as
   US-ASCII if there are no non-ascii characters, ISO-8859-7 if there are
   only Greek characters, or UTF-8 if there are some characters which
   aren't representable in ISO-8859-7. Another possibility is to set this
   option explicitly to UTF-8. In that case _Alpine_ labels only ascii
   messages as US-ASCII and all other messages as UTF-8.
     __________________________________________________________________

Interrupted and Postponed Messages

   If the user is composing mail and is interrupted by being disconnected
   (SIGHUP, SIGTERM or end of file on the standard input), _Alpine_ will
   save the interrupted composition and allow the user to continue it when
   he or she resumes _Alpine_. As the next _Alpine_ session starts, a
   message will be given that an interrupted message can be continued. To
   continue the interrupted message, simply go into the composer. To get
   rid of the interrupted message, go into the composer and then cancel
   the message with _^C._

   Composition of half-done messages may be postponed to a later time by
   giving the _^O_ command. Other messages can be composed while postponed
   messages wait. All of the postponed messages are kept in a single
   folder. Postponing is a good way to quickly reference other messages
   while composing.
     __________________________________________________________________

Message Status

   The c-client library allows for several flags or status marks to be set
   for each message. _Alpine_ uses four of these flags: UNSEEN, DELETED,
   ANSWERED, and FLAGGED. The N in _Alpine_'s FOLDER INDEX means that a
   message is unseen-it has not been read from this folder yet. The D
   means that a message is marked for deletion. Messages marked with D are
   removed when the user _Expunges_ the folder (which usually happens when
   the folder is closed or the user quits _Alpine_). The A in _Alpine_'s
   FOLDER INDEX means that the message has been replied-to. The * in
   _Alpine_'s FOLDER INDEX means that the message has been ``flagged'' as
   important. That is, the user used the _Flag_ command to turn the
   FLAGGED flag on. This flag can mean whatever the user wants it to mean.
   It is just a way to mark some messages as being different from others.
   It will usually probably be used to mark a message as somehow being
   ``important''. For Berkeley format folders, the message status is
   written into the email folder itself on the header lines marked Status:
   and X-Status.

   It is also possible for a user to define their own flags in addition to
   the standard system flags above. In _Alpine_ these user defined flags
   are called Keywords.
     __________________________________________________________________

MIME: Reading a Message

   _Alpine_ should be able to handle just about any MIME message. When a
   MIME message is received, _Alpine_ will display a list of all the
   parts, their types and sizes. It will display the attachments when
   possible and appropriate and allow users to _Save_ all other
   attachments.

   _Alpine_ honors the "mailcap" configuration system for specifying
   external programs for handling attachments. The mailcap file maps MIME
   attachment types to the external programs loaded on your system which
   can display and/or print the file. A sample mailcap file comes bundled
   with the _Alpine_ distribution. It includes comments which explain the
   syntax you need to use for mailcap. With the mailcap file, any program
   (mail readers, newsreaders, WWW clients) can use the same configuration
   for handling MIME-encoded data.

   If a MAILCAPS environment variable is defined, _Alpine_ will use that
   to look for one or more mailcap files, which are combined. In the
   absence of MAILCAPS, Unix _Alpine_ will look for a personal mailcap
   file in ~/.mailcap and combine that with a system-wide file in
   /etc/mailcap. _PC-Alpine_ will look for a file named MAILCAP in the
   same directory as the PINERC file, and/or the directory containing the
   ALPINE.EXE executable.

   Messages which include _rich text_ or _enriched text_ in the main body
   will be displayed in a very limited way (it will show bold and
   underlining).

   If _Alpine_ sees a MIME message part tagged as type IMAGE, and
   _Alpine_'s image-viewer configuration variable is set, _Alpine_ will
   attempt to send that attachment to the named image viewing program. In
   the case of UNIX _Alpine_, the DISPLAY environment variable is checked
   to see if an X-terminal is being used (which can handle the images). If
   the _image-viewer_ variable is not set, _Alpine_ uses the _mailcap_
   system to determine what to do with IMAGE types, just as it does for
   any other non-TEXT type, e.g. type APPLICATION. For MIME's generic
   "catch all" type, APPLICATION/OCTET-STREAM, the _mailcap_ file will
   probably not specify any action, but _Alpine_ users may always _Save_
   any MIME attachment to a file.

   MIME type "text/plain" is handled a little bit differently than the
   other types. If you are viewing the main body part in the MESSAGE TEXT
   viewing screen, then _Alpine_ will use its internal viewer to display
   it. This happens even if there is a mailcap description which matches
   this particular type. However, if you view a part of type "text/plain"
   from the ATTACHMENT INDEX screen, then _Alpine_ will check the mailcap
   database for a matching entry and use it in preference to its internal
   viewer.

   Some text attachments, specifically those which are just other email
   messages forwarded as MIME messages, are displayed as part of the main
   body of the message. This distinction allows easy display when possible
   (the forward as MIME case) and use of an attachment viewer when that is
   desirable (the plain text file attachment case).

   If the parts of a multipart message are alternate versions of the same
   thing _Alpine_ will select and display the one best suited. For parts
   of type "message/external-body", the parameters showing the retrieval
   method will be displayed, and the retrieval process is automated.
   Messages of type "message/partial" are not supported.
     __________________________________________________________________

MIME: Sending a Message

   There are two important factors when trying to include an attachment in
   a message: encoding and labeling. _Alpine_ has rules for both of these
   which try to assure that the message goes out in a form that is robust
   and can be handled by other MIME mail readers.

   MIME has two ways of encoding data-Quoted-Printable and Base64.
   Quoted-Printable leaves the ASCII text alone and only changes 8-bit
   characters to "=" followed by the hex digits. For example, "=09" is a
   tab. It has the advantage that it is mostly readable and that it allows
   for end of line conversions between unlike systems. Base64 encoding is
   similar to _uuencode_ or _btoa_ and just encodes a raw bit stream. This
   encoding is designed to get text and binary files through even the most
   improperly implemented and configured gateways intact, even those that
   distort uuencoded data.

   _All_ attachments are encoded using Base64 encoding. This is so that
   the attachment will arrive at the other end looking exactly like it did
   when it was sent. Since Base64 is completely unreadable except by
   MIME-capable mailers or programs, there is an obvious tradeoff being
   made here. We chose to ensure absolutely reliable transport of
   attachments at the cost of requiring a MIME-capable mailer to read
   them. If the user doesn't want absolute integrity he or she may always
   _include_ text (with the _^R_ command) in the body of a message instead
   of attaching it. With this policy, the only time quoted-printable
   encoding is used is when the main body of a message includes special
   foreign language characters.

   When an attachment is to be sent, _Alpine_ sniffs through it to try to
   set the right label (content-type and subtype). An attachment with any
   lines longer than 500 characters in it or more than 10% of the
   characters are 8-bit it will be considered binary data. _Alpine_ will
   recognize (and correctly label) a few special types including GIF,
   JPEG, PostScript, and some audio formats. Another method which can be
   more robust and flexible for determining the content-type and subtype
   is to base it on the file extension. This method uses a MIME.Types
   File.

   If it is not binary data (has only a small proportion of 8-bit
   characters in it,) the attachment is considered 8-bit text. 8-bit text
   attachments are labeled "text/plain" with charset set to the value of
   the user's _keyboard-character-set_ variable. If an attachment is ASCII
   (no 8-bit characters) and contains no control characters then it is
   considered plain ASCII text. Such attachments are given the MIME label
   "text/plain; charset=US-ASCII", regardless of the setting of the user's
   _keyboard-character-set_ variable.

   All other attachments are unrecognized and therefore given the generic
   MIME label "application/octet-stream".
     __________________________________________________________________

New Mail Notification

   _Alpine_ checks for new mail in the _INBOX_ and in the currently open
   folder every two and a half minutes by default. This default can be
   changed in the system-wide configuration file or at compile-time with
   the --with-mailcheck-interval=VALUE configuration option. A user can
   change it by changing the option mail-check-interval. A new mail check
   can be manually forced by redrawing the screen with a _^L_.

   When there is new mail, the message(s) will appear in the index, the
   screen will beep, and a notice showing the sender and subject will be
   displayed. If there has been more than one new message since you last
   issued a command to _Alpine_, the notice will show the count of new
   messages and the sender of the most recent one.
     __________________________________________________________________

NFS

   It is possible to access mail folders on _NFS_ mounted volumes with
   _Alpine_, but there are some drawbacks to doing this, especially in the
   case of incoming-message folders that may be concurrently updated by
   _Alpine_ and the system's mail delivery agent. One concern is that
   _Alpine_'s user-contention locks don't work because _/tmp_ is usually
   not shared, and even if it was, _flock()_ doesn't work across _NFS._

   The implementation of the standard UNIX ".lock" file locking has been
   modified to work with _NFS_ as follows. Standard hitching post locking
   is used so first a uniquely named file is created, usually something
   like _xxxx.host.time.pid._ Then a link to it is created named
   _xxxx.lock_ where the folder being locked is _xxxx._ This file
   constitutes the lock. This is a standard UNIX locking scheme. After the
   link returns, a _stat(2)_ is done on the file. If the file has two
   links, it is concluded that the lock succeeded and it is safe to
   proceed.

   In order to minimize the risks of locking failures via _NFS_, we
   strongly recommend using IMAP rather than _NFS_ to access remote
   incoming message folders, e.g. your _INBOX_. However, it is generally
   safe to access personal saved-message folders via _NFS_ since it is
   unlikely that more than one process will be updating those folders at
   any given time. Still, some problems may occur when two _Alpine_
   sessions try to access the same mail folder from different hosts
   without using IMAP. Imagine the scenario: _Alpine_-A performs a write
   that changes the folder. _Alpine_-B then attempts to perform a write on
   the same folder. _Alpine_-B will get upset that the file has been
   changed from underneath it and abort operations on the folder.
   _Alpine_-B will continue to display mail from the folder that it has in
   its internal cache, but it will not read or write any further data. The
   only thing that will be lost out of the _Alpine_-B session when this
   happens is the last few status changes.

   If other mail readers besides _Alpine_ are involved, all bets are off.
   Typically, mailers don't take any precautions against a user opening a
   mailbox more than once and no special precautions are taken to prevent
   _NFS_ problems.
     __________________________________________________________________

Printers and Printing

   UNIX _Alpine_ can print to the standard UNIX line printers or to
   generic printers attached to ANSI terminals using the escape sequences
   to turn the printer on and off. The user has a choice of three printers
   in the configuration.

   The first setting, _attached-to-ansi_, makes use of escape sequences on
   ANSI/VT100 terminals. It uses "<ESC>[5i" to begin directing all output
   sent to the terminal to the printer and then "<ESC>[4i" to return to
   normal. _Alpine_ will send these escape sequences if the printer is set
   to _attached-to-ansi._ This works with most ANSI/VT100 emulators on
   Macs and PCs such as kermit, NCSA telnet, VersaTerm Pro, and WinQVT.
   Various terminal emulators implement the print feature differently.
   There is also a closely related method called
   _attached-to-ansi-no-formfeed_ which is the same except for the lack of
   formfeed character at the end of the print job.

   _Attached-to-wyse_ and _attached-to-wyse-no-formfeed_ are very similar
   to "attached-to-ansi". The only difference is in the control characters
   sent to turn the printer on and off. The Wyse version uses Ctrl-R for
   on, and Ctrl-T for off.

   The second selection is the standard UNIX print command. The default is
   _lpr_, but it can be changed on a system basis to anything so desired
   in /usr/local/lib/pine.conf.

   The third selection is the user's personal choice for a UNIX print
   command. The text to be printed is piped into the command. _Enscript_
   or _lpr_ with options are popular choices. The actual command is
   retained even if one of the other print selections is used for a while.

   Both the second and third sections are actually lists of possible
   commands rather than single commands.

   If you have a PostScript printer attached to a PC or Macintosh, then
   you will need to use a utility called _ansiprt_ to get printouts on
   your printer. _Ansiprt_ source code and details can be found in the
   ./contrib directory of the _Alpine_ distribution.
     __________________________________________________________________

Save and Export

   _Alpine_ users get two options for moving messages in _Alpine_: _Save_
   and _Export_. _Save_ is used when the message should remain ``in the
   _Alpine_ realm.'' Saved messages include the complete header (including
   header lines normally hidden by _Alpine_), are placed in a _Alpine_
   folder collection and accumulate in a standard folder format which
   _Alpine_ can read. In contrast, the _Export_ command is used to write
   the contents of a message to a file for use outside of _Alpine_.
   Messages which have been exported are placed in the user's home
   directory (unless the feature use-current-dir is turned on), not in a
   _Alpine_ folder collection. Unless FullHeaderMode is toggled on, all
   delivery-oriented headers are stripped from the message. Even with
   _Export_, _Alpine_ retains message separators so that multiple messages
   can accumulate in a single file and subsequently be accessed as a
   folder. On UNIX systems, the _Export_ command pays attention to the
   standard _umask_ for the setting of the file permissions.
     __________________________________________________________________

Sent Mail

   _Alpine_'s default behavior is to keep a copy of each outgoing message
   in a special "sent mail" folder. This folder is also called the fcc for
   "file carbon copy". The existence, location and name of the sent mail
   folder are all configurable. Sent mail archiving can be turned off by
   setting the configuration variable default-fcc="". The sent mail folder
   is assumed to be in the default collection for _Save_s, which is the
   first collection named in folder-collections. The name of the folder
   can be chosen by entering a name in _default-fcc_. With _PC-Alpine_,
   this can be a bit complicated. If the default collection for _Save_s is
   local (DOS), then the _default-fcc_ needs to be SENTMAIL, which is
   syntax for a DOS file. However, if the default collection for _Save_s
   is remote, then the _default-fcc_ needs to be sent-mail to match the
   UNIX syntax.

   The configuration variable fcc-name-rule also plays a role in selecting
   the folder to save sent mail in.

   A danger here is that the sent mail could grow without bound. For this
   reason, we thought it useful to encourage the users to periodically
   prune their sent mail folder. The first time _Alpine_ is used each
   month it will offer to archive all messages sent from the month before.
   _Alpine_ also offers to delete all the sent mail archive folders which
   are more than 1 month old. If the user or system has disabled sent mail
   archiving (by setting the configuration variable _default-fcc=""_)
   there will be no pruning question.
     __________________________________________________________________

Spell Checker

   Both UNIX _Alpine_ and _PC-Alpine_ depend on the system for their spell
   checking and dictionary. _Pico_, the text editor, uses the same spell
   checking scheme as _Alpine_.

   Lines beginning with ">" (usually messages included in replies) are not
   checked. The message text to be checked is on the standard input and
   the incorrect words are expected on the standard output.

   The default spell checker is UNIX _spell_. You can replace this by
   setting the speller configuration variable. A common choice for a
   superior replacement is _ispell_.

   _PC-Alpine_ relies on the aspell library being installed. Aspell is
   independent of Alpine. The Windows version has traditionally been
   available at http://aspell.net/win32/. You'll need to download and
   install both Aspell and a precompiled dictionary. Aspell is provided in
   an installer package. Dictionaries, to be installed after Aspell, are
   in '.exe' files to download and run.
     __________________________________________________________________

Terminal Emulation and Key Mapping

   UNIX _Alpine_ has been designed to require as little as possible from
   the terminal. At the minimum, _Alpine_ requires cursor positioning,
   clear to end of line, and inverse video. Unfortunately, there are
   terminals that are missing some of these such as a vt52. _Alpine_ makes
   no assumptions as to whether the terminal wraps or doesn't wrap. If the
   terminal has other capabilities it may use some of them. _Alpine_ won't
   run well on older terminals that require a space on the screen to
   change video attributes, such as the Televideo 925. One can get around
   this on some terminals by using "protected field" mode. The terminal
   can be made to go into protected mode for reverse video, and then
   reverse video is assigned to protected mode.

   _Alpine_ handles screens of most any size and resizing on the fly. It
   catches SIGWINCH and does the appropriate thing.

   On the input side of things, _Alpine_ uses all the standard keys, most
   of the control keys and (in function-key mode) the function keys.
   _Alpine_ avoids certain control keys, specifically ^S, ^Q, ^H, and _^\_
   because they have other meanings outside of _Alpine_ (they control data
   flow, etc.) _^H_ is treated the same as the _delete_ key, so the
   _backspace_ or _delete_ keys always work regardless of any
   configuration. There is a feature _compose-maps-delete-key-to-ctrl-d_
   which makes the delete key behave like ^D rather than ^H (deletes
   current character instead of previous character).

   Sometimes a communications program or communications server in between
   you and the other end will eat certain control characters. There is a
   work-around when you need it. If you type two escape characters
   followed by a character that will be interpreted as the character with
   the control key depressed. For example, _ESC ESC T_ is equivalent to
   _^T_.

   When a function key is pressed and _Alpine_ is in regular (non-function
   key) mode, _Alpine_ traps escape sequences for a number of common
   function keys so users don't get an error message or have an unexpected
   command executed for each character in the function key's escape
   sequence. _Alpine_ expects the following escape sequences from
   terminals defined as VT100:

     ANSI/VT100
     F1: <ESC>OP
     F2: <ESC>OQ
     F3: <ESC>OR
     F4: <ESC>OS
     F5: <ESC>Op
     F6: <ESC>Oq
     F7: <ESC>Or
     F8: <ESC>Os
     F9: <ESC>Ot
     F10: <ESC>Ou
     F11: <ESC>Ov

   Arrow keys are a special case. _Alpine_ has the escape sequences for a
   number of conventions for arrow keys hard coded and does not use
   _termcap_ to discover them. This is because _termcap_ is sometimes
   incorrect, and because many users have PC's running terminal emulators
   that don't conform exactly to what they claim to emulate. There is a
   feature called termdef-takes-precedence which can be set to cause the
   _termcap_ or _terminfo_ definitions to be used instead of the built in
   definitions. Some arrow keys on old terminals send single control
   characters like _^K_ (one even sends _^\_). These arrow keys will not
   work with _Alpine_. The most popular escape sequences for arrow keys
   are:

     Up: <ESC>[A <ESC>?x <ESC>A <ESC>OA
     Down: <ESC>[B <ESC>?r <ESC>B <ESC>OB
     Right: <ESC>[C <ESC>?v <ESC>C <ESC>OC
     Left: <ESC>[D <ESC>?t <ESC>D <ESC>OD