X-Git-Url: https://git.cameronkatri.com/mandoc.git/blobdiff_plain/17fe2cc58076cb3f7055c7b944dd9352095f6588..157acc96e57eb848d9e9d3918f644f9bb1a463bc:/index.sgml?ds=inline diff --git a/index.sgml b/index.sgml index ab387b0e..af276036 100644 --- a/index.sgml +++ b/index.sgml @@ -3,253 +3,257 @@
-- mdocml – mdoc macro compiler + + mdocml – UNIX manpage compiler, current version @VERSION@ (@VDATE@) +
++ Sources: current, + cvsweb + (archives)
-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. + UNIX manuals. + It is small, ISO C, ISC-licensed, and quite fast.
-- 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 tool set features mandoc, + based on the libmandoc validating compiler, + to format output for UNIX terminals (with + support for wide-character locales), XHTML, HTML, PostScript, and PDF. + It also includes preconv, for recoding multibyte manuals; + demandoc, for emitting only text parts of manuals; + mandocdb, for indexing manuals; and + apropos, whatis, and + man.cgi (via catman) for semantic search of manual content.
-- 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. + mdocml has predominantly been developed on OpenBSD + and is both an OpenBSD + and a BSD.lv project. + We strive to support all interested free operating systems, in particular + DragonFly, + NetBSD, + FreeBSD, + Minix 3, + and GNU/Linux, + as well as all systems running the pkgsrc portable package build system. + All of these projects have helped to make mdocml better, by providing feedback and advice, + bug reports, and patches.
-
Disambiguation: mdocml is often referred to by its installed binary, mandoc
.
- mdocml is in plain-old ANSI C and should build and run on any UNIX system. The most current
- version is @VERSION@, dated @VDATE@.
+ mdocml is in ISO C99 and should build and run on any modern system; however, you'll need sqlite3 to build apropos (links to whatis),
+ man.cgi, and mandocdb.
+ To build and install into /usr/local/, just run make install
.
+ Be careful: the preconv, apropos, and whatis binary names are usually taken by existing utilities.
Source archive | +DragonFly BSD | - /snapshots/mdocml.tar.gz - (md5) + contrib/mdocml (1.12.3 sources) + lib/libmandoc + usr.bin/mandoc (build system) |
Online source | +FreeBSD 10.0, -CURRENT | - cvsweb + contrib/mdocml (1.12.1 sources) + usr.bin/mandoc (build system) |
DragonFly BSD | +FreeBSD 9.x, 8.x | - usr.bin/mandoc + ports/textproc/mdocml (1.12.2 port) |
FreeBSD | +NetBSD | - ports/textproc/mdocml + src/external/bsd/mdocml (1.12.1 sources plus patches and build system) |
NetBSD | +OpenBSD | - src/external/bsd/mdocml + src/usr.bin/mandoc (1.12.3 sources under active development and build system) |
OpenBSD | +pkgsrc | - src/usr.bin/mandoc + textproc/mdocml (1.12.3 port) + | +
Minix3 | ++ external/bsd/mdocml (1.10.9 sources and build system) |
Source archive | +Alpine Linux | - /snapshots/ + aports/main/mdocml (1.12.2 port) |
- These manuals are generated automatically and refer to the current snapshot. + These manuals are generated automatically and refer to the current release. + They are the authoritative documentation for the mdocml system.
apropos(1) | ++ search the manual page database + | +|
demandoc(1) | ++ emit only text of UNIX manuals + | +|
mandoc(1) | format and display UNIX manuals - - (text | - xhtml | - pdf | - postscript) - + | +|
preconv(1) | ++ recode multibyte UNIX manuals | |
mandoc(3) | mandoc macro compiler library - - (text | - xhtml | - pdf | - postscript) - | |
man(7) | +tbl(3) | - man language reference - - (text | - xhtml | - pdf | - postscript) - + roff table parser library for mandoc |
eqn(7) | eqn-mandoc language reference - - (text | - xhtml | - pdf | - postscript) - + | +|
man(7) | ++ man language reference + | +|
man.cgi(7) | ++ cgi for manpage query and display | |
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) - + | +|
mandocdb(8) | ++ index UNIX manuals |
- Use the mailing lists for bug-reports, patches, questions, etc. (these require subscription). Please check the + Use the mailing lists for bug-reports, patches, questions, etc. Please check the TODO for known issues - before posting. Beyond that, contact Kristaps at kris...@bsd.lv. + before posting. All lists are subscription-only: send a blank e-mail to the listed address to subscribe. Beyond that, + contact Kristaps at kris...@bsd.lv. Archives are available at Gmane.
-bug-reports, general questions, and announcements - (archive) |
patches and system discussions - (archive) |
source commit messages - (archive) |
- 04-04-2011: version 1.11.1 + xx-xx-2014: version 1.13.0
- 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). + The mandocdb tools (mandocdb, apropos (absorbing whatis), and man.cgi) have been re-written to + use sqlite3 as a database. +
++ 31-12-2013: version 1.12.3
- 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. + In the mdoc(7) SYNOPSIS, line breaks and hanging indentation + now work correctly for .Fo/.Fa/.Fc and .Fn blocks. + Thanks to Franco Fichtner for doing part of the work.
- As usual, many general fixes and improvements have also occured. In particular, a great - deal of redundancy and superfluous code has been removed with the merging of the backend - libraries. + The mdoc(7) .Bk macro got some addititonal bugfixes.
- -- 07-01-2011: version 1.10.9 +
+ In mdoc(7) macro arguments, double quotes can now be quoted + by doubling them, just like in man(7). + Thanks to Tsugutomo ENAMI for the patch.
- Many back-end fixes have been implemented: argument handling (quoting), man improvements, error/warning classes, and many more. + At the end of man(7) macro lines, end-of-sentence spacing + now works. Thanks to Franco Fichtner for the patch.
- Initial tbl functionality (see the TS
, TE
, and
- T&
macros in the roff manual) has been
- merged from tbl.bsd.lv. Output is
- still minimal, especially for -Thtml and -Txhtml, but manages to at least display data. This means that mandoc now has built-in support for two troff preprocessors via
- libroff: soelim and tbl.
+ For backward compatibility, the man(7) parser now supports the
+ man-ext .UR/.UE (uniform resource identifier) block macros.
+
+ The man(7) parser now handles closing blocks that are not open + more gracefully. +
++ The man(7) parser now ignores blank lines right after .SH and .SS. +
++ In the man(7) formatter, reset indentation when leaving a block, + not just when entering the next one. +
++ The roff(7) .nr request now supports incrementing and decrementing + number registers and stops parsing the number right before the first non-digit character. +
++ The roff(7) parser now supports the alternative escape sequence + syntax \C'uXXXX' for Unicode characters. +
++ The roff(7) parser now parses and ignores the .fam (font family) + and .hw (hyphenation points) requests and the \d and \u escape sequences. +
++ The roff(7) manual got a new ESCAPE SEQUENCE REFERENCE.
-- 24-12-2010: version 1.10.8 + 05-10-2013: version 1.12.2
- Significant improvements merged from OpenBSD downstream, including
+ The mdoc(7) to man(7) converter,
+ to be called as mandoc -Tman
, is now fully functional.
- Also overhauled the -Thtml and -Txhtml output modes. They now display readable output in arbitrary
- browsers, including text-based ones like lynx. See HTML and XHTML manuals in the DOCUMENTATION section for examples. Attention: available style-sheet classes have been considerably
- changed! See the example.style.css file for details.
- Lastly, libmdoc and libman have been
- cleaned up and reduced in size and complexity.
+ The mandoc(1) utility now supports the -Ios
(default operating system)
+ input option, and the -Tutf8
output mode now actually works.
- See cvsweb for - historical notes. + The mandocdb(8) utility no longer truncates existing databases when starting to build new ones, + but only replaces them when the build actually succeeds.
- ++ The man(7) parser now supports the PD macro (paragraph distance), + and (for GNU man-ext compatibility only) EX (example block) and EE (example end). + Plus several bugfixes regarding indentation, line breaks, and vertical spacing, + and regarding RS following TP. +
++ The roff(7) parser now supports the \f(BI (bold+italic) font escape, + the \z (zero cursor advance) escape and the cc (change control character) + and it (input line trap) requests. + Plus bugfixes regarding the \t (tab) escape, nested escape sequences, and conditional requests. +
++ In mdoc(7), several bugs were fixed related to UTF-8 output of quoting enclosures, + delimiter handling, list indentation and horizontal and vertical spacing, + formatting of the Lk, %U, and %C macros, + plus some bugfixes related to the handling of syntax errors like badly nested font blocks, + stray Ta macros outside column lists, unterminated It Xo blocks, + and non-text children of Nm blocks. +
++ In tbl(7), the width of horizontal spans and the vertical spacing around tables was corrected, + and in man(7) files, a crash was fixed that was triggered by some particular unclosed T{ macros. +
+
+ For mandoc developers, we now provide a tbl(3) library manual and gmdiff
,
+ a very small, very simplistic groff-versus-mandoc output comparison tool.
+
- Copyright © 2008–2011 - Kristaps Dzonsons, - $Date: 2011/04/09 16:43:30 $ + + Copyright © 2008–2011 + Kristaps Dzonsons, + © 2013 Ingo Schwarze, + $Date: 2013/12/31 17:47:17 $ +