544c191c34
--- MAJOR NEW FEATURES --- * apropos(1): improve POSIX compliance by accepting case-insensitive extended regular expressions by default * new -O tag[=term] output option (open a page at the definition of a term) * tbl(7) -T html: spanning and horizontal and vertical alignment of cells * tbl(7) -T html: draw lines on the edges of table cells * tbl(7) -T utf8: render lines with the Unicode box drawing characters * mandoc is now able to handle the manual pages of the groff package. --- MINOR NEW FEATURES --- * -T html: new option -O toc (table of contents) * -T html: second argument to -O man to support local and remote links * mdoc(7) .Bd -centered now fills the text contained in it * man-ext .SY and .YS macros (synopsis block) * man-ext .TQ macro (tagged paragraph without vertical space before it) * tbl(7) \& explicit alignment indicator * roff(7) .shift, .while, and .return requests * roff(7) .char request (output glyph definition) * roff(7) .nop request (no operation) * roff(7) .ft request: handle the CB, CI, and CR fonts * roff(7) .if c conditional (character available) * roff(7) \\$@ escape sequence (insert all macro arguments, quoted) * roff(7) \*(.T predefined string (interpolate output device name) * roff(7) \[charNNN] escape sequence (for printable ASCII characters) * roff(7) \# escape sequence (line continuation with comment) --- HTML OUTPUT SYNTAX CORRECTIONS --- * Render .br and \p as <br/>, not as an empty <div>. * Render .Pp and .PP as <p> and automatically close it when needed. * Stop writing empty list elements for non-compact .Bl -tag lists. * Do not put <p> inside <a> if .UR or .MT contain .PP. * Implement tooltips purely in CSS rather than abusing title= attributes. --- MINOR FUNCTIONAL IMPROVEMENTS --- * many improvements to the handling of fill and no-fill mode * tbl(7): better column widths in the presence of horizontal spans * several minor improvements to escape sequence handling * several minor improvements to manual font handling * portability: autodetect need for _GNU_SOURCE or _OPENBSD_SOURCE * portability: autodetect whether less(1) supports the -T option * large numbers of bugfixes of diverse kinds --- STRUCTURAL IMPROVEMENTS --- * Disentangle eqn(7) and tbl(7) from other parser header files, and clean up some parser data structures. * Substantially simplify error and warning message infrastructure. --- THANKS TO --- * John Gardner for crucial help implementing tooltips in CSS. * Alexander Bluhm, Raphael Graf, Ted Unangst (OpenBSD) and Daniel Sabogal (Alpine Linux) for patches. * Anthony Bentley and Jason McIntyre (OpenBSD) for documentation patches, suggesting new features, bug reports, and useful discussions. * Kyle Evans and Baptiste Daroussin (FreeBSD) for minor patches. * Pali Rohar for suggesting multiple new features and for reporting several bugs and missing features. * Klemens Nanni (OpenBSD) for suggesting multiple new features. * Kristaps Dzonsons (bsd.lv), Marc Espie (OpenBSD), Adam Kalisz, and Laura Morales for suggesting new features. * Wolfram Schneider and Yuri Pankov (FreeBSD) for reporting missing features. * Edward Tomasz Napierala (FreeBSD) for suggesting a feature improvement. * Thomas Klausner (NetBSD) and Sevan Janiyan (SmartOS) for bug reports and release testing. * Bryan Steele, Janne Johansson, Kurt Mosiejczuk, Mike Belopuhov, Theo Buehler, Todd Miller (OpenBSD), Andreas Gustafsson, Christos Zoulas, Robert Elz (NetBSD), Kurt Jaeger (FreeBSD), Fabio Scotoni, Kelvin Sherlock, Mark Harris, Orestis Ioannou, Raf Czlonka, and Sean Farrell for bug reports. * Ulrich Spoerlein (FreeBSD), Leah Neukirchen (Void Linux), Matej Cepl (openSUSE), and Jan Stary (MacOS X) for release testing. * Brian Callahan and Stuart Henderson (OpenBSD) for help with the OpenBSD groff port. * Bertrand Garrigues, Branden Robinson, Ralph Corderoy, and Werner Lemberg (GNU troff) for checking groff patches. * Scott Cheloha, Theo de Raadt (OpenBSD) and Natanael Copa (Alpine Linux) for useful discussions.
88 lines
3.0 KiB
C
88 lines
3.0 KiB
C
/* Id: libmdoc.h,v 1.117 2018/12/31 04:55:46 schwarze Exp */
|
|
/*
|
|
* Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
|
|
* Copyright (c) 2013,2014,2015,2017,2018 Ingo Schwarze <schwarze@openbsd.org>
|
|
*
|
|
* Permission to use, copy, modify, and distribute this software for any
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
* copyright notice and this permission notice appear in all copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHORS DISCLAIM ALL WARRANTIES
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR
|
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
|
|
struct roff_node;
|
|
struct roff_man;
|
|
struct mdoc_arg;
|
|
|
|
#define MACRO_PROT_ARGS struct roff_man *mdoc, \
|
|
enum roff_tok tok, \
|
|
int line, \
|
|
int ppos, \
|
|
int *pos, \
|
|
char *buf
|
|
|
|
struct mdoc_macro {
|
|
void (*fp)(MACRO_PROT_ARGS);
|
|
int flags;
|
|
#define MDOC_CALLABLE (1 << 0)
|
|
#define MDOC_PARSED (1 << 1)
|
|
#define MDOC_EXPLICIT (1 << 2)
|
|
#define MDOC_PROLOGUE (1 << 3)
|
|
#define MDOC_IGNDELIM (1 << 4)
|
|
#define MDOC_JOIN (1 << 5)
|
|
};
|
|
|
|
enum margserr {
|
|
ARGS_ERROR,
|
|
ARGS_EOLN, /* end-of-line */
|
|
ARGS_WORD, /* normal word */
|
|
ARGS_ALLOC, /* normal word from roff_getarg() */
|
|
ARGS_PUNCT, /* series of punctuation */
|
|
ARGS_PHRASE /* Bl -column phrase */
|
|
};
|
|
|
|
/*
|
|
* A punctuation delimiter is opening, closing, or "middle mark"
|
|
* punctuation. These govern spacing.
|
|
* Opening punctuation (e.g., the opening parenthesis) suppresses the
|
|
* following space; closing punctuation (e.g., the closing parenthesis)
|
|
* suppresses the leading space; middle punctuation (e.g., the vertical
|
|
* bar) can do either. The middle punctuation delimiter bends the rules
|
|
* depending on usage.
|
|
*/
|
|
enum mdelim {
|
|
DELIM_NONE = 0,
|
|
DELIM_OPEN,
|
|
DELIM_MIDDLE,
|
|
DELIM_CLOSE,
|
|
DELIM_MAX
|
|
};
|
|
|
|
const struct mdoc_macro *mdoc_macro(enum roff_tok);
|
|
|
|
void mdoc_elem_alloc(struct roff_man *, int, int,
|
|
enum roff_tok, struct mdoc_arg *);
|
|
struct roff_node *mdoc_block_alloc(struct roff_man *, int, int,
|
|
enum roff_tok, struct mdoc_arg *);
|
|
void mdoc_tail_alloc(struct roff_man *, int, int,
|
|
enum roff_tok);
|
|
struct roff_node *mdoc_endbody_alloc(struct roff_man *, int, int,
|
|
enum roff_tok, struct roff_node *);
|
|
void mdoc_state(struct roff_man *, struct roff_node *);
|
|
const char *mdoc_a2arch(const char *);
|
|
const char *mdoc_a2att(const char *);
|
|
const char *mdoc_a2lib(const char *);
|
|
enum roff_sec mdoc_a2sec(const char *);
|
|
const char *mdoc_a2st(const char *);
|
|
void mdoc_argv(struct roff_man *, int, enum roff_tok,
|
|
struct mdoc_arg **, int *, char *);
|
|
enum margserr mdoc_args(struct roff_man *, int,
|
|
int *, char *, enum roff_tok, char **);
|
|
enum mdelim mdoc_isdelim(const char *);
|