Annotation of embedaddon/bird2/doc/sbase/dist/birddoc/groff/mapping, revision 1.1
1.1 ! misho 1: % linuxdoc replacement file
! 2: % translates into nroff, using ms macros
! 3: % manpages can be processed using the man macros
! 4: % does not use neqn for math.
! 5:
! 6: % Based on qwertz replacement file by Tom Gordon
! 7: % linuxdoc mods by mdw
! 8:
! 9: % Groff dependencies are few. To port to another roff:
! 10: % 1. Check and modify, if necessary, font changes. (e.g. In psroff the
! 11: % same fonts have other names.)
! 12: % 2. Check the code for including Encapsulated PostScript, generated
! 13: % for eps elements.
! 14: % 3. Also make versions of general.grops and math.grops, which are sed
! 15: % scripts translating character entities into groff character references.
! 16:
! 17:
! 18: <birddoc> + ".nr PS 11\n"
! 19:
! 20: % Hacked by mdw
! 21: ".nr PI 3n\n"
! 22: ".ds CF \\\\n\%\n"
! 23: ".ds CH \\&\n"
! 24: ".ds dR $\n" % dollar, to avoid EQN conflicts
! 25:
! 26: % Start with no TOC
! 27: ".ds printtoc\n"
! 28:
! 29: % Footnote style
! 30: ".nr FF 1\n"
! 31:
! 32: % James Clark's trick to prevent unintended paragraph
! 33: % breaks
! 34:
! 35: ".tr \\&\n"
! 36:
! 37: % horizontal line
! 38: ".de hl\n"
! 39: ".br\n"
! 40: "\\l'\\\\n(.lu-\\\\n(.iu'\n"
! 41: "..\n"
! 42:
! 43: % paragraph spacing
! 44: ".if n .nr PD 1v\n"
! 45:
! 46: % margins added by mdw
! 47: ".nr PO 0.25i\n"
! 48: ".po 0.25i\n"
! 49: ".nr LL 7.0i\n"
! 50: ".nr TL 7.0i\n"
! 51: ".nr HM 0i\n"
! 52: ".nr FM 0i\n"
! 53:
! 54: % Turn off right-margin filling
! 55: ".na\n"
! 56:
! 57: % h is 1 if first paragraph after heading
! 58:
! 59: ".nr h 0\n"
! 60:
! 61: % initialize heading level
! 62:
! 63: ".nr il 1\n"
! 64:
! 65: % Number registers for list
! 66:
! 67: ".nr bi 0\n" % initialize begin items
! 68: ".nr ll 0\n" % list level, stores current level
! 69: ".nr el 0\n" % current enumeration level
! 70:
! 71: % Not all list levels are enumerations, as
! 72: % itemizations can be embedded within enumerations
! 73: % and vice versa
! 74:
! 75: % type of list level is in \n(t\n(ll, where
! 76: % 0 : itemize, 1 : enumerate, 2: description
! 77:
! 78: % enumerator for an enumeration level is in
! 79: % \n(e\n(el -- i.e. \n(e1=2 means current item of
! 80: % enumeration level 1 is 2
! 81:
! 82: % context-sensitive paragraph macro
! 83:
! 84: % Bug: There's some problem using this to re-start paragraphs after the
! 85: % </verb> and </code>, so after verb and code I insert .LP. That's fine
! 86: % except that is loses indentation when using verb or code inside of a list.
! 87:
! 88: ".de Pp\n"
! 89: ".ie \\\\n(ll>0 \\{\\\n" % within list?
! 90: ".ie \\\\n(bi=1 \\{\\\n" % first par element of item?
! 91: ".nr bi 0\n" % reset bi flag
! 92: % if itemization, mark with a bullet
! 93: ".if \\\\n(t\\\\n(ll=0 \\{.IP \\\\(bu\\}\n" % itemize
! 94: % if enumeration: increment and print enumerator
! 95: % for this enumeration level
! 96: ".if \\\\n(t\\\\n(ll=1 \\{.IP \\\\n+(e\\\\n(el.\\}\n"
! 97: % if first par element of descrip, do nothing
! 98: ".\\}\n"
! 99: ".el .sp \n" % subsequent par element of item
! 100: ".\\}\n"
! 101: ".el \\{\\\n" % not within list
! 102: ".ie \\\\nh=1 \\{\\\n" % first par after heading
! 103: ".LP\n"
! 104: ".nr h 0\n" % reset h flag
! 105: ".\\}\n"
! 106: ".el .LP \n" % Changed from .PP, mdw
! 107: ".\\}\n"
! 108: ".nh\n"
! 109: "..\n"
! 110:
! 111:
! 112:
! 113: % for each level, a number register is created
! 114: % to store its type and current item number, where
! 115: % -1=bullet of an itemized list.
! 116:
! 117: % Format of list level enumerators
! 118:
! 119: ".ds f1 1\n"
! 120: ".ds f2 a\n"
! 121: ".ds f3 i\n"
! 122: ".ds f4 A\n"
! 123:
! 124: % Number registers for theorems
! 125: ".nr def 0\n"
! 126: ".nr prop 0\n"
! 127: ".nr lemma 0\n"
! 128: ".nr coroll 0\n"
! 129: ".nr proof 0\n"
! 130: ".nr theorem 0\n"
! 131:
! 132: % Reference commands
! 133:
! 134: % redefine superscript strings so that refer tags look like [this]
! 135:
! 136: ".ds \[. \[\n"
! 137: ".ds .\] \]\n"
! 138:
! 139: </birddoc>
! 140:
! 141: % set initial level of headings, in register il
! 142:
! 143: <article> + ".nr il 0" +
! 144: </article> + ".if '\\*[printtoc]'true' .PX\n"
! 145:
! 146: <report> + ".nr il 1" +
! 147: </report> + ".bp\n"
! 148: ".rm LH\n.rm RH\n"
! 149: ".TC" +
! 150:
! 151: <book> + ".nr il 1" +
! 152: </book> + ".rm LH\n.rm RH\n"
! 153: ".bp\n"
! 154: ".TC" +
! 155:
! 156: <notes>
! 157: </notes>
! 158:
! 159: <manpage> + ".nr il -1" +
! 160: </manpage>
! 161:
! 162: <progdoc>
! 163: </progdoc>
! 164:
! 165: % Hacked up titlepag stuff to look more reasonable. Titles and author
! 166: % names are now stored in strings, printed by the end of </titlepag>.
! 167: % Wake up! This uses groff-like long string names. You must use groff
! 168: % to format this.
! 169:
! 170: <titlepag> + ".ds mdwtitle\n"
! 171: ".ds mdwsubtitle\n"
! 172: ".ds mdwdate\n"
! 173: ".de printabstract\n"
! 174: "..\n" +
! 175: </titlepag> + "\\*[mdwtitle]\n"
! 176: ".br\n"
! 177: ".if !'\\*[mdwsubtitle]'' \\*[mdwsubtitle]\n"
! 178: ".br\n"
! 179: ".printauthor\n"
! 180: ".br\n"
! 181: "\\*[mdwdate]\n"
! 182: ".br\n"
! 183: ".printabstract\n"
! 184: ".br\n"
! 185:
! 186: %<title> + ".TL" +
! 187: %</title>
! 188:
! 189: <title> + ".ds mdwtitle "
! 190: </title> +
! 191:
! 192: %<subtitle> + ".br\n"
! 193: % ".ft R\n"
! 194: % ".SM" +
! 195: %</subtitle> + ".LG" +
! 196:
! 197: <subtitle> + ".ds mdwsubtitle "
! 198: </subtitle> +
! 199:
! 200: <date> + ".ds mdwdate "
! 201: </date> +
! 202:
! 203: <abstract> + ".de printabstract\n"
! 204: ".LP\n"
! 205: </abstract> + ".." +
! 206:
! 207: % author needs to be set up as its own macro, fired off from .printtitle.
! 208:
! 209: <author> + ".de printauthor" +
! 210: </author> + ".." +
! 211:
! 212: %<name> + ".AU" +
! 213: %</name>
! 214:
! 215: <name> + ".br" +
! 216: </name>
! 217:
! 218: <and>
! 219: </and>
! 220:
! 221: <thanks> "\\**\n"
! 222: ".FS" +
! 223: </thanks> + ".FE" +
! 224:
! 225: <inst> + ".br" +
! 226: </inst>
! 227:
! 228: %<newline> + ".br" +
! 229: <newline> + ".br"
! 230: </newline>
! 231:
! 232: <label>
! 233: </label>
! 234:
! 235: <header>
! 236: </header>
! 237:
! 238: <lhead> + ".EH '"
! 239: </lhead> "'''" +
! 240:
! 241: <rhead> + ".OH '''"
! 242: </rhead> "'" +
! 243:
! 244: <comment> + "(*" +
! 245: </comment> + "*)" +
! 246:
! 247: % New abstract given above --mdw
! 248: %<abstract> + ".AB" +
! 249: %</abstract> + ".AE" +
! 250:
! 251: <appendix> + ".af H1 A" +
! 252: </appendix>
! 253:
! 254: % limitation: no list of figures or tables. A table of contents
! 255: % is always generated for books and reports. Thus these next three tags
! 256: % are no-ops
! 257:
! 258: % For now, no table-of-contents in ASCII output. (Uncomment this if
! 259: % desired).
! 260: %<toc> + ".ds printtoc true"
! 261: %</toc>
! 262:
! 263: <toc>
! 264: </toc>
! 265:
! 266: <lof>
! 267: </lof>
! 268:
! 269: <lot>
! 270: </lot>
! 271:
! 272: <chapt> + ".bp\n"
! 273: ".NH \\n(il " +
! 274: </chapt>
! 275:
! 276: <sect> + ".NH 1+\\n(il" +
! 277: </sect>
! 278:
! 279: <sect1> + ".NH 2+\\n(il" +
! 280: </sect1>
! 281:
! 282: <sect2> + ".NH 3+\\n(il" +
! 283: </sect2>
! 284:
! 285: <sect3> + ".NH 4+\\n(il" +
! 286: </sect3>
! 287:
! 288: <sect4> + ".NH 5+\\n(il" +
! 289: </sect4>
! 290:
! 291: <heading> ".ds h "
! 292: </heading> + "\\*h\n"
! 293: ".XS \\n%\n"
! 294: "\\*(SN \\*h\n"
! 295: ".XE\n"
! 296: ".nr h 1\n" % set heading flag to true
! 297:
! 298: <p> + ".Pp" +
! 299: </p>
! 300:
! 301: <itemize> + ".nr ll +1\n" % increment list level
! 302: ".nr t\\n(ll 0\n" % set type of level to itemize
! 303: </itemize> + ".nr ll -1\n" % decrement list level
! 304:
! 305: <enum> + ".nr ll +1\n" % increment list level
! 306: ".nr el +1\n" % increment enumeration level
! 307: ".nr t\\n(ll 1\n" % set type of level to enum
! 308: ".nr e\\n(el 0 1\n" % initialize enumerator
! 309: ".af e\\n(el \\*(f\\n(el\n" % style of enumerator
! 310: ".if \\n(ll>1 .RS" +
! 311: </enum> + ".if \\n(ll>1 .RE\n"
! 312: ".br\n"
! 313: ".nr el -1\n" % decrement enumeration level
! 314: ".nr ll -1\n" % decrement list level
! 315:
! 316: <descrip> + ".RS\n"
! 317: ".nr ll +1\n" % increment list level
! 318: ".nr t\\n(ll 2\n" % set type of level to descrip
! 319: </descrip> + ".nr ll -1\n" % decrement list level
! 320: ".RE" +
! 321:
! 322: % number register bi means "begin item". Used in the .P macro to print
! 323: % bullets or numbers at beginning of first paragraph of an item.
! 324: % If bi=1 then the paragraph is the first one of the item.
! 325:
! 326: <item> + ".nr bi 1\n.Pp" +
! 327: </item>
! 328:
! 329: <tag> + ".IP \"\\fB"
! 330: </tag> "\\fR\"\n"
! 331: ".nr bi 1" +
! 332:
! 333: <m> ""
! 334: </m> ""
! 335:
! 336: <cf> ""
! 337: </cf> ""
! 338:
! 339: <cite> + ".\[\n[ID]\n.\]" +
! 340: </cite>
! 341:
! 342: <ncite> + ".\[\n[ID]\n.\]\n([NOTE])"
! 343: </ncite>
! 344:
! 345: <footnote> " (-- "
! 346: </footnote> "--)" +
! 347:
! 348: <sq> "\\*Q"
! 349: </sq> "\\*U"
! 350:
! 351: <lq> + ".RS\n"
! 352: ".nr LL \\n(LL-\\n(PI" +
! 353: </lq> + ".nr LL \\n(LL+\\n(PI\n"
! 354: ".RE" +
! 355:
! 356: <em> "\\fI"
! 357: </em> "\\fP"
! 358:
! 359: <bf> "\\fB"
! 360: </bf> "\\fR"
! 361:
! 362: <it> "\\fI"
! 363: </it> "\\fR"
! 364:
! 365: <sf> "\\fR"
! 366: </sf> "\\fR"
! 367:
! 368: <sl> "\\fI"
! 369: </sl> "\\fR"
! 370:
! 371: % Changed by mdw
! 372: <tt> "\\fC"
! 373: </tt> "\\fR"
! 374:
! 375: % Added by mdw
! 376: <cparam> "\\fI<"
! 377: </cparam> ">\\fR"
! 378:
! 379: <url> "[NAME] <\\fC[URL]\\fR>"
! 380: </url>
! 381:
! 382: <htmlurl> "[NAME]"
! 383: </htmlurl>
! 384:
! 385: <ref> "``[NAME]''"
! 386: </ref>
! 387:
! 388: <nidx> + "\\#"
! 389: </nidx> "\\n"
! 390:
! 391: <ncdx> + "\\#"
! 392: </ncdx> "\\n"
! 393:
! 394: <pageref> "??"
! 395: </pageref>
! 396:
! 397: <x>
! 398: </x>
! 399:
! 400: <mc>
! 401: </mc>
! 402:
! 403: <biblio> + ".\[\n"
! 404: "$LIST$\n"
! 405: ".\]" +
! 406: </biblio>
! 407:
! 408: <code> + ".DS L\n"
! 409: ".hl\n"
! 410: ".ft R\n" +
! 411:
! 412: </code> + ".hl\n"
! 413: ".DE\n"
! 414: ".ft P\n"
! 415: % ".Pp" + % continue previous paragraph (changed mdw)
! 416: ".LP"
! 417:
! 418: <verb> + ".DS L\n"
! 419: ".ft R\n" +
! 420:
! 421: </verb> + ".DE\n"
! 422: ".ft P\n"
! 423: % ".Pp" + % continue previous paragraph (changed mdw)
! 424: ".LP"
! 425:
! 426: % tscreen added by mdw
! 427: <tscreen> + ".br\n"
! 428: ".po 0.75i\n"
! 429: ".ll 6.0i\n"
! 430: ".ft C\n"
! 431: ".LP\n" % Used to be Pp
! 432: </tscreen> + ".br\n"
! 433: ".po 0.25i\n"
! 434: ".ll 7.0i\n"
! 435: ".ft R\n" % This might not be correct
! 436: ".LP\n" % Used to be Pp
! 437:
! 438: <quote> + ".br\n"
! 439: ".po 0.75i\n"
! 440: ".ll 6.0i\n"
! 441: ".nr LL 6.0i\n"
! 442: ".LP\n" % Used to be Pp
! 443: </quote> + ".br\n"
! 444: ".po 0.25i\n"
! 445: ".ll 7.0i\n"
! 446: ".nr LL 7.0i\n"
! 447: ".LP\n" % Used to be Pp
! 448:
! 449:
! 450:
! 451:
! 452: % theorems and such
! 453:
! 454: <def> + ".sp\n"
! 455: ".nr def \\n\[def\]+1\n"
! 456: ".B \"Definition \\n\[def\] \"" +
! 457: </def> + ".ft P\n.sp" +
! 458:
! 459: <prop> + ".sp\n"
! 460: ".nr prop \\n\[prop\]+1\n"
! 461: ".B \"Proposition \\n\[prop\] \"" +
! 462: </prop> + ".ft P\n.sp" +
! 463:
! 464:
! 465: <lemma> + ".sp\n"
! 466: ".nr lemma \\n\[lemma\]+1\n"
! 467: ".B \"Lemma \\n\[lemma\] \"" +
! 468: </lemma> + ".ft P\n.sp" +
! 469:
! 470: <coroll> + ".sp\n"
! 471: ".nr coroll \\n\[coroll\]+1\n"
! 472: ".B \"Corolloary \\n\[coroll\] \"" +
! 473: </coroll> + ".ft P\n.sp" +
! 474:
! 475: <proof> + ".sp\n"
! 476: ".nr proof \\n\[proof\]+1\n"
! 477: ".B \"Proof \\n\[proof\] \"" +
! 478: </proof> + ".ft P\n.sp" +
! 479:
! 480: <theorem> + ".sp\n"
! 481: ".nr theorem \\n\[theorem\]+1\n"
! 482: ".B \"Theorem \\n\[theorem\] \"" +
! 483: </theorem> + ".ft P\n.sp" +
! 484:
! 485: <thtag> + ".B\n("
! 486: </thtag> ")\n.I" +
! 487:
! 488: % mathematics -- this nroff version needs work.
! 489:
! 490: <f>
! 491: </f>
! 492:
! 493: <dm> + ".DS L" +
! 494: </dm> + ".DE" +
! 495:
! 496: <eq> + ".DS L" +
! 497: </eq> + ".DE" +
! 498:
! 499: <fr>
! 500: </fr>
! 501:
! 502: <nu> "{"
! 503: </nu> "} over "
! 504:
! 505: <de> "{"
! 506: </de> "}"
! 507:
! 508: <lim>
! 509: </lim>
! 510:
! 511: <op>
! 512: </op>
! 513:
! 514: <ll> " from {"
! 515: </ll> "}"
! 516:
! 517: <ul> " to {"
! 518: </ul> "}"
! 519:
! 520: <opd>
! 521: </opd>
! 522:
! 523: <pr> " prod "
! 524: </pr>
! 525:
! 526: <in> " int "
! 527: </in>
! 528:
! 529: <sum> " sum "
! 530: </sum>
! 531:
! 532: % limitation: eqn only does square roots!
! 533:
! 534: <root> " sqrt {"
! 535: </root> "}"
! 536:
! 537: <ar> + ".TS\n"
! 538: "center, tab(|) ;\n"
! 539: "[ca]." +
! 540: </ar> + ".TE" +
! 541:
! 542: <arr> "\n"
! 543: </arr>
! 544:
! 545: <arc> "|"
! 546: </arc>
! 547:
! 548:
! 549: <sup> " sup {"
! 550: </sup> "}"
! 551:
! 552: <inf> " sub {"
! 553: </inf> "}"
! 554:
! 555:
! 556: <unl> "{"
! 557: </unl> "} under "
! 558:
! 559: <ovl> "{"
! 560: </ovl> "} bar "
! 561:
! 562: <rf> " bold{"
! 563: </rf> "}"
! 564:
! 565: <v> "{"
! 566: </v> "} vec "
! 567:
! 568: % limitation: no calligraphic characters, using helvetica italics instead. Is there a better font?
! 569:
! 570: <fi> "\\fI"
! 571: </fi> "\\fP"
! 572:
! 573: <phr> " roman }"
! 574: </phr> "}"
! 575:
! 576:
! 577: <tu> + ".br" +
! 578: </tu>
! 579:
! 580: % figures
! 581:
! 582: <figure> % + ".KF" +
! 583: </figure> % + ".KE" +
! 584:
! 585: <eps> + ".if t .PSPIC [file].ps\n"
! 586: ".if n .sp 4" +
! 587: </eps>
! 588:
! 589: % Are TeX units properly handled by this translation of ph?
! 590:
! 591: <ph> + ".sp [VSPACE]" +
! 592: </ph>
! 593:
! 594: <caption> + ".sp\n.ce" +
! 595: </caption>
! 596:
! 597: % tables
! 598:
! 599: <table> + ".KF\n.R" +
! 600: </table> + ".KE" +
! 601:
! 602: <tabular> + ".TS\n"
! 603: "center, tab(|) ; \n"
! 604: "[ca]." +
! 605: </tabular> + ".TE" +
! 606:
! 607: <rowsep> "\n" +
! 608: </rowsep>
! 609:
! 610: <colsep> "|"
! 611: </colsep>
! 612:
! 613: %<hline> + "_" +
! 614: % gregh
! 615: <hline> + ".hl\n" +
! 616:
! 617: </hline>
! 618:
! 619: <slides> + ".nr PS 18" +
! 620: </slides>
! 621:
! 622: <slide>
! 623: </slide> + ".bp\n\\&" +
! 624:
! 625: % letters -- replacement for email, using mh format.
! 626:
! 627: <letter> + ".nf" +
! 628: </letter> +
! 629:
! 630: <from> + "From: "
! 631: <to> + "To: "
! 632:
! 633: <address> + ".de Ad\n"
! 634: </address> + ".." +
! 635:
! 636: <email> " <"
! 637: </email> ">"
! 638:
! 639: <subject> + "Subject: "
! 640:
! 641: <sref> + "Sref: "
! 642: <rref> + "In-Reply-To: "
! 643:
! 644: <cc> + "cc: "
! 645:
! 646: <opening> + ".fi\n.LP" +
! 647:
! 648: <closing> + ".LP" +
! 649:
! 650: <encl> + ".XP\n"
! 651: "encl: "
! 652:
! 653: <ps> + ".LP\np.s."
! 654:
! 655:
! 656: % end of roff replacement file
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>