X-Git-Url: https://git.cameronkatri.com/mandoc.git/blobdiff_plain/330def09deee27bc7f1f70f0870aebf0eeddd62c..c397b35429cecadd0788107f6fd8770d11dcd696:/index.sgml diff --git a/index.sgml b/index.sgml index f652fbb4..cb489104 100644 --- a/index.sgml +++ b/index.sgml @@ -2,383 +2,383 @@ - mdocml | mdoc macro compiler - - - - - - - - - - - - - - - - - - - - - - - - - -
-
- mdocml – mdoc macro compiler -
- -
-

- DESCRIPTION -

+

+ mdocml – mdoc macro compiler +

-

- mdocml is a suite of tools compiling -mdoc, the roff macro package - of choice for BSD manual pages, and -man, the predominant historical package for UNIX - manuals. The mission of mdocml is to deprecate groff, the GNU roff implementation, for - displaying -mdoc pages whilst providing token support for -man. -

+

+ Description +

-

- Why? groff amounts to over 5 MB of source code, most of which is C++ and all of which is GPL. It runs - slowly, produces uncertain output, and varies in operation from system to system. mdocml strives to fix - this (respectively small, C, ISC-licensed, fast and regular). -

+

+ mdocml is a suite of tools compiling mdoc, the roff macro + package of choice for BSD manual pages, and man, the predominant historical package for + UNIX manuals. The mission of mdocml is to deprecate groff, the GNU troff implementation, for displaying mdoc + pages whilst providing token support for man. +

-

- The core of mdocml is composed of the libmdoc, libman, and libroff validating compiler libraries. All - are simple, fast libraries operating on memory buffers, so they may be used for a variety of front-ends - (terminal-based, CGI and so on). The front-end is mandoc, which formats - manuals for display. -

+

+ Why? groff amounts to over 5 MB of source code, most of which is C++ and all of which is GPL. It runs slowly, produces + uncertain output, and varies in operation from system to system. mdocml strives to fix this (respectively small, C, ISC-licensed, fast and regular). +

-

- The mdocml suite is a BSD.lv - Project member. -

-
-

- SOURCES -

+

+ mdocml consists of the libmandoc validating compiler and mandoc, which interfaces with the compiler library to format output for UNIX terminals, XHTML, + HTML, PostScript, and PDF. It is a BSD.lv project. +

-

- Sources correctly build and install on DragonFly BSD, FreeBSD, OpenBSD, NetBSD, GNU/Linux, and many - other operating systems, tested variously on i386, AMD64, alpha, and others. The most current version - is @VERSION@, dated @VDATE@. A full ChangeLog (txt) is written with each release. -

+

+ Disambiguation: mdocml is often referred to by its installed binary, mandoc. +

-

- Current -

+

+ Sources +

- - - - - - - - - - - - - -
Source archive - /snapshots/mdocml.tar.gz - (md5) -
Online source - cvsweb -
+

+ mdocml is in plain-old ANSI C and should build and run on any UNIX system, although makewhatis requires Berkeley Database (this is + installed by default on all BSD operating systems). The most current version is @VERSION@, + dated @VDATE@. If your system doesn't come with mdocml (see + Downstream), run make to compile and make install to install into /usr/local. + Note that makewhatis is not yet linked to the build. You must run make + makewhatis to build it (it does not install). +

-

- Downstream -

+

+ Current +

- - - - - - - - - - - - - - - - - - - - - -
DragonFly BSD - usr.bin/mandoc -
FreeBSD - ports/textproc/mdocml -
NetBSD - src/external/bsd/mdocml -
OpenBSD - src/usr.bin/mandoc -
+ + + + + + + + + + + + + +
Source archive + /snapshots/mdocml.tar.gz + (md5) +
Online source + cvsweb +
-

- Historical -

+

+ Downstream +

- - - - - - - - - -
Source archive - /snapshots/ -
-
-

- DOCUMENTATION -

+ + + + + + + + + + + + + + + + + + + + + +
DragonFly BSD + usr.bin/mandoc +
FreeBSD + ports/textproc/mdocml +
NetBSD + src/external/bsd/mdocml +
OpenBSD + src/usr.bin/mandoc +
-

- These manuals are generated automatically and refer to the current snapshot. -

+

+ Historical +

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
man(3) (text)man macro compiler library
man(7) (text)man language reference
mandoc(1) (text)format and display UNIX manuals
mandoc_char(7) (text)mandoc special characters
mdoc(3) (text)mdoc macro compiler library
mdoc(7) (text)mdoc language reference
roff(3) (text)roff macro compiler library
roff(7) (text)roff-mandoc language reference
+ + + + + + + + + +
Source archive + /snapshots/ +
-

- See Writing UNIX Manual Pages for a general - introduction to manpages and mdoc. -

-

- CONTACT -

+

+ Documentation +

-

- For all issues related to mdocml, contact Kristaps Dzonsons, kris...@bsd.lv. -

+

+ These manuals are generated automatically and refer to the current snapshot. +

-

- You may also subscribe to several mailing lists (these require subscription, which is moderated). An - archive is not yet available on-line, although you may request one once subscribed. -

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
mandoc(1) + format and display UNIX manuals + + (text | + xhtml | + pdf | + postscript) + +
makewhatis(1) + index UNIX manuals + + (text | + xhtml | + pdf | + postscript) + +
preconv(1) + recode multibyte UNIX manuals + + (text | + xhtml | + pdf | + postscript) + +
mandoc(3) + mandoc macro compiler library + + (text | + xhtml | + pdf | + postscript) + +
man(7) + man language reference + + (text | + xhtml | + pdf | + postscript) + +
eqn(7) + eqn-mandoc language reference + + (text | + xhtml | + pdf | + postscript) + +
mandoc_char(7) + mandoc special characters + + (text | + xhtml | + pdf | + postscript) + +
mdoc(7) + mdoc language reference + + (text | + xhtml | + pdf | + postscript) + +
roff(7) + roff-mandoc language reference + + (text | + xhtml | + pdf | + postscript) + +
tbl(7) + tbl-mandoc language reference + + (text | + xhtml | + pdf | + postscript) + +
- - - - - - - - - - - - - - - - - -
- disc...@mdocml.bsd.lv - high-level discussions and version announcements
- tec...@mdocml.bsd.lv - low-level discussions
- sou...@mdocml.bsd.lv - source commit messages
-
-

- NEWS -

-
-

- 07-06-2010: - version 1.10.1 -

-

- This primarily focusses on the Bl and It macros described in mdoc. Multi-line column support is now fully compatible with - groff, as are implicit list entries for columns. Removed manuals.7 in favour of http://manpages.bsd.lv. The way we - handle the SYNOPSIS section (see the SYNOPSIS documentation in MANUAL STRUCTURE) has also - been considerably simplified compared to groff's method. Lastly, the -Owidth=width output option has been added to -Tascii (see mandoc). -

-
-
-

- 29-05-2010: - version 1.10.0 -

-

- Release consisting of the results from the m2k10 hackathon and up-merge from OpenBSD. - This requires a significant note of thanks to Ingo Schwarze (OpenBSD) and Joerg - Sonnenberger (NetBSD) for their hard work, and again to Joerg for hosting m2k10. - Highlights (mostly cribbed from Ingo's m2k10 report) follow in no particular order: -

-
    -
  • a libroff preprocessor in front of libmdoc and libman stripping out - roff instructions;
  • -
  • end-of-sentence (EOS) detection in free-form and macro lines;
  • -
  • correct handling of tab-separated columnar lists in -mdoc;
  • -
  • improved main calling routines to optionally use mmap() for better - performance;
  • -
  • cleaned up exiting when invoked as -Tlint or over - multiple files with -fign-errors;
  • -
  • error and warning message handling re-written to be unified for libroff, libmdoc, and libman;
  • -
  • handling of badly-nested explicit-scoped macros;
  • -
  • improved free-form text parsing in libman and libmdoc;
  • -
  • significant GNU troff compatibility improvements in -Tascii, largely in terms of spacing;
  • -
  • a regression framework for making sure the many fragilities of GNU troff - aren't trampled in subsequent work;
  • -
  • support for -Tascii breaking at hyphens - encountered in free-form text;
  • -
  • and many more minor fixes and improvements (no really, consult cvsweb and see - for yourself!).
  • -
-
-
-

- 13-05-2010: - version 1.9.25 -

-

- Fixed handling of \*(Ba escape. Backed out -fno-ign-chars (pointless complexity). Fixed erroneous - breaking of literal lines. Fixed SYNOPSIS breaking lines before non-initial - macros. Changed default section ordering. Most importantly, the framework for - end-of-sentence double-spacing is in place, now implemented for the - end-of-sentence, end-of-line rule. This is a stable roll-back point - before the mandoc hackathon in Rostock! -

-
-
-

- 09-05-2010: - version 1.9.24 -

-

- Rolled back break-at-hyphen. -DUGLY is now the - default (no feature splits!). Free-form text is not de-chunked any more: lines - are passed whole-sale into the front-end, including whitespace. Added mailing - lists. Lastly, mdocml is the focus of two Google Summer of Code - projects this year: mandoc -Tps - (NetBSD) and BSD-licensed - Text-Processing Tools (FreeBSD). -

-
+

+ Contact +

-
-

- 07-04-2010: - version 1.9.23 -

-

- mdocml has been linked to the OpenBSD build. This - version incorporates many small changes, mostly from patches by OpenBSD, - allowing crufty manuals to slip by with warnings instead of erroring-out. Some - subtle semantic issues, such as punctuation scope, have also been fixed. - Lastly, some issues with -Thtml have been fixed, which - prompted an update to the online manual pages style - layout. -

-
-

- See cvsweb for - historical notes. -

-
-
- Copyright © 2008–2010 Kristaps Dzonsons, $Date: 2010/06/07 12:20:07 $ -
-
+

+ Use the mailing lists for bug-reports, patches, questions, etc. (these require subscription). Please check the + TODO for known issues + before posting. Beyond that, contact Kristaps at kris...@bsd.lv. +

+ + + + + + + + + + + + + + + + + + +
+ disc...@mdocml.bsd.lv + + bug-reports, general questions, and announcements + (archive) +
+ tec...@mdocml.bsd.lv + + patches and system discussions + (archive) +
+ sou...@mdocml.bsd.lv + + source commit messages + (archive) +
+ +

+ News +

+ +

+ 19-05-2011: version 1.11.3 +

+

+ Introduce locale-encoding of output with the -Tlocale output option and Unicode escaped-character input. + See mandoc and mandoc_char, respectively, for details. + This allows for non-ASCII characters (e.g., \[u5000]) to be rendered in the locale's encoding, if said + environment supports wide-character encoding (if it does not, -Tascii is used instead). + Locale support can be turned off at compile time by removing -DUSE_WCHAR in the Makefile, in which case + -Tlocale is always a synonym for -Tascii. +

+

+ Furthermore, multibyte-encoded documents, such as those in UTF-8, may be on-the-fly recoded as mandoc input by using the newly-added preconv utility. +

+ +

+ 12-05-2011: version 1.11.2 +

+

+ Corrected some installation issues in version 1.11.1. + Further migration to libmandoc. + Initial public release (this utility is very much under development) of makewhatis, + initially named mandoc-db. + This utility produces keyword databases of manual content + mandoc-cgi, which features semantic querying of manual content. +

+ +

+ 04-04-2011: version 1.11.1 +

+

+ The earlier libroff, libmdoc, and libman soup have been merged into + a single library, libmandoc, which manages all aspects of + parsing real manuals (from line-handling to tbl parsing). +

+

+ Beyond this structural change, initial eqn functionality is in + place. For the time being, this is limited to the recognition of equation blocks; + future version of mdocml will expand upon this framework. +

+

+ As usual, many general fixes and improvements have also occurred. In particular, a great + deal of redundancy and superfluous code has been removed with the merging of the backend + libraries. +

+ +

+ See cvsweb for + historical notes. +

+ +

+ + Copyright © 2008–2011 + Kristaps Dzonsons, + $Date: 2011/05/26 12:14:46 $ + +