File: changes.txt

package info (click to toggle)
slrn-ja 0.9.6.2-1
  • links: PTS
  • area: main
  • in suites: woody
  • size: 3,828 kB
  • ctags: 5,753
  • sloc: ansic: 57,052; makefile: 309; sh: 302
file content (1659 lines) | stat: -rw-r--r-- 65,842 bytes parent folder | download | duplicates (3)
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
Changes since 0.9.6.1
1. NULL ponter dereference fixed.

Changes since 0.9.6.0
    Misc bug fixes:
      misc.c: get_host_from_file sizeof(host)-->sizeof(line)
       (Russ Allbery <rra@stanford.edu>)
      art.c: toggle_headers would sometimes force an article to be
       downloaded.
      startup.c: color of "box" changed from b/b to b/w
      art.c: toggle_wrap with a == NULL caused a SEGV.
      slrn.c: Use setlocale (<kas@magnetic-ink.dk> Klaus Alexander Seistrup)

1. Updates to slrn.rc and slrn.1.
2. DESTDIR added to Makefile.in to facilitate the creation of binary
   distributions (Thomas Schultz <tststs@gmx.de>).
3. Emphasized text may be scanned in quoted and signature portions of
   a message if `emphasized_text_mask' is set accordingly.
4. If process_verbatum_marks is non-zero, #v+ and #v- will be used to
   denote lines of verbatum text, e.g.,
     #v+
        % Some code
	define this ()
	{
	   do_that ();
	}
     #v-
   "set color verbatum" may be used to color such sections of an
   article.
5. New hook: article_mode_startup_hook.  Called in article mode after
   headers have been read, scored, and sorted.
6. /text/ highlighted as using `italicstext' color.

Changes since 0.9.5.7
0.  misc bugs fixed
1.  If the newsrc file indicates that articles in the range 1-N have
    not been read, but the server indicates that those articles are
    nolonger available, then mark that range as read.
2.  slrn incorrectly interpreted an empty body as a server error.  I
    think that most servers reject such messages but a few allow them.
3.  Patches from Sylvan Butler <sylvan@bigfoot.com>: improved tin
    emulation macros; -s added to install to strip slrn; body added
    to slrn_select_prev_group function;
4.  If slrn fails to initialized the terminal, it will exit
    gracefully.  How did this fall through the cracks??
5.  If username contains a space, avoid the space when creating the
    message id.
6.  If `use_flow_control' is non-zero, ^S/^Q processing by the
    terminal driver will be enabled.
7.  sortdate.sl: small tweak to handle articles from the 1980s and
    earlier.
8.  `author_display' and `display_author_realname' removed from
    doc/slrn.rc file.
9.  slrn --version will show all compile-time options.
10. help.c: Post a postponed article reworded.
11. A score file may contain an `include' statement to include other
    score files.  See doc/score.txt for details.  (This feature
    suggested by Sylvain Robitaille <syl@alcor.concordia.ca>).
12. Small 32-vs-64 bit problem fixed where an int was used instead of
    a long in comparing strings.
13. There is nolonger any need to exit article mode to apply a changed
    score file.
14. New intrinsic functions (see docs for more info)

        get_visible_headers (counterpart of set_visible_headers)
	headers_hidden_mode (indicates whether or not some headers may 
	   be hidden)
        _is_article_visible (similar to is_article_visible)
	extract_displayed_article_header (get the header in the
	   displayed article)

15. slrn_is_fqdn rejects names that end in a `.'.
16. `Headers Received' message modified to include group name as
    suggested by W M Brelsford <k2di@bigfoot.com>.
17. If `read_article_hook' exists, then it will be called after an
    article has been read in (Marcin 'Qrczak' Kowalczyk" <qrczak@knm.org.pl>).
18. Different quote levels may be assigned different colors, e.g.,

        color quotes0 "red" "black"
        color quotes1 "green" "black"
	   .
	   .
	color quotes7 "yellow" "black"
    
    A maximum of 8 levels (0->7) are permitted.  Make sure that your
    quote regular expressions match as few characters as possible.
    For example, use ">" and not ">*".
19. Some code in art.c moved to artmisc.c in an effort to clean it up
    for future improvements.
20. The toggle-quotes function maybe used with a prefix-argument to
    hide the nth level of quotes.
21. `toggle_signature' function suggested by Tom Friedetzky
    <friedetz@informatik.tu-muenchen.de>.  Default binding is to "\".
    Also, toggle_pgp_signature added with binding "]" and a color:
    pgpsignature.  The `hide_signature' and `hide_pgpsignature'
    variables may also be used.

22. If compiled with SLRN_HAS_EMPHASIZED_TEXT (default), text such as
    *this* and _that_ will get highlighted using "underlinetext" and 
    "boldtext" colors, resp.  This requires the variable
    `emphasized_text_mode' to be set to a non-zero value: if 1, do not
    write `_' or `*' characters; if 2, write them as spaces; if 3;
    write them as they are. (suggested by Dawid Kuroczko
    <qnex@atlantis.ssw.krakow.pl>).
23. Improved tin emulation macros from Sylvan Butler <sylvan@bigfoot.com>.
24. Patch from Sami Farin <sfarin@ratol.fi> replace `/' characters
    with `_' in decoded filenames.

Changes since 0.9.5.6
1.  Fixed calculation of article window size in non-zoomed mode.
2.  Fixed a bug in parsing of realnames that contain no alphabetical
    characters.
3.  spool.c will check the .minmax file if no articles are present in a 
    spool directory.
4.  New intrinsic added: replace_article.  This allows a macro to
    replace the contents of an article with a specified string.
5.  slrnpull `--debug FILENAME' command line option added.
6.  Some modifications to nntp.c to call the connection-lost-hook as
    early as possible.

Changes since 0.9.5.5
1.  Misc bug-fixes:
    a.   Intrinsic function `locate_header_by_msgid' improperly
         interfaced to the interpreter.
    b.   `make install' was trying to install some old, obsolete, and
         non-existent documentation files.
    c.   Tiny bug fixed in new get_hostname function that manifests itself
         when the name server times-out.
2. With slrnpull it is now possible to specify an alternate log file
   via the `--logfile FILE' command line option.

3.  Philipp Grau <phgrau@zedat.fu-berlin.de> suggested using ` in the
    ascii thread tree instead of \.

4.  Add patch from Thomas Schultz <tststs@gmx.de> to mime-encode the
    real name when posting.  The original patch was due to Joachim
    Wieland <joe@mcknight.swin.de>.

5.  When replying, slrn adds References headers and also takes into
    account the To and Cc lines.  This enables the newsreader to
    better support mailing lists.

6.  If a thread has some unread headers, then it is marked with a `%'
    instead of a `D'. (Andrzej Radecki <radecki@posejdon.wpk.p.lodz.pl>).

7.  When asking for a password/username, a newline character will be
    written first (Philipp Grau <phgrau@cis.fu-berlin.de>).

Changes since 0.9.5.4
0.  Online documentation for slrn intrinsic functions
    (http://space.mit.edu/%7Edavis/doc/slrn-doc.html).  See also
    slrn/doc/slrnfuns.txt.

1.  koi8 character set from Roman Shaposhnick
    <roman@yellow.pdmi.ras.ru>.
2.  message_now intrinsic function added.
3.  If make_from_string_hook exists, it will be called to generate
    `From' header lines, e.g.,
    
          define make_from_string_hook ()
	  {
	     return "My Name <me@my.machine>"
	  }

4.  Small bug in base64 decoding of headers fixed.
5.  art.c:update_ranges rewritten to avoid marking too many articles
    as read when one recontructs a thread via ESC-p.
6.  Added patchs from Hubert Figuiere <Hubert.Figuiere@solsoft.fr> to
    handle some improperly mime encoded headers generated by broken
    software (specifically when ' ' is not converted to '_'), and to
    fix a potential problem with XOVER.
7.  Fixed scrore file problem with groupnames containing `+'.
8.  Body searching macro added to distribution (slrn/macros/search.sl).
9.  article mode function locate_header_by_msgid will not uncollapse
    the thread unless the header is hidden in the fold.
10. New intrinsic function: locate_header_by_msgid.  This takes 2
    arguments: the message-id and a flag that indicates whether or not
    the server should be queried.
11. Semantics of cc_followup variable modified for GNKSA compliance.
12. New option: abort_unmodified_edits.  Many users requested this
    feature.
13. `set hostname' now possible.
14. Patch from Dinko Korunic <kreator@fly.cc.fer.hr> fixing a NULL
    pointer dereference in the Cc code.
15. Failed posting are appended to a file specified by the
    failed_posts_file variable.
16. Patches from Tony Houghton <tonyh@tcp.co.uk>: supersede function
    and an option to strip signatures on followup:
       
       setkey article "supersede" "\e^S"   % ESC Ctrl-S
       set followup_strip_signature 0
17. slrnpull: more verbose messages via mapping of nntp codes to strings

Changes since 0.9.5.3
0. Misc bug fixes, including:
    * Mapping of / to \\ in Win32 and OS/2 editor variables.
    * slrn now honors port information encoded in hostname when
      refreshing newsgroups. 

1. Tweak to generation of NEWGROUPS server command to make it y2k
   compliant.  (In my opinion, the protocol is weak in this area)
2. VMS grplens.c support from Martin P.J. Zinser <m.zinser@gsi.de>.
3. New configuration variable:
     
     set simulate_graphic_chars 0

   Setting this to 1 will cause slrn to use simple ascii characters to 
   represent the thread tree.
4. Patch from Hubert Figuiere <Hubert.Figuiere@solsoft.fr> to handle
   (broken?) knews iso-latin1 mime encoding.
5. New configuration variable: set auto_mark_article_as_read 1
   If zero, reading an article will not cause it to be marked as read.
6. It is now possible to specify what headers to show via the .slrnrc
   line:

       visible_headers "From:,Subject:,Newsgroups:,Followup-To:,Reply-To:"

   or the slang function `set_visible_headers'.  To show no headers,
   use "", to show only X-* headers in addition to From, use "X-,From:".
   (Stephane CHAZELAS <Stephane.CHAZELAS@maisel-gw.enst-bretagne.fr>
   provided code that was used as a basis for this feature).
7. Tweak to group.c:group_sync_group_with_server courtesy of 
   stesch@parsec.rhein-neckar.de (Stefan Scholl).

Changes since 0.9.5.2
0. Misc bug fixes
1. \n --> \r\n mapping required for the print code.
2. install target courtesy of Klaus Franken <kfr@klaus.franken.de>.
3. Mods to update interp.c to use some slang 1.0 features.
4. Amiga patches and MIME bug fix from Jrg Strohmayer <j_s@gmx.de>.
5. Winsock initialization bug-fix from sgibier@mail.dotcom.fr
   (Stephane Gibier).
6. typo involving signals when quitting article mode corrected.
7. Bug fix so that article counts are not modified when a group read is
   aborted.
8. extract_article_header now trims leading whitespace.
9. New intrinsic for macros:
     is_article_window_zoomed ()
   This may be used to define macros that behave differently depending
   upon the zoom state of the article window.
10. New printer code added (vtailor@gte.net).
11. Added slrnpull setgid patch from Sylvain Robitaille
    <syl@alcor.concordia.ca>.  See slrnpull/setgid.txt for more
    information.  By default this is disabled in slrnfeat.h.
12. User-Agent header added.
13. New hook: article_mode_quit_hook
14. Added VMS patches for sltcp.c from Martin P.J. Zinser <m.zinser@gsi.de>.

Changes since 0.9.5.1
1. ibm850 character set made the default on Win32 and OS/2 systems.
2. New hook: post_file_hook
3. new header format descriptor: %g.  This may be used to specify the
   column the next write to the screen should take place.
   Specifically, `%Xg' indicates that the cursor should be moved to
   column X (numbered from 0).  If X is negative, the cursor will be
   moved X columns from the right edge of the window.  To
   understand this, compare:

       header_display_format 0 "%F%-5S%-5l:%t%35s %f"
   to
       header_display_format 0 "%F%-5S%-5l:%t%35s%-24g%f"

   in the presence of an open thread tree.  The latter form indicates
   that the `From' header (%f) should be written out 24 columns from
   the right edge of the window.
4. Andreas M. Kirchwitz <amk@krell.snafu.de> suggested that scores
   with a value of zero be printed on the header as a blank to keep
   the display less busy.  I took his advice.
5. doc/w32keys.txt and doc/os2keys.txt merged into one file:
   pc-keys.txt.
6. SLang_VMessage_Hook was set to slrn_va_message.
7.  --no-post option added to slrnpull.
8. New macros files: 
  
      slrn/macros/color.sl
      slrn/macros/posthook.sl

   The latter file illustrates how to use the `post_file_hook' to
   manipulate a message before posting it.
9. Fixed a bug in which the references appeared as blank when
   following up to articles whose message id exceeded the screen with
   and the headers were wrapped.
   
10. New function: print_article.  This function may be customized via
    the `printer_name' setting.  If `printer_name' is not set, then
    the default printer will be selected.  Otherwise, the meaning of
    this variable will depend upon the OS:
    
        WIN32  :  The name of the print queue.  The default is to use
	          the win.ini setting.
	UNIX   :  The name of a process that represents the printer, e.g.,
	
	            set printer_name "my_print_filter | lpr -Pmy_printer"

                  The default is to use "lpr -P$PRINTER".

        OS/2, VMS: ??? needs implemented

    The key binding may be set via, e.g.,
    
        setkey article "print_article"  "y"

    (`y' is the default binding)

    Note: This function could have been defined via a macro for Unix systems,
    but for e.g., windows 95 this was not possible and required a
    built-in solution.

11. References header truncated to 998 characters to satisfy the GNKSA
    2.x requirement.  The real implication of this is that no header
    should be wrapped, nor should the total length of a header be more
    than 998 characters long since there are broken servers that
    cannot handle long lines nor can handle a wrapped header.  The
    previous version of slrn would wrap the headers according to the
    NNTP protocol standards but the GNKSA forbids that.  Sigh.

Changes since 0.9.5.0
0. Oops.  score.c contained a break statement where it should not have.

Changes since 0.9.4.6
0. Misc bug fixes, e.g., the [~group, group] score bug. A silly
   uudecode bug was also fixed involving multi-part encoded files.
1. Watcom CC specific typo in src/slrnconf.h corrected (Bill McCarthy
   <WJMc@pobox.com>).
2. version.o add to Makefile.OS2 (Bjoern Frantzen)
3. Header display format is now customizable.  Up to 10 header formats
   are available and ESC-a will switch among them.  By default there
   are 4 pre-defined formats:

        "%F%-5S%G%-5l:[%12r]%t%s"
	"%F%G%-5l:[%12r]%t%s"
	"%F%-5l:%t%s"
	"%F%-5S%-5l:%t%50s %r"
   
   The generic format specifier begins with the `%' character and must
   be of the form:

        %[-][w]x
	
   where the brackets indicate optional items.  Here, w is a width
   specifier consisting of one or more digits.  If the minus sign (-)
   is present, the item will be right justified, otherwise it will be
   left justified.  The item specifier (x) is required and, depending
   on it value, has the following meaning:
   
         s : subject
	 S : score
	 r : author real name
	 f : from header
	 G : Group lens score
	 l : Number of lines
	 n : server number
	 d : date
	 t : thread tree
	 F : flags (read/unread, `*' and `#' tags, header number)
	 % : percent character
	 
  
   Thus, "%F%-5l:%t%s" indicates that the header window will contain
   the, in order: the flags, the number of lines the article contains
   right justified in a 5 character field, a `:', the tree, and the
   subject.
   
   There are two methods of setting these formats.  The first way is
   via a line in  the .slrnrc file using the header_display_format
   command.  This command takes two arguments: an integer that
   indicates the format to set, and a string that specifies the
   format, e.g, 

        header_display_format 0 "%F%-5S%G%-5l:[%12r]%t%s"
  
   sets the 0th format.  There are 10 formats available and the ESC-a
   command will switch among them.

   The second method is via the S-Lang macro language, e.g.,
   
       set_header_display_format (0, "%F%-5S%G%-5l:[%12r]%t%s");
       
   Finally, ESC-a may be used with a prefix argument to select a
   particular format, e.g., ESC-0 ESC-a will select the 0th format.

4. Added patches from http://home3.inet.tele.dk/byrial/slrn:

     resize patch
     prefix_arg patch ==> two new slrn macro intrinsics:
         get_prefix_arg
	 reset_prefix_arg
     msgid patch ==> new slrn.rc option:
	    set generate_message_id 1

5.  If you are using slang 1.2.x, then you can change the `cursor'
    from "->" to a bar across the display via:
       
       set display_cursor_bar 1

6.  Now score files can contains slang preprocessing constructs (patch
    from Jan Hlavacek <lahvak@math.ohio-state.edu>).

7.  Header window will now scroll horizontally if the article window
    is not visible.  Otherwise, the article window will be the one
    that horizontally scrolls.
    
8.  New article mode keybinding:

         setkey article "zoom_article_window"  "z"
	 
    This will cause the header window to disappear with the article
    window zoomed to full screen (minus the top/bottom lines of the
    display).  If the window is already zoomed, it will `un-zoom'.

    
Changes since 0.9.4.5
1. uudecode bug fixed.
2. VMS specific NETLIB update of clientlib.c.
3. Explicitly added the GNU copyright to source code files.
4. Updated to use slang 1.0.3.  For Win32 users this means you can
   use bright background colors and the mouse.
5. For CYGWIN32 and MINGW32 compilers, use src/Makefile.g32.  Do NOT
   use the Unix configure script because WIN32 is NOT Unix.  (Note:
   gcc in the CYGWIN32 distribution (b18) kept getting signal 33, so I
   could not compile slrn with it.  However, I had no problems with
   MINGW32.)
6. Autoconf now checks for socket.h (Marius Groeger <mag@sysgo.de>).

Changes since 0.9.4.4
1. Bug fix related to  `system' when called from a slang macro.

Changes since 0.9.4.3
0. Many, many changes to the slang interpreter.  Version 1.0 of slang is now
   required.  Some changes may affect pre-existing macros.  See
   the slang documentation for more information (in particular, see
   slang/UPGRADE.txt for more information about upgrading your slang
   macros).
   
   There are some new intrinsics to help isolate problems by
   re-routing slang traceback messages to a log file:
   
      open_log_file (FILENAME);
      close_log_file ();
      log_message ("My Message\n");
      
   You also need to set `_traceback = 1;'.

1. Small wrapping changes that permit header lines to be properly
   wrapped.
2. Integrated WIN32 patches.  Thanks Chin Huang <cthuang@vex.net>!!!
3. Included reject-long-lines patch from Byrial Jensen
   <byrial@post3.tele.dk>.  Add
   
      set reject_long_lines 2
   
   to be given the opportunity to post an article with long lines.

4. If slrnpull fails, it returns an error code to indicate the failure:

       1    Unspecified reason
       2    Bad usage
       3    Failed to connect
       4    Connection Lost
       5    Signaled
       10   Malloc Failure
       20   File I/O

5. Added Andy Harper's do_netlib_read routine for VMS.  Thanks Andy!

Changes since 0.9.4.2

0. Bug fixes, tiny documentation corrections.  In particular, one of the
   bug fixes concerns a somewhat nasty bug that, although unnoticed
   until 0.9.4.1, appears to have been around for a while.

Changes since 0.9.4.1
1. Add charset tables from Mark Nowiasz <buckaroo@blackbox.free.de>.
   I also changed `slrn --version' to show the supported character sets.
2. New customizable color objects:

      box --- This objects represents the are of the screen when a box
              pops up.
      frame - The border of the box
      selection
              The currently selected text in the selection box

3. New hooks for macro customization

         reply_hook
	 forward_hook
	 followup_hook   (see macros/xcomment.sl for example)
	 post_hook
	 post_filter_hook

   The post_filter_hook allows you to run the article to be posted
   through something such as ispell, a shell script, etc...  The file
   to be posted is passed as a parameter to this hook.  See
   macros/ispell.sl for an example.

4. New intrinsic macro functions:
       
         get_response
	 set_color
	 select_list_box
	 get_grouplens_score
	 set_input_chars

5. OS/2 patches from Bjoern Frantzen for OS/2 FAT file systems.
6. Support for X-Mail-Copies-To added.
7. cc_followup_string now expands %n, etc...

Changes since 0.9.4.0
0. Small (nothing serious) bug fixes
1. Typo prevented slrn to compile on Non-POSIX systems corrected.
2. slrnpull ported to NeXT (flight@mathi.uni-heidelberg.de)
3. Olly's mail-copies-to patch implemented
4. A new interface to ``browse-url''.  This is not the clickable
   interface but it does have the feature that it works on ordinary
   terminals.
5. I added a ``postpone'' interface.  To use this, set the variable
     
     set postpone_directory "whatever"

   to specify where articles are to be saved.  Make sure the directory
   exists!  To post a postponed article, press `ESC P'.  Use, e.g.,

     setkey group "post_postponed" "KEY_SEQUENCE"
     
   to rebind it.
6. I integrated the NeXT character set patch from Daniel G. Kluge 
   <daniel@hallus.swill.org>.
7. New color object: response_char.  This is used to set the color for
   response characters in prompts such as:
     
         Do you really want to quit? Yes, No

   Here the response characters are `Y' and `N'.
   
    
Changes since 0.9.3.2
0. Some bug fixes as well as slrnpull bug fixes.  Also, the libc system
   function has been replaced.  The fact is that system is broken on
   Linux.

1. Small change to pathname manipulation to avoid problems with \\ and
   / conflicts on OS/2.
2. To additions from Olly Betts <olly@muscat.co.uk> that affect spool
   users:
   
       set spool_check_up_on_nov 1
       
   will cause slrn to check to make sure that an article that is
   referred to by the overview file actually exists.  The default is 0.
   See the slrnfeat.h variable SLRN_HAS_FAKE_REFS for the other feature.

3. New .slrnrc function:

     include "filename"
     
   For example, your .slrnrc file can load other files via:
   
     include ".slrn/colors"
     include ".slrn/keybindings"
     
4. Two new .slrnrc variables:

     set post_object    "inews"  % or "nntp"
     set server_object  "spool"  % or "nntp"
     
   This means that if you compiled slrn to default to nntp, you
   nolonger need to run slrn via
   
      slrn --spool
      
   to read from a news spool.
   
5. macro function extract_article_header will not fetch the article
   from the server if the requested header is already available.

6. Now possible to save replies to a file:

     set save_replies "News/Replies"
     
   and you can specify the string to be used in the reply:
   
     set reply_string "In %n, you wrote:"

7. Small improvments such as re-wrapping upon window resizing and the
   message-id is also saved in the save_posts file.
   
8. New intrinsic: get_next_art_pgdn_action.  See README.macros for
   more information.

9. `username whatever' is not obsolete.  Use `set username WHATEVER'
   instead.  This change allows username to be changed via a macro.

10. Grouplens support changed to match current grouplens protocol.

11. Wrapping now takes place on word boundaries.
    frank_thieme@l2.maus.de provided a similar patch.
    
12. VMS patches by Ian.Miller@softel.co.uk.

Changes since 0.9.3.1
0. Bug fix involving non-XOVER headers.  This alone caused me to
   discontinue 0.9.3.1.
1. Misc bug fixes, char set tweaking
2. New variable for better compliance with standards:
   
      set reject_long_lines 1

   If non-zero, slrn will reject posting articles with non-quoted
   lines whose length exceeds 80 characters.

3. New editor options:
     
      set post_editor_command "my_posting_editor"
      set mail_editor_command "my_mailing_editor"
      set score_editor_command "my_score_editor"

   These may be used to override the more generic `editor_command'.
   For example, I use:
   
       set score_editor_command "jed %s -g %d -f score_arrange_score"

4. Patches for display code provided by itz@rahul.net (Ian T Zimmerman).
   There is a new .slrnrc variable:

      set display_author_realname 1
      
   It controls whether or not the real name should be displayed.

5. Spoiler patches from Olly Betts with new slrnrc variable:

   % set to 0 to keep the display still, and just reveal the spoiler
   % set to 1 to start a new page when spoiler is revealed
   % set to 2 to keep the display still, and reveal ALL spoilers
   % set to 3 to start new page and reveal ALL spoilers
   set spoiler_display_mode 1

Changes since 0.9.2.1
-13. Small patches from Uichi Katsuta <katsuta@lang2.bs1.fc.nec.co.jp>,
     and uudeview patches from Mark McWhorter <morak@ziplink.net>.
-12. Re: now added to subject header of reply.
-11. Fixed a bug that manifested itself when scoring on non-XOver
     headers.

-10. If a posted article is cc'd, the message-id used for the article
     will also be used in the email.
-9. `slrn --nntp --debug FILE' may be used to write out the dialog
    between slrn and the nntpserver to FILE.  This is a debugging aid.

-8. Sort by date added:
       set sorting_method 8    % most recent first
       set sorting_method 9    % thread with most recent first
       set sorting_method 10   % most recent last
       set sorting_method 11   % thread with most recent last

-7. If slrn is run in NNTP mode, the preprocessor symbol NNTP will be
    defined while processing the .slrnrc file.  If it is run in spool
    mode, SPOOL will be defined.

-6. Patches from Justus Pendleton <justus@ryoohki.res.cmu.edu> enabling
    slrn to work with uudeview.

-5. More OS/2 patches from Bjoern Frantzen enabling slrn to work with
    other mailers.

-4. New slrnrc variable: set metamail_command "metamail"

-3. Workaround for XHDR bug in DNEWS

-2. slrn/doc/os2keys.txt describes OS/2 key sequences.  They differ
    from the standard ANSI escape sequences.

-1.  Distribution reorganized.  Autoconf config files are in autoconf
    directory and documentation in doc dir.
    
0.  Offline reading possible by using the new `slrnpull' program.  See
    the slrnpull documentation for details.  `make slrnpull' should be
    sufficient to compile it.

1.  Small CC: problem under OS/2 fixed by Marko Teittinen
    (marko@tekamah.com). 

3.  New slrn.rc variable to control scrolling behavior: 

       set scroll_by_page 1
       
    to have slrn automatically perform a pagedown/up at window 
    boundaries.  This requires slang 0.99-38 otherwise this does
    nothing.
    
4.  New .slrnrc options:

      % Start new thread if subject changes
      set new_subject_breaks_threads  0
      
5.  New charcter set mapping code.  The idea is to translate incoming
    and outgoing articles from isolatin to the ``native'' character
    set.  For example, under OS/2, the native character set is assumed
    to be "ibm850".  The character set may be specified by the slrnrc
    line:
    
        set charset "ibm850"      % default for OS/2
        set charset "isolatin"    % default for Unix and VMS
	
    Currently only ibm850 and isolatin are supported.  I suspect a
    future version of slrn will be more precise in the specification
    of isolatin and support more chatacter sets.  But the current idea
    is that there is one ``usenet'' character set called ``isolatin''
    and selecting isolatin as the host character set will essentually
    turn of the mapping since isolatin --> isolatin is just the
    identity map.
    
    I am grateful to Bjoern Frantzen, bjoff@bgnett.no for the original
    code as well as other OS/2 fixes.

6.  Small tweak to MIME encoding.

Changes since 0.9.2.0
0.  Bug causing slrn to hang on VMS fixed.  The bug was tracked down
    with the help of Andrew Brennan <brennan@crashprone.allegheny.edu>.

1.  man page and slrn.rc updated to reflect the fact that
    `art_header_bob' and `art_header_eob' functions were renamed to
    simply `header_bob' and `header_eob', resp.  Also, the functions
    `goto_beginning' and `goto_end' are being phased out in favor of
    `art_bob' and `art_eob', resp.
2.  Fixed a compilation problem on NeXT.  mching@inow.com
    submitted OS/2 makefile and config patches for EMX compiler, and
    cardio@orsola.med.unibo.it (cardio) submitted patches for Ultrix.
    
3.  The default for min_high_score was incorrectly set to 0.  It has
    been changed to 1.
4.  New intrinsics for macros:
	 get_header_score
	 set_header_score
5.  New feature: SLRN_HAS_END_OF_THREAD
    See src/slrnfeat.h for more information.  This feature is enabled
    by default.  In the current implementation, it is a compile-time
    option-- there is nothing to disable it at run-time.

6.  Some of the documentation updated.

Changes since 0.9.1.0
0.  The macro functions read_mini and read_mini_no_echo now take three
    arguments.  See README.macros for more information.  This change
    was necessary because the ``read input from user'' routines are
    now more flexible and support recall of previously entered text.

1.  Renamed `group_mode_hook' to `group_mode_startup_hook'.  Added a new
    hook `group_mode_hook' that is called every time group mode is
    re-entered.
2.  Oops.  A horrible bug that manifested itself when the quote string
    was not specified via `set quote_string' has been fixed.
3.  `set use_color' added so that `set use_color 0' may be used to
    turn off color support.
4.  The name of a header and its value may be be given a different
    colors using, e.g.,
    
        color headers "green" "white"
        color header_name "red" "white"
	
    This means that the header 'From: davis@space.mit.edu' will appear
    with 'From:' in red/white and the rest will appear as green/white.
5.  It is now possible to customize the keybindings of the command
    prompt.  The defaults are:
    
setkey readline bol		 "^A"		% Beginning of line
setkey readline eol		 "^E"		% End of line
setkey readline right		 "\e[C"		% Move right
setkey readline left		 "\e[D"		% Move left
setkey readline bdel		 "^H"		% Delete backward
setkey readline bdel		 "^?"		% Delete Backward
setkey readline del		 "^D"		% Delete Foreword
setkey readline deleol		 "^K"		% Delete to End of line
setkey readline trim		 "\e/"		% Trim whitespace
setkey readline quoted_insert	 "^Q"		% Quoted insert

    The name of the keymap is `readline'.

6.  New intrinsic functions for macros include:

      thread_size              % Returns number of headers in thread
      collapse_thread          % Collapse current thread
      uncollapse_thread        % Uncollapse current thread
      is_thread_collapsed      % Returns non-zero if current thread is collapsed
      get_header_tag_number   
      article_as_string        % Returns whole article as a string
      tt_send                  % Send argument to terminal
      header_next_unread       % goto next unread header
      input_pending            % Wait for input or timeout
      getkey                   % read keyboard character
      ungetkey                 % push back keyboard character
      set_input_string         % provide answer to prompt
      get_yes_no_cancel        % get response from user
      
    See README.macros for more information.

7.  New .slrnrc variable macro_directory controls where macro file are
    loaded from.  For example, 
    
        set macro_directory "News/macros,/usr/local/lib/slrn/macros"
	interpret "util.sl"
	interpret "tin.sl"
	
    will search for the macro files in $HOME/News/macros,
    /usr/local/lib/slrn/macros, and, as a last resort, in the home
    directory ($HOME).

8.  Now possible to add custom headers to followups and replies.  The
    actual headers are controlled by new slrn.rc variables:
    
         set reply_custom_headers "X-Bla: Bla bla"
         set followup_custom_headers "X-Bla: Bla bla"
	 
    The string assigned to these variables may contain the format
    specifiers of the 'followup' variable.  This idea was presented to
    me by John Goerzen <jgoerzen@complete.org>.
    
9.  Several people have sent me patches for customization of high/low
    score thresholds.  The following .slrnrc variables are now available:
    
          set min_high_score 1
	  set max_low_score 0
	  set kill_score -9999

    One might want to set these on a group by group basis.  This is
    possible via a macro.  The best way to do this is to put the
    appropriate statements in a 'pre_article_mode_hook' described below.
    
10. New hooks for macros:

        resize_screen_hook : called when screen size changes
	pre_article_mode_hook: called before grabbing headers from server
	  in article mode.


    
Changes since 0.9.0.0
-1. features.h changed to slrnfeat.h to avoid GNU C problems.

0.  Misc bug-fixes, e.g., xgtitle operational again.  In addition, I
    rewrote the lowlevel tcp/ip code so that slrn should now be more
    responsive to Ctrl-G abortion and suspension.

1.  The following .slrnrc commands are obsolete and will not be
    supported for too much longer:

     "quote_string"
     "realname"
     "replyto"
     "organization"
     "followup"
     "cc_followup_string"
     "decode_directory"
     "editor_command"

    These are now `set' type variables.  That is, the new usage is:
    
      set quote_string ">"
      
    etc...

2.  If a piece of authentication information is supplied as an empty
    string as in
    
         nnrpaccess "news.mit.edu"  "davis"  ""
	 
    slrn will prompt for the information.  

3.  It is now possible to specify the ``help'' string that is
    displayed at the bottom of the display via the variables:

       set art_help_line "bla bla"
       set header_help_line "more bla bla"
       set group_help_line "and even more"
       
4.  Scrolling improvements.
5.  It is now possible to use, e.g., 

        setkey article "digit_arg"  "\eOP1"
        setkey group   "digit_arg"  "\eOP1"
       
    to bind a key to the prefix argument function.
6.  Group search also search group description
7.  `set use_tilde 0' may be used to turn off tilde feature.
8.  New interpreter intrinsics:

      get_group_flags
      set_group_flags
      is_article_visible
      is_group_mode
      extract_article_header
      set_article_window_size
      read_mini_no_echo
      save_current_article
      select_group
      group_search
      group_down_n
      group_up_n
      group_unread


Changes since 0.8.8.4
0.  Tiny problem with server timeout fixed.
1.  GroupLens support added.  See README.GroupLens

2.  Sort by score implemented.  See src/features.h to disable it.  To
    sort by score, add:
    
        set sorting_method 5
	set display_score 1
	
    to your .slrnrc file.  Set display_score to 0 to disable
    displaying the score value.  If the score value is displayed, the
    number of lines in the article will not be displayed.
    Thanks go to Olly Betts <olly@mantis.co.uk> for this feature.

3.  Score file lines such as:

       [~rec.crafts.*, rec.hobbies.*]
       
    are now supported.  The `~' character means that the set of scores
    implied by this line applies to any group EXCEPT rec.crafts.* and
    rec.hobbies.*.  That is, the `~' character may be used as a NOT
    operator in this context.
    
4.  New slrnrc configuration option:

      set custom_headers "X-Whatever: bla\nX-Misc: bla bla"

5.  New group mode function: move_group.  This will allow you to use the
    up/down arrow keys to move a group to a different location.  It
    has a default binding of `m'.

6.  Added Felix von Leitner's cross posting and tilde patches.  The
    cross posting patch is enabled via the SLRN_HAS_MSGID_CACHE feature.
    Similarly, the tilde patch is available via SLRN_HAS_TILDE_FEATURE.
    Thanks Felix.

7.  S-Lang interpreter available.  Set SLRN_HAS_SLANG in features.h to
    enable it.  See also README.slang and slrn.sl for more
    information.  The 0.9 series of slrn releases will feature more
    and more interpreter capabilities.

Changes since 0.8.8.3
0.  Bug fix release and patches to get it to compile under VMS again.

Changes since 0.8.8.2
0.  Misc bug fixes
1.  Support for INEWS and LOCAL NEWS SPOOL.  The INEWS patches were
    originally provided by Erik Manders <erik@il.ft.hse.nl>.
    Olly Betts <olly@mantis.co.uk> is responsible for the local spool support.
    Edit src/features.h to enable these options.
    
    The following slrn.rc variables are are related to the spool support:
    
	 set spool_inn_root "/export/opt/inn"
	 set spool_root "/export/news"
	 set spool_nov_root "/export/news"
	 % -- The following filenames are relative to spool_root
	 set spool_nov_file ".overview"
	 set spool_active_file "data/active"
	 set spool_activetimes_file "data/active.times"
	 set spool_newsgroups_file "data/newsgroups"

    Of course default values for these files may be hard-coded.  See
    src/features.h.
    
    In addition, new command line arguments have been added:
    
          --inews ==> use inews for posting
	  --nntp  ==> use nntp
	  --spool ==> use local news spool
	  --version
	  
2.  Score files now allow more than one newsgroup pattern to be specified,
    e.g., 
    
        [sci.*, comp.*]
	   .
	   .

Changes since 0.8.8.1
1.  base 64 decoding support
2.  On VMS, the personal slrn configuration file has been renamed to slrn.rc.
    See features.h for changing this.  Also, many thanks to Andy Harper
    (A.HARPER@kcl.ac.uk) for work on DCL make files.
3.  Small bug fixes

Changes since 0.8.8.0

0.  Bug fixes (hangup, connection aborts, article/header percentage counts,
    etc..)

1.  Oops.  Forgot to provide a way to turn off video attributes.  Now you can
    use `none', e.g.,
    
        mono headers none
	
2.  New variable for group descriptions: group_dsc_start_column

        set group_dsc_start_column 40
	
    causes descriptions to start in column 40.
3.  Now possible to color descriptions via:

        color description blue white
	mono description bold 

4.  ^G abort of header retrieval.
5.  New variable:

        set lines_per_update 50
	
    sets the granularity of slrn's percentage meters.

6.  Spoiler support provided by Olly Betts (olly@mantis.co.uk).  The .slrnrc
    variable `spoiler_char' may be used to specify the character used to
    hide the text.  The default is '*':
    
        set spoiler_char '*'

7.  .slrnrc `ignore_quotes' specifier can take up to 5 regular expression
    patterns, e.g.,
    
        ignore_quotes  "^ *[:=|+>]"    "^ *[A-Za-z]>"
	
    specifies two patterns.

8.  Certain compiler symbols such as NO_DECODE have been renamed and moved to
    the new file: features.h
Changes since 0.8.7
0.  Misc bug fixes

1.  Use of the XGTITLE command is turned off by default.  Use the variable
    `use_xgtitle' to turn it on.

2.  New configuration settings for your .slrnrc file

       set Xbrowser "netscape %s &"
       set non_Xbrowser "lynx %s"

    Press the `U' key (browse_url) for slrn to search for a URL and call the
    appropriate browser.  Thanks go to Justus Pendleton
    <justus@ryoohki.res.cmu.edu> for the patches.
    
3.  When creating a score from within article mode, you will be prompted for
    whether or not the score is local or global.  This patch was the idea of 
    Colin Perkins <csp@ohm.york.ac.uk>.

4.  Use `set query_reconnect 0' in your .slrnrc file to turn off
    reconnection confirmation.

5.  `ESC 1 *' now removes all `*' marks.
6.  If `cc_followup' is -1, slrn will prompt whether or not to cc the
    followup message.
7.  If linked against slang version 0.99-30 or later, it is possible to
    customize the video attributes on mono-chrome terminals, e.g.,
    
         mono cursor reverse blink
	 mono headers bold
	 mono author bold blink
	   .
	   .

    The above lines will cause the author part of the header to blink in
    bold, the cursor will blink in reverse video, etc...

8.  New variable to set: write_newsrc_flags
    
         % If 0, save all groups when writing newsrc file
	 % if 1, do not save any unsubscribed groups
	 % if 2, do not save any unread-unsubscribed groups
	 set write_newsrc_flags 0

9.  Better checking of articles before posting.  Now, a new screen will
    appear with error messages if the article appears badly formatted.

10. Modified scrolling behavior when the article window is open.  Now the
    next and previous headers are always visible.

Changes since 0.8.6
0.  Under Unix there is a new `configure' script for building slrn.
1.  ``Header Numbers'' add for more efficient article selection.  This is
    enabled by default and may be disabled by adding
    
        set use_header_numbers 0
	
    in your .slrnrc file.  In addition, the color of these numbers may be
    controlled via something like
    
        color header_number "green" "white"
	
    The numbers appear at the left margin of the header window.  To goto a
    particular numbered header, e.g., 12, simply press `1' then `2' followed
    by RETURN, SPACE, etc...
2.  The function ``xpunge'' has been added for article mode.  The default
    binding of this function is to the `x' key.  It removes already read
    articles from the list.
3.  If slrn does not read the active file, then it will now attempt to use
    the `xgtitle' command to query the server for newsgroups matching a
    pattern.  (This affects the `L' key in group-mode).
Changes since 0.8.5
-1. New distribution structure
0.  Thanks to Jay Maynard (jmaynard@nwpros.com), slrn now runs under OS/2.  
    Since this is the first OS/2 version, it should be regarded as ALPHA.
1.  New .slrnrc configuration variable: prompt_next_group.  If 0, slrn will
    not provide the opportunity to use up/down arrow keys to select the next
    group.  Instead, pressing a key that performs a goto next group action,
    e.g., the Next-Group mouse button, will simply put you in the headers of
    the next group in the group list.
2.  When the mouse is clicked on a button at the top of the display, the
    button will ``flash''.  The color that is used to simulate the flash may
    be specified by using, e.g., 
    
         set color menu_press blue yellow
	 
    in your .slrnrc file.
3.  New groups are displayed with an `N' in the flags column.
4.  `ESC 1 L' will hide unsubscribed groups  (`L' with a prefix argument).
5.  The `?' key may be used in help mode to re-start help.
6.  OS/2 port thanks to Jay Maynard <jmaynard@admin5.hsc.uth.tmc.edu>.
    Note: this port is still considered to be in its alpha stage.
7.  slrn will nolonger run unless the user has a username and a FQDN.
8.  New article mode functions (Thanks to Alain.Knaff@imag.fr (Alain Knaff)):
      fast_quit                       % quit news reader from article mode
      skip_to_prev_group              %
    None of these function have default bindings.
9.  When replying, slrn will warn the user if the email address appears
    invalid.
10. New configuration variable:

       set use_metamail 0
       
    If non-zero, metamail will be called to process MIME articles that 
    slrn does not support.

Changes since 0.8.4
1.  Small bug fixes (nothing major).
2.  Cosmetic change where one can more easily see the progress of the
    download of tagged articles.  In addition the server name is printed on
    the top status line.
3.  The `*' (toggle_header_tag) function has been changed.  If used on a
    collapsed thread, it will tag the entire thread.  In addition, after
    pressing `*', the pointer moves down one header.
4.  -m command line option forces XTerm mouse reporting to be turned on.
5.  When the mouse is enabled, ``buttons'' also appear on the top status
    line.  Simply click on them with the mouse.  Perhaps in the future,
    these buttons will become menus.

Changes since 0.8.3
0.  The slrn makefile has changed.  Now it asks for a location to put slrn
    object files and it asks for the location of the slang library file.
    The nice thing about this is that it is easy to compile slrn under
    multiple architectures.  The down side is that some makes will not work
    with the Makefile.  If your make fails, use Makefile.old.  Since I do
    not plan to continue support for Makefile.old, please look into
    installing GNUmake.
1.  .newsrc file is now created in mode where only user has read permission
    to it.
2.  If a prefix argument is given to the subscribe/unsubscribe commands, the
    user will be prompted for a group pattern which will be used, e.g., 
    pressing `ESC 1 s' and entering `*linux*' at the prompt will result in
    a subscription to all newsgroups of form `*linux*'.
3.  If a prefix argument is given to the `K' (create_score) function, the
    editor will be called to edit the score file-- no questions asked.
4.  New .slrnrc variable: query_read_group_cutoff
    Whenever slrn enters a group with `query_read_group_cutoff' or more
    unread articles in it, it will prompt for how many to read.  The default
    is 100.  If set to 0 or less than 0, slrn will not prompt at all, i.e.,
    
        set query_read_group_cutoff 0

5.  It is now possible to have articles automatically wrapped by adding 4 to
    the wrap flags value.  See the slrn.rc file.
6.  VMS changes: some patches added, ``makefiles'' fixed

Changes since 0.8.2
1.  If slrn cannot find a fully qualified domain name, it will not run.
    This name can be specified in the .slrnrc file so there is no excuse for
    not having one.  There are too many articles already floating around
    usenet with bad hostnames and I do not want slrn to contribute to this.
2.  Bug in authorization fixed
3.  Oops.  If one were editing a file from within slrn and the window was
    resized, slrn would re-draw the window!  That is fixed.
4.  article wrapping added-- press `w' in article mode to wrap/unwrap.  The
    variable `wrap_flags' may be used to control whether or not headers or
    quoted material is wrapped, e.g.,
    
        set wrap_flags 1    % Wrap headers
	set wrap_flags 2    % Wrap quoted material
	set wrap_flags 3    % Wrap headers and quoted material
	
    The default is to wrap everything (3).

5.  slrn may be started as in `slrn -h server.name:XXX' where XXX in an
    integer that represents a port number. 

6.  `set sendmail_command' may be used in the .slrnrc file to specify an
    alternative mail program.  The default is: 
    
          "/usr/lib/sendmail -oi -t -oem -odb"
	  
    See config.h for selecting a different default.
       
7.  ESC u in group mode may be used to Un-Catchup on a group.

Changes since 0.8.1
1.  Misc bug fixes:
      MIME re-worked
      some VMS problems ironed out
      VMS: callable mail support

Changes since 0.8.0
1.  The `toggle_sort' function bound to `ESC s' in article mode has been
    modifed.  Now, it prompts for the sorting method.
2.  New variables for the .slrnrc file:

      % If 0, do not sort.  If 1, perform threading.  If 2, sort by subject
      % If 3, thread then sort result by subject
      set sorting_method 3

      % If non-zero, threads will be uncollapsed when a group is entered
      set uncollapse_threads 0
      
    Note: methods 2 and 3 were not available in previous versions of slrn.
    This is why the `toggle_sort' function needed to be modified.
3.  It is now possible to have all posted articles saved in a file.  The
    file is specified in the .slrnrc with a line like:

        set save_posts "News/My_Posts"

4.  slrn now generates its own message id provided that it can find the
    machines fully qualified domain name (FQDN).  The reason for this is
    that one can easily more efficiently score follow-ups to the user's
    posted articles.  For example, if the FQDN is `machine.my.domain' and
    the user's name is `user' then simply put:
    
       [*]
       Score: 100      (or whatever)
       References: user@machine.my.domain>
       
    in the score file.  (The first part of the generated message-id is
    composed of a base 32 representation of the current time and process-id).
5.  Default values available at all yes/no prompts.

6.  Saving an article is slightly different but simpler.  The new bindings
    are: 
    
	`:'  uudecode file
        `o'  save a file-- no decoding
	
    Use "decode" and "save_article" to re-bind these.
    See the FAQ for more detailed help on uudecoding articles.
    
7.  New variable: 'save_directory' may be used to specify where files are
    saved.  The default is 'News'.  Use something in your .slrnrc file:
    
        set save_directory "News"
	
8.  There is now an option for slrn to read the active file upon startup.
    Using this option may result in faster startup times.  Using the active
    file also has the advantage that the `L' key will list all groups
    available at the server.  
    
    There are two ways of enabling this option:
    
        a.  Startup slrn with the -a switch:  slrn -a
	b.  Add the line:
	  
	         set read_active 1
	   
	    to your .slrnrc file.

9.  The `Expires' date may be given in one of the following formats:

       MM/DD/YYYY
       DD-MM-YYYY
       
    Previous versions only allowed the first format.

10.  MIME support add by Michael Elkins <elkins@aero.org>.
    To enable MIME support, add:
    
        set use_mime 1
	
    to your .slrnrc file.  In addition, you may select a character set by
    adding something like:
    
        set mime_charset "iso-8859-1"

    to your .slrnrc file.
    
    The MIME code is still in the testing phase but it appears to be ok.
    
Changes since 0.7.9.0
1.  If Cc: header appears in a followup, the message will also be email to 
    the addresses listed on the line.  The address `poster' will be
    considered as an alias for the original poster.  This header will
    automatically be generated if the line:
    
         set cc_followup 1
       
    appears in the .slrnrc file.
    By default, the body of an email message generated this way will be
    prefixed by the string:
    
      [This message has also been posted.]
      
    To change it, use a line of the form:
      
      cc_followup_string "[Note: Even though I posted this, here is a copy.]"
      
    in your .slrnrc file.
    
2.  Broken threads are now collaped together.
3.  In replies, the In-Reply-To header is generated with the message-id of
    the original post.
4.  New variable for .slrnrc: `set confirm_actions 1'.  If set to 1 (default
    is 0), confirmation on quitting, followup, reply, etc... is not performed.
    
5.  Arbitrary header keywords are now allowed for Score files.  Keep in mind
    that a score that is based on such keywords take ALOT longer to process.
    The command line option -k0 will suppress expensive scores.  

    In addition, the K key (bound to `toggle_scoring') may be used at the
    group level to set the scoring mode.

6.  Enhanced score file syntax:

       a.  If Score::  (TWO colons) is used to denote a score, all
           expressions that it covers will be considered as OR type
	   expressions.  That is,
	  
	       Score:: 20
	        Subject: larry
	        Subject: curly
	   
          is (almost) equivalent to
	  
	       Score: 20
	        Subject: larry
	       Score: 20
	        Subject: curly
          
	  Homework: What do I mean by ``almost''?
	  Note: Scores with only one colon are AND scores.
	  
      b.  If a score value is prefixed with the `=' sign, e.g., Score: =30
          Then scoring on the article is regarded as finished and a value of
	  30 will be assigned to the article.

    See score.txt and KILL_FAQ for more information.
    
7.  Article mode keybindings of `<' and `>' have been changed to goto the
    beginning and end of the article, resp.
    
8.  The `#' key may be used to NUMERICALLY tag articles.  The save operation
    now saves tagged articles in their numerically tagged order.  The key
    sequence `ESC #' will remove all numerical tags.
9.  The save function is now more sophisticated.  It can now save tagged
    articles, the current thread, or a single article.  After it saves, it
    prompts for decoding.  The present version of slrn can only decode
    uuencoded files or share archives.  If decoding is selected, slrn will
    prompt for whether or not he save file should be deleted.
    
    The variable `decode_directory' may be used to control where decoded
    files are placed.
    
10. If a line of the form:

       set use_tmpdir 1
      
    appears in the .slrnrc file, a tmp directory will be used for posting
    and replying.  The directory /tmp will be used unless the environment
    variable TMPDIR exists.
    
11. It is now possible to set the editor command in the .slrnrc file, e.g.,

        editor_command "jed %s -g %d -tmp"
	
      

Changes since 0.7.8.2
1.  Score files added-- See score.txt for score file syntax.  To use score
    files you must add a line such as:
    
         scorefile "News/Score"

    to you .slrnrc file.  slrn assumes no default value for this file.  With
    this defined, you may either edit the file by hand or press the `K' key
    in article mode to automatically add ``scores'' to this file.  If you
    edit it by hand and you use the jed editor, see `score.sl' for a syntax
    highlighting and indentation mode for score files.
    
    A new commad line option `-k' may be used to turn OFF score file
    processing.

2.  In article mode, `=' key will now follow articles of a specified
    subject.  In addition, the `!' key will go to articles with high scores.

Changes since 0.7.8.1
1.  Threads are now collapsed.  An individual thread may be un-collapsed by
    pressing `ESC t'.  Pressing `ESC t' will re-collapse it.  In addition,
    simply reading the first article in a thread will un-collapse it.
    Deleting a collapsed thread will delete all articles in th thread.
    Hopefully, this interface will seem intuitive.
    
    Note: `ESC 1 ESC t' will toggle collapsing of ALL threads.  
    
    To bind this to a different key, use the function 
    `toggle_collapse_threads'.
    
    Of course the thread number has to have a color.  The default is:
    `color thread_number "blue" "white"'
    
2. New configuration variables for your .slrnrc file (defaults shown)

      set query_next_article 1
      set query_next_group 1
     
   For example, setting query_next_article to 0 will result in the next
   article being read when the end of the current one is reached.

3. Parse error messages while parsing .slrnrc file are now more meaningful.

Changes since 0.7.8.0
1.  Additional support for XTerm mouse (Thanks Mark).  These include:

    Article mode:

        Left Button: Help bar:        return help
                     Header status:   header page down
		     Article status:  Next unread
		     Article window:  Article page down
      Middle Button: Help bar:        toggle show author
                     Header status:   hide article
		     Article status:  toggle quotes
		     Article window:  nothing
      Right Button:  Help bar:        help
                     Header status:   header page up
		     Article status:  Prev unread
		     Article window:  Article page up
                     
    Similar functionality for group mode.
    
2.  VMS makefile fixed
3.  New group mode function: transpose_groups.  The default binding is ^X^T.
    This will transpose the position of two groups.  This may be used to
    rearrange groups.
4.  man page updated
5.  `set color signature' now supported.  (Thanks to
    combee@ptsg-austin.sps.mot.com (Ben Combee))
6.  Misc bug fixes.
7.  `hide article' will now toggle.

Changes since 0.7.7
0.  Misc bug fixes
1.  slrn calling syntax changed: The -D parameter has changed to lowercase -d.
    Now, a new -Ddefine-something is available.
2.  If using slang0.99-20 or newer, it is possible to use slang preprocessing
    in your .slrnrc file.  Use the -D flag to define a token.
3.  Oops!  Previous version broke art_lineup, art_linedn functions.
4.  Problem with "unknown" as username fixed.
5.  Suspension now allowed during lengthy transfers.  This requires slang
    version 0.99-20 or greater.
6.  New article mode function: "toggle_header_tag".  A header that is
    ``tagged'' is marked with a `*' in the left column.  The default binding
    is to the `*' key (Shift-8).  A tagged article will not change its read
    status by the `catchup' series of functions.  There may be more uses
    later.
7.  If a `prefix' argument is given to the `get_parent_header' function, the
    entire tree will be reconstructed.  This means that the whole tree can
    be reconstructed by pressing: ESC 1 ESC p
8.  Another oops.  -create flag was not working in 0.7.7.
9.  `set unsubscribe_new_groups' added to slrn.rc file.  If this is non-zero,
    newgroups will not automatically be subscribed to, e.g., if you desire
    this behavior, put the following in your .slrnrc file:
       set unsubscribe_new_groups 1
10. In an effort to make the article screen look less busy, a new
    configuration variable `show_thread_subject' has been made available.
    If zero, only the parent thread's subject will be displayed.  If you do
    not like this, add:
      
        set show_thread_subject 1
	
    to your .slrnrc file.
11. By default, articles are saved in folders with names beginning with a 
    capital letter.  If a folder with a lower case name already exists, slrn
    will use that.  That is, it is backward compatable.
12. Improved man page (Thanks to Howard Goldstein <hg@n2wx.ampr.org>)
13. XTerm mouse support added.  This option requires slang version 0.99-21.
    Use `set mouse 1' in your .slrnrc file to enable.  Note: mouse reporting
    is disabled at all slrn prompts so the mouse will be available for
    cut/paste in such contexts.

Changes since 0.7.6
1.  Improvements for VMS.  Now supports NETLIB (Thanks Andrew).
2.  Improved detection of supercite
3.  The article mode functions `catchup' and `uncatchup' have changed
    slightly in a way that may be more useful.  Now, they function on all
    headers from the top of the header list to the current header.
    Previously they functioned on all headers from the current one to the
    end of the list.  Of course the functions `catchup_all' and
    `uncatchup_all' are still available.
4.  New `config.h' file that allows HOSTNAME, ORGANIZATION, etc... to be
    compiled into the executable.
5.  Slightly improved FAQ.

Changes since 0.7.5
0.  VMS port thanks to Andrew Greer (Andrew.Greer@vuw.ac.nz)
1.  Small bug in help.c corrected that caused problems on some systems if a
    custom help file was used.
2.  New function: repeat_last_key.  The default binding is `.'.  The
    function that `.' used to be bound to has been moved to `;'.
3.  slrn.rc may be placed in SLRN_LIB_DIR to provide defaults for all users,
    e.g., organization, hostname, ...  See INSTALL.
4.  Catchup bindings changed in article mode.  (By popular demand).
5.  Misc improvements.

Changes since 0.7.4
1.  Oops!  It was possible to cancel any article in the old version.  I
    forgot to add a `return' statement after checking to make sure that the
    person cancelling actually posted the article.
2.  Missing comma between two strings in help.c added.
3.  `delete_thread' function added to article mode keybindings
4.  `followup' added to slrn.rc.  This allows the user to set the followup 
     string.  For example, I use:  followup "On %d, %r <%f> wrote:"
     See slrn.rc for more information.
5.  It is now possible to concatenate newsrc files.  slrn will now ignore
    repetitions.  For example, suppose that you have an old newsrc file that
    you wish to bring uptodate.  Let's call it `old'.  Suppose that another
    one, `new' is much more extensive.  Then do:
    
        % mv old old~
	% cat old~ new > old
	% slrn -f old
	
    If you have no idea how this may be useful, then you do not need it.
6.  Group mode searches will automatically wrap.    
7.  Some support for automatic detection of ``super-cited'' articles so that
    quoted lines are handled properly.  This works most of the time.
8.  If `set no_backups 1' appears in the .slrnrc file, backups of the .newsrc
    file is turned off.
9.  `g' in article mode will skip to the next digest.
10. User is now prompted for chance to re-edit a message after editing.
11. `set beep 0' may now be used to turn off the bell.  See slrn.rc.

Changes since 0.7.3
1.  -i init-file command option added.  This allows a different slrn.rc file
    to be specified (default: .slrnrc).
2.  Silly problem fixed when -create option used but .newsrc does not exist.
3.  A line read in from the server that begins with two periods is stripped 
    of one of them as RFC977 requires.
4.  Using a prefix argument to the followup command will insert the original
    headers into the followup.
5.  If server drops the connection, an attempt is made to reconnect.
    (ljz@panix.com)

Changes since 0.7.2
1.  Slight modification to extract real name routine so that if the name is
    not available, the address is used.
2.  Now possible to specifiy a color for quoted text via `color quotes'.
    The default is: color quotes red white
    This really does improve readability of an article with quoted material!
3.  NNRP authentification support added.  In .slrnrc, use a line like:
       nnrpaccess HOSTNAME USERNAME PASSWORD
 
Changes since 0.7.1
0.  The XPAT server command is exploited if it is available.  Not all servers
      support it even though it is pretty standard.
1.  ESC Ctrl-P will find all children of current header by querying the
    server.
2.  Confirm Follow-up when poster sets the followup line to poster.
3.  ESC-d will now mark the current thread as read-- that is, current header
    plus all children.
4.  SPACE in article mode can be used to read next article or go to next
    group if pressed twice at the end of the current article.
    
Changes since 0.7.0
1.  Typo in the `unsetkey' function corrected.  The typo was a serious one.
2.  Small change in the Top/Bottom/Percentage calculation for the status line.
3.  Misc bug fixes
4.  See help.txt for creating your own custom help screen.

Changes since 0.6.3
1.  Added `realname' to slrn.rc file.
2.  TRUE referenced based threading added.  Subject sorting has been 
      abandoned.  A tree in drawn showing how articles are threaded.  The
      color of the tree may be specified by `color tree' in your .slrnrc
      file.  ESC-p will got to the parent of the current header.
      
      Note:  If the terminal cannot support line drawing characters, the
      tree will not appear.

Changes since 0.6.2
1.  Xref mark as read now takes advantage of group name hashing.
2.  Fixed problem with getlogin on some systems.

Changes since 0.6.1
1.  `N' in article mode will now skip on to next group.  Lowercase `n' still
    retains its previous meaning.
2.  Bug fixed in catchup-all in article mode.  Previously, it did not mark
    all as read.
3.  A description of each newsgroup can be displayed next to the group name. 
    Use ESC-a to toggle it on/off.
4.  New environment variable SLRN_LIB_DIR determines where to load files
    that may be shared by all users, e.g., the group description file.  By
    default, it is /usr/local/lib/slrn.  See INSTALL for more details.
    
Changes since 0.6.0
1.  The `G' key at group mode may be used to retrieve new news from the
    server.  In addition, `X' will force the newsrc file to be saved.
2.  Small bug corrected that manifests itself when no groups are subscribed
    to (a very rare situation).
3.  The one-line help at the bottom of the screen is always visible now.  Of
    course, the full on-line help is still available.
4.  The Makefile has been modified so that slrn may be easily termified
    under Linux.
5.  Fixed a silly bug that made the -C color flag do nothing.

Changes since 0.5.3
1.  Selecting a group with an ESC prefix digit argument will now select
    unread articles too.
2.  My uudecode program can also unpack shell archives.  No need to edit
    those headers either.
3.  When replying, the user defined quote string is used to quote the
    article. 
4.  ESC-r from article mode will toggle rot13 decryption.
5.  `|' in article mode will pipe article to an external command (e.g., lpr)
6.  Some cosmetic improvements by ljz@ingress.com (Lloyd Zusman).
7.  ESC-U, ESC-u, ESC-C, ESC-c added by ljz@ingress.com (Lloyd Zusman).
    These functions may be used to catchup and un-catchup on articles in
    article mode.
8.  IF the line: `set show_article 1' appears in your .slrnrc file, the
    article is displayed when article mode is entered.

Changes since 0.5.2
1.  Path header added when posting
2.  When the newsrc file is written, a backup is made of the previous version.

Changes since 0.5.1
1.  ESC-a toggles showing author's name on/off in the header window.  This
    provides a wider display for the subject.

Changes since 0.5.0
1.  Improved help screen for beginners.
2.  ESC-s now toggles header sorting on/off.
Changes since 0.4.0
1.    LOGNAME environment variable now checked to get the user's login name.
      Previously, only USER was checked.
2.    newsrc file locking added.
3.    TAB key now moves past quoted text
4.    `autobaud' keyword in .slrnrc file may be used to incicate that the
      output rate to the terminal should be synchronized to the terminal
      baud rate.  This behavior was always the default in previous versions.
      Now, it is off by default.
5.  The `L' key in the group menu may now be used to toggle the display of
    unsubscribed groups on and off.