Training courses

Kernel and Embedded Linux

Bootlin training courses

Embedded Linux, kernel,
Yocto Project, Buildroot, real-time,
graphics, boot time, debugging...

Bootlin logo

Elixir Cross Referencer

  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
*Thu Aug 11 2005

o Makefile.sub (HTMLDOCFILES): Add `refer.html'

*Mon Jun 20 2005

o Makefile.sub (HTMLDOCFILES_, EXAMPLEFILES_, PROCESSEDEXAMPLEFILES_): New
  variables.
  (install_data): Install files in `mom' subdirectories.
  Make it work actually.
  (uninstall_sub): Updated.

*Thu Jun 16 2005

o Makefile.sub (install_data, uninstall_sub): Use $(exampledir) for example
files.  Reported by Keith Marshall.

*Mon May 16 2005

o Update groff_mom.man.

*Thu May 12 2005

o Added margin notes capability

o Added mom-specific refer support; refer calls can be embedded in
  running text, sent to footnotes or endnotes, or collected for
  output on a bibliography page; also added mom-specific refer
  control macros

o Added bibliography page capability, with full suite of control
  macros

o Added referencing of footnotes and endnotes by line number

o Added capability to have footnotes run on when footnotes are
  being referenced by line number

o Added a post footnote space option, in case users want a little
  space between their footnotes

o Added ENDNOTE_MARKER_STYLE, so user can choose between endnotes
  identified by a numerical marker in the text, or by line number

o Added control macros to accommodate differing needs for endnotes
  identified by line number

o Added ENDNOTE_TITLE_SPACE, so user can control starting position
  of the endnotes page title

o Extended LIST so that it accepts lowercase alpha, uppercase roman
  numeral and lowercase roman numeral enumerators; also added a
  "prefix" argument (which comes *after* the separator argument)

o Changed RESET_LIST so that it can reset a list to any number,
  letter, or roman numeral, instead of just 1, a, A, I and i

o Change to handling of footnote/endnote markers in text; input
  lines before FOOTNOTE still require \c, but input line after
  FOOTNOTE OFF must be entered as a literal continuation of the
  line before FOOTNOTE, including any required word space or
  punctuation (this so users can get the footnote marker in text
  either before or after the punctuation without hassle)

o Added QUOTE_AUTOLEAD and BLOCKQUOTE_AUTOLEAD, so user can have
  quotes and blockquotes leaded differently from running text

o Reworked QUOTE and BLOCKQUOTE to accommodate _AUTOLEAD control;
  spacing above and below quotes is equalized *on a per quote
  basis* (not completely happy with this, but at least it gives
  users some flexibility in designing (block)quotes)

*Fri Mar 18 2005

o Added mom.vim to /examples

*Thu Jan 20 2005

o Added \*[TB+] and \*[B] to give inline functionality of .TN and
  .EL, respectively.

o Added SECTION and SECTION_CHAR as aliases of LINEBREAK and
  LINEBREAK_CHAR

o Added a NOBREAK option to PAD, so when PAD is called, it's possible
  to instruct mom not to advance on the page.

*Wed Jan 19 2005

o New macro, ADD_SPACE, so that extra space can be added at the
  top of a new page in document processing; the .ns call in HEADER
  was making additional space impossible

o Reworked handling of ALD/SPACE/SP and LS when they're used at
  the tops of pages during pure (i.e. non-docprocessing)
  typesetting.  First lines were still wandering.  Should also be
  more intuitive: ALD after LS advances the specified distance from
  the top baseline; LS after ALD doesn't change the position of the
  first baseline (i.e. merely sets the lead for the text that
  follows).

*Tue Dec 14 2004

o Fixed a small problem with spacing under quotes when paragraph
  spacing is turned on.

*Fri Dec 10 2004

o Put all calls in VFP_CHECK inside their own environment.  Without
  the .ev call, the trap invoked VFP_CHECK was chopping off the
  first word of the last line before footnotes.

*Dec 6 2004

o Small fixes to elvis_syntax.new (dealing with strings, \{\ and \}

o Changed
    .    ie \\n[#START] \{\
    .       if \\n[#DOC_HEADER]=0 \{ . \}
    .    \}
  in HEAD to
    .    ie \\n[#START] \{\
    .       if \\n[#DOC_HEADER]=0 \{ .RLD 1v \}
    .    \}
  so that HEADs at the start of docs with no docheaders falls on
  the correct baseline.

*Dec 3 2004

o Removed spurious parens from if ( \\n[#TRAP_DISTANCE] < \\n[#DOC_LEAD]*2 )
  in SUBHEAD.

*Oct 14 2004

o Reworked the LL macro so that the argument can take a prepended +
  or - sign (i.e. the argument is relative to the current line
  length).

*Oct 13 2004

o Added an .if \\n(.n=0 if to the ie clause in LS that controls how mom
  responds to initial LS invocation at page top if T_MARGIN has
  been set.  Now, if there's text on the "top" baseline, LS behaves
  as expected when invoked afterwards.

*Oct 11 2004

o Added an ie !r#DOCS clause to the processing of "top baseline"
  ALDs.  ALD is used extensively (internally) in the document
  processing macros, and does not need to check--indeed, should not
  check--for top baseline placement prior to execution.

*Sep 29 2004

o Additions to elvis_syntax.new

*Sep 12 2004

o Small fixes to the documentation.

*Aug 21 2004

o Removed superfluous second arguments from strings UP, DOWN, FWD
  and BCK

*Aug 8 2004

o Version changed from the 1.1.x series to 1.2.  All of the
  features I originally wanted mom to have originally have been
  implemented, and appear to be stable.

o Major overhaul to the setting of page traps and the handling of
  footnotes, both "normal" footnotes and footnotes that occur
  inside QUOTE, BLOCKQUOTE and EPIGRAPH.

o Addtion of font "styles" to om.tmac, plus changes to the FAMILY
  and FT macros to manage them.  New section in the doc appendices
  on adding fonts and managing the new font styles.

o Mom now uses a "fallback font" whenever there's an illegal call
  to FAMILY.

o RW and EW now affect only the font in effect.  A change of family
  or font disables them.

o BR_AT_LINE_KERN now properly does a .brp (spread and break) when
  used in justified text.

o NEWPAGE, which used to be an alias for .bp, has been moved into
  its own macro, in order to make it more responsive to some unusal
  situations.

o Some changes to elvis_syn.new, including that the file extensions
  recognized by elvis now include both .mom and .tmac.  This makes
  om.tmac much easier to read.

*Jul 6 2004

o FT and FAM(ILY) reworked to take advantage of if S, if F and
  \n[.sty] additions to groff (1.19.2).  Warnings are emitted if a
  style hasn't been registered, or if a font style doesn't exist in
  the current family.  Invalid .FAM(ILY) calls now use a "fallback"
  font" (although no warning is issued); fallback is user-settable

o New macro, FALLBACK_FONT.  Not only controls the fallback font
  for invalid family calls, but also controls whether mom aborts on
  invalid .FT calls after issuing a warning.

o RW/EW now affect only the current font (or font style)

o BR_AT_LINE_KERN now (properly) does a break-and-spread when text
  is justified.

o Fairly extensive list of .sty's added to om.tmac.  Hopefully,
  this will make life easier for users wishing to add new fonts
  and/or entire new families to their groff site-font/devps
  directory.

*Jun 6 2004

o Altered kerning slightly for footnote markers in text.  Daggers
  and double-daggers were getting a bit jammed 

*Fri Jun 4 2004

o Makefile.sub (HTMLDOCFILES, EXAMPLEFILES, PROCESSEDEXAMPLEFILES): Updated.

*Thu Jun 3 2004

o Rewrote the routines dealing with _FAMILY, _FONT, _SIZE, _COLOR
  and _QUAD.  A single macro for each checks for the calling alias
  (e.g. TITLE_FAMILY in _FAMILY), and performs the appropriate
  action.

o All "COLOUR" aliases of "COLOR", no matter where, have been
  removed.

o Added cover and doc cover page generation.

o Added reference macros COVERTITLE, DOC_COVERTITLE, MISC and
  COPYRIGHT (for use with covers only)

o Fixed EL and TN so they don't spring page traps; in nofill modes
  the preceding input line must be terminated by \c.

o Added #T_MARGIN_LEAD_ADJ to DO_B_MARGIN, DO_T_MARGIN and NEWPAGE
  to ensure accurate placement of first lines on new pages when
  docprocessing is not taking place.

o Made NEWPAGE it's own macro; formerly just an alias of .bp.

o Made BREAKQUOTE obsolete; rewrote sections of footnote handling,
  including adding support macros to deal with processing of
  footnotes that were started inside quotes, blockquotes and
  epigraphs.

o Added a TERMINATE .em to docprocessing (except letters) to ensure
  that deferred footnotes print on the last page of a doc.


*Mar 15 2004

o Added color support

o Adjusted vertical placement of hyphens around page numbering
  so that they are better centered on the height of the page
  number.

o Re-wrote portions of the document processing macros so that tabs
  behave in a consistent and intuitive manner.  Tab structures are
  now properly preserved from page to page and column to column.

*Feb 20 2004

o Rewrote the macros associated with DOCTYPE LETTER so that the
  user can enter DATE, TO and FROM in any order s/he likes.  For
  backward compatibility, if the older, fixed order (DATE-TO-FROM)
  is used, the date goes flush right with two linespaces after
  it, while the other fields go flush left with a single linespace
  separating them.

o Fixed handling of DOCHEADER OFF <distance> when <distance> fell
  short of the top margin of running text (the change is actually
  in the SHIM macro, which is called by DOCHEADER).

o Added a selection of iso 639 two-letter language codes as
  optional arguments to SMARTQUOTES, so that the use can enter
  her/his language code to get language specific quoting styles

o Changed the way the strings for \*[ST<n>], \*[ST<n>X], \*[FU<n>]
  and \*[BU<n>] are read.  Formerly, they were entered literally.
  Now they're entered as an array.

*Jan 24 2004

o Added lists and associated macros.  Mom now does (nested) lists.

o Added German-style lowered double quotes and two styles of
  guillemets to SMARTQUOTES.

o Added macro SIZE, intended to be called inline as \*[SIZE <n>].
  This is to bring mom's inline size change syntax into line with
  her other inlines.

o Added ESC_CHAR as an alias of .ec

o Added doc entries for lists.

o Updated SMARTQUOTES entry in docs.

o Updated reserved words in docs.

o Fixed a few more typos in docs.

*Tue Oct 21 2003

o Changed \n[#DRAFT] and \n[#REVISION] to strings \*[$DRAFT] and
  \*[$REVISION], allowing for the possibility of blank entries that
  don't mess up headers/footers with zeros if user doesn't want any
  numbers.

o Extended handling of draft and revision numbers and strings in
  headers/footers for increased flexibility.  It's possible now to
  have just about any combo of DRAFT_STRING, DRAFT, REVISION_STRING
  and REVISION, and have them come out in headers/footers as one
  intuitively expects/wants.

*Fri Jul 25 2003

o Added a .bp after .if \\n[#START]=1 in FOOTER.  Without it,
  in document processing mode, documents that use *none* of the
  docprocessing tags (yes, there are times when users want to do
  this) ignored the footer trap.

*Fri Jun 6 2003

o Changed register #DOCHEADER_LEAD_ADJ to string

*Wed May 21 2003

o DOC_TITLE changed to be used exclusively with DOCTYPE DEFAULT

o Fixed problem with restoration of previous doc pagenum
  style when endnotes use a different pagenum style (set with
  ENDNOTES_PAGENUM_STYLE)

o Fixed handling of headers/footers with respect to endnotes.  Now,
  when either headers or footers are on, mom picks up the correct
  page header/footer on the last page prior to ENDNOTES, gets the
  pageheaders correct for endnotes pages *including the last one*,
  and picks up correct page headers/footers for the subsequent docs
  after COLLATE

*Sat May 17 2003

o Added TOC (finally) and a nearly complete set of associated
  control macros

o Added new control macros to endnotes:

  ENDNOTES_STRING_CAPS       - capitalize the endnotes string
  ENDNOTES_NO_COLUMNS        - allows docs in columns and endnotes not
  ENDNOTES_PAGENUM_STYLE     - set page numbering style for endnotes
  ENDNOTES_FIRST_PAGENUMBER  - set first pagenumber for endnotes
  ENDNOTES_ALLOWS_HEADERS    - page headers on endnotes pages off or on
  ENDNOTES_NO_FIRST_PAGENUM  - allows non-printing first page number when page footers are being used instead of headers
  ENDNOTES_SINGLE_SPACE      - for TYPEWRITE, if doc double-spaced
  SUSPEND/RESTORE_PAGINATION - turns page numbering off for endnotes

o Added an ADJUST option to ENDNOTE_LEAD

o Added DOC_TITLE (like TITLE, but sets document-wide title for collated docs)

o Added HDRFTR_CENTER_PAD, to allow adjustments to placement of
  HDRFTR_CENTER_STRING

o Added BLANKPAGE macro, to output blank pages (silently numbered)

o Extensive changes to DEFAULTS, START, COLLATE, HEAD, SUBHEAD and
  PARAHEAD because of new TOC and extended flexibility of ENDNOTES
  page design

o Fixed DOCHEADER OFF (distance), FINIS

-----------------------------------------------------------------------

*Sat Feb 22 2003

o (Re)-fixed handling of post epigraph spacing after #START for
  TYPEWRITE double-spaced.

------------------------------------------------------------------------

*Sun Feb 16 2003

o Added James Ramsey's proposed CHAPTER_TITLE macro, along with his
  rewritten START macro and his utility macros to make START easier
  to read.

o Expanded handling of CHAPTER_TITLE to encompass TYPEWRITE, as well as
  plugging it into the docheaders.  Made CHAPTER_TITLE backwardly
  compatible so that pre-1.1.5 docs using CHAPTER_STRING to create a
  chapter title remain unaffected when groffed with 1.1.5.

o Created control macros for CHAPTER_TITLE FAMILY, FONT and SIZE.
  Added defaults for handling of CHAPTER title to DEFAULTS.  Documented
  CHAPTER_TITLE and everything that goes along with it.

o Fixed broken draft and revision in headers/footers.

o Fixed \*[RULE] so that it behaves properly with indents and justified
  copy.

o Fixed/tweaked handling of epigraph spacing in TYPEWRITE.

o Fixed broken spacing of docheaders in TYPEWRITE.

*Mon Feb 3 2003

o Fixed an oversight in CLOSING for DOCTYPE LETTER (closing wasn't
  being set flush left)

*Sun Sep 29 2002

o Changed .ne in .HEAD when PRINTSTYLE TYPESET from 5 to 4.  With 5,
  heads required at least 2 lines of text underneath or they'd be
  defered to the next page, which created too much whitespace at the
  end of the page.  Heads will now be processed on the same page if the
  head plus at least one line of text underneath fits.  I figure it's
  easier for the user to break to a new page manually if this behaviour
  is unsatisfactory than to massage the page to fix the excess
  whitespace.

*Sun Aug 25 2002

o Changed .IX to .IQ.  The older form still works, but emits a message
  advising the user to update to the newer.  (The macro in om.tmac
  still remains IX; IQ is an alias.)  Docs updated to reflect the
  change.

*Tue Aug 20 2002

o Added new (better) way to handle inline kerning.  \*[BU #] and
  \*[FU #] allow passing an argument to the inline string.  The older
  forms \*[BU#] and \*[FU#] still work, though.

o Changed handling of inline horizontal and vertical movements.
  Horizontal movements are now done with \*[BCK #<unit>] and
  \*[FWD #<unit>]; verticals with \*[UP #<unit>] and \*[DOWN #<unit>].
  The older forms \*[FP#] and \*[BP#] still work (horizontals), as do
  \*[ALD#] and \*[RLD#] (verticals).

------------------------------------------------------------------------

*Mon Aug 19 2002

o Fixed ENDNOTES so footnotes output properly when ENDNOTES is called

o Added ENDNOTES_HDRFTR_CENTER so that default no-print of header
  center string on endnotes page(s) when DOCTYPE is CHAPTER can
  be disabled (i.e. header center will be printed).

*Sat Aug 10 2002

o Added .nf to top of PAD, with a test beforehand for current fill
  mode.  If fill mode was on, it's restored after PAD completes
  processing.  Updated reserved.html to include number register
  #FILL_MODE.

*Fri Jul 12 2002

o More fixes to underlining.

*Fri Jul 5 2002

o Added capability of endnotes and pertinent control macros to om.tmac.

o Added document entries pertaining to endnote macros.

o Incorporated endnote macros into elvis_syntax.

o Small doc fixes.

o Tidied up indenting of om.tmac.

o Fixed handling of underlining of italics in PRINTSTYLE TYPEWRITE
  (there was a problem with footnotes getting underlined when they
  shouldn't have been).

o Removed ENDNOTES from TODO

o Fixed the character translations for UNDERLINE so they work properly
  with digraphs.

*Mon Jul 1 2002

o Expanded docprocessing.html entry "Special Note on Chapters".  Tidied
  up html a bit.

*Sat Jun 15 2002

o Small fix to PAD to make the use of inlines within the pad string
  more intuitive.

o Added \*[RULE] ( = \l'\n(.lu' ) so that full measure rules (either to
  full line length or within tabs) are easier to set.

*Sat Jun 8 2002

o Macro .PS renamed to .PT_SIZE.  Alias .TS removed.

o .tr bits in .CAPS rewritten in the form .tr é\[`E].

o General cleanup of docs to reflect changes

o Small changes/additions to elvis_syn

*Thu Jun 6 2002

o In DOCTYPE, in .if '\\$1'LETTER', added .FOOTER_RIGHT_SIZE +0.
  Without it, the suite page was printing at the default
  FOOTER_RIGHT_SIZE of -.5, which didn't look good.

*Wed Jun  5 2002

o Makefile.sub (TFLAG): Add `$(top_builddir)/tmac'.

*Tue Jun  4 2002

o Makefile.sub (groff_bin_dirs): Fix typo (forgotten `src' element).

*Mon Jun  3 2002

o Makefile.sub (uninstall_sub): Don't use `momdocdir' but `htmldocdir'.
  Add missing backslash.

*Sat Jun  1 2002

o Makefile.in (prepare_make_examples): Test for `penguin.ps', not
  `examples/penguin.ps'.

*Wed May 29 2002

o Rewrote portions of PAGENUM_STYLE and COPYSTYLE so that PAGENUM_STYLE
  behaves as advertised.

*Fri May 24 2002

o /Makefile.sub (momdocdir): Removed.
  (HTMLDOCFILES): Prepend `momdoc/'.
  (EXTRAEXAMPLEFILES): Removed.  Added entries to...
  (EXAMPLEFILES): This.
  (.SUFFIXES, .mom.ps): New.
  (prepare_make_examples): Updated.
  (examples/*.ps): Removed; .mom.ps will handle this.
  (install_data): Updated.  

*Thu May 23 2002

o Applied two small bug fixes to om.tmac (patches 1.1.1a and 1.1.1b).

o mom is now part of groff.

o Some renaming to avoid problems with 8+3 filesystems:

    examples/docprocessing_typeset.mom   -> examples/typeset.mom
    examples/docprocessing_typewrite.mom -> examples/typewrite.mom
    examples/typesetting_macros.mom      -> examples/macros.mom
    examples/penguin_small2_bw.ps        -> examples/penguin.ps

o Removed `INSTALL' and `README' since groff takes care of installation
  now.

o Added Makefile.sub.

o Added mom.tmac (which simply calls om.tmac).

o Added groff_mom.man for orthogonality; it simply points to the HTML
  documentation.

*Thu May 16 2002

o Added macro DRAFT_WITH_PAGENUMBER so user can have draft/revision
  info attached to the pagenumber in COPYSTYLE DRAFT, instead of having
  it HEADER center.  Always having it HEADER center was creating problems
  with long doc titles, esp. with PRINTSTYLE TYPEWRITE (which is when
  COPYSTYLE DRAFT is most likely to be used).  Now user has the choice,
  in these circumstances, either to reduce HEADER_SIZE, or to displace
  the draft/revision info.  Also rewrote portions of COPYSTYLE so that
  if no revision number is given in the reference macros, "Rev. #"
  doesn't appear when COPYSTYLE DRAFT.

*Fri May 10 2002

o Added capability of user-defined, single string recto/verso
  headers/footers.

o Added new entries to docs about the above.  Made some additional
  small changes to toc.html, rectoverso.html, and headfootpage.html
  to supplement the new entries.

o Small fix to handling of footer separator rule -- was 1 point too low
  owing to fuzziness of #CAP_HEIGHT as returned by SIZESPECS.

o Added some more useful stuff to elvis_syntax.

*Sun May 05 2002

o Fix to DEFAULTS so that L_MARGIN and R_MARGIN are reprocessed if
  DOCTYPE LETTER.  R_MARGIN, as set by DOCTYPE LETTER had no preceding
  PAGEWIDTH or PAPER from which to get #PAGE_WIDTH for figuring out
  line length.

o Additional fix to DEFAULTS in handling DOCTYPE LETTER so that if user
  sets line length prior to START, no reprocessing of R_MARGIN occurs.
  This necessitated adding a new number register: #USER_SET_L_LENGTH

*Sat May 04 23:48:05 EDT 2002

o Added .cflags 4 /\(en -- was driving me nuts that lines wouldn't
  break after these characters; I'm assuming others feel the same way

* Fri May 03 2002

o Made some small fixes to space handling around quotes, mostly to do
  with quotes immediately after START and quotes after (sub)heads.

* Wed May 01 2002

o Fixed a small bug that was causing the first .PP after START to begin
  at the top margin of the page regardless of any type that preceded
  .PP when docheaders were off.

o Fixed HEADER so that when HEADERS are off the first line of type on
  pages after the first falls properly at the top margin

*Sat Apr 27 2002

o Renamed docprocessing_macros.mom in /examples to
  docprocessing_typeset.mom.  Added docprocessing_typewrite.mom, as
  well as a README file.

o Fixed UNDERLINE_QUOTES (for PRINTSTYLE TYPEWRITE) so they really are
  on by default as the docs say.

o Changes to doc entry on COLLATE:

    - removed bit about using COLLATE after a cover page (I wrote the
      entry *before* I wrote the macro!).  Cover pages should be
      followed by NEWPAGE, not COLLATE.

    - added caution about mixing PRINTSTYLEs

    - added caution about using DOC_FAMILY to change family of all
      document elements after COLLATE

o Made HEADER_SIZE (and, by extension, FOOTER_SIZE) available to
  PRINTSTYLE TYPEWRITE.  Changed appropriate doc entries to reflect
  this.

*Wed Apr 24 2002

o Small change to DO_QUOTE to correct a problem with quotes and
  blockquotes that fall in the middle of paragraphs (i.e. text after
  the quote is not a new para).  Basically, added a bit that stores the
  current para indent, sets para indent to 0, invokes a PP, then
  restores the original para indent.

o Added new macro, BREAK_QUOTE, to deal with the problem of
  footnotes in quotes and blockquotes that cross pages or columns.

  Quotes and blockquotes are read into diversions, which means they
  get their footnote information from the page/column on which they
  were started.  If a footnoted quote crosses a page/column, what
  sometimes happens is that the footnote itself is output at the
  bottom of page/column where the quote started, whereas the text
  marker for the footnote appears on the next page/column where the
  quote ends.  Furthermore, the text marker is the one appropriate
  to the previous page.  BREAK_QUOTE is a workaround.

o Added directory /examples to archive.

o Added typesetting_macros.mom, docprocessing_macros.mom, elvis_syntax
  and penguin_small2_bw.ps to /examples.

o Added BREAK_QUOTE to docs, made some additions to reserved words
  list, and corrected a few little doc errors.

*Mon Apr 22 2002

o Added default .L_MARGIN 1i and .R_MARGIN 1i to PAPER, PAGE, and
  PAGEWIDTH.  L_MARGIN is essential otherwise left indents and tabs
  don't have a register #L_MARGIN to work with.  The default right
  margin is a convenience only.  Updated the doc entries for L_MARGIN
  and R_MARGIN to reflect the change.

*Sun Apr 21 2002

o Changes to COLLATE:

    - added some "resets" (LL, LS, QUAD)
    - added a check for whether pagination is at page top (either
      because FOOTERS are on or because PAGENUM_POS was user set).
      If pagination is on, and PAGENUM_POS is TOP, it's turned off
      for next page (start of next collated document) and restored
      for subsequent pages unless PAGENUM_ON_FIRST_PAGE is on, in
      which case the page number appears at page top.

o The macro TRAPS is always invoked at the end of DEFAULTS (which is
  called by START).  Formerly, TRAPS was only invoked at the start
  of a doc, not after COLLATE.  Now runs after COLLATE as well.

o Distance from $DOC_TYPE in DOCTYPE NAMED "<string>" to start of
  running text was one linespace too deep.  Fixed (in START).

o When 1st arg to PAGENUM_POS was user set to TOP, running text was
  printing 1 linespace too high, even when PAGINATION was OFF.  Same
  problem when HEADERS were OFF (i.e. nothing in the header margin at
  all).  Fixed by removing -\\n[#DOC_LEAD]u from all .sp |\\n[#T_MARGIN]u
  calls of .el portion after .ie \\n[#HEADERS_ON].

o Added new macro: PAGENUM_ON_FIRST_PAGE.  Normally, when FOOTERS are
  being used instead of HEADERS, mom doesn't print the page number at
  the top of the first page of a doc, or the first page of collated
  docs.  New macro allows user to get mom to put the page number on
  "first" pages if that's desired.  Updated docs to include the macro.

o More little fixes to docs.

*Thu Apr 18 2002

o Fixed TI (temporary indent) so that it continues to work as expected,
  even when called while another type of indent is in effect.

*Tue Apr 16 2002

o String tabs weren't working as advertised when set from within
  a tab.  Fixed.  Two new registers added: #ST_OFFSET and #IN_TAB.
  String tabs now behave poperly and intuitively when set within tabs.

o Added a note to docs about surrounding \w'...' escape with double-
  quotes when it's used as an argument to macros

o Added a note to docs that SILENT does not deposit a .br

*Mon Apr 15  2002

o Added new macro BR_AT_LINE_KERN if user wants mom to deposit .br's
  before .RW and/or .EW.

o Added 1/4 points to inline escapes \*[ALD] and \*[RLD].

o Added 1/4 points to inline escapes \*[FP] and \*[BP]

o Updated docs to reflect the above changes.

*Fri Apr 12 2002

o Fixed .RW and .EW which weren't working because of a missing \ in
  \\n(.f register.  Also made it so that .RW and .EW affect all fonts
  in positions 1, 2, 3, and 4 at once, hence line kerning now affects
  all fonts that appear after it, not just the font that was current at
  the time of the macros' invocation.

o .SS and .WS now working properly.  .WS no longer has any effect on
  .SS, which remains constant regardless of .WS.  Furthermore, .SS no
  longer gets its value by adding \*[$SS_VAR] + \n[.ss].  Instead,
  it remains constant.  Don't know what I was thinking when I wrote
  the routine in the first place.

o Updated and rewrote doc entry pertaining to SS

*Wed Apr 10 2002

o Renamed tmac.om to om.tmac to bring macro file's name into line
  with current groff policy

o Added more standard paper sizes to PAPER.

o Fixed T_MARGIN, LS, and AUTOLEAD so that if T_MARGIN is set before LS
  or AUTOLEAD at the top of a file, the first line of type falls
  properly on the baseline set by T_MARGIN.  Previously, LS and
  AUTOLEAD automatically advanced by the value passed to them before
  setting the first line of type, meaning that the first line of type
  fell at T_MARGINu+1v instead of T_MARGIN.

o Updated docs to reflect changes.

o Removed #TEST_FOR_NUMERIC from list of reserved words.

o Added "t" and #T_MARGIN_SET to list of reserved words.

*Sat Apr 6 2002

o Added FACTOR arg to AUTOLEAD, so if user wants autolead to be a factor
  of point size, instead of being the sum of pointsize + autolead, s/he
  has the choice.  Incorporated appropriate changes to PS and LS.

o Added new register #AUTOLEAD_FACTOR to reserved words.  Modified
  comments for AUTOLEAD, PS, and LS to reflect changes.  Also
  corrected an error where #AUTOLEAD_VALUE had mistakenly been written
  $AUTOLEAD_VALUE in comments in the macro file, and removed erroneous
  | <anything>.  Updated AUTOLEAD entry in momdoc/typesetting.html
  to reflect the changes.

*Wed Apr 3 2002

o Cleaned up html errors in the docs.

o Added "Next," "Prev" and "Top" links to top and bottom of doc files.

o Fixed some typos in the docs.