2011-09-26 18:19:29 +02:00
|
|
|
/* $Vendor-Id: mdoc.h,v 1.114 2011/01/01 12:18:37 kristaps Exp $ */
|
2010-06-26 04:20:06 +02:00
|
|
|
/*
|
2011-09-26 18:19:29 +02:00
|
|
|
* Copyright (c) 2008, 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
|
2010-06-26 04:20:06 +02:00
|
|
|
*
|
|
|
|
* 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 AUTHOR DISCLAIMS ALL WARRANTIES
|
|
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR 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.
|
|
|
|
*/
|
|
|
|
#ifndef MDOC_H
|
|
|
|
#define MDOC_H
|
|
|
|
|
2011-09-26 18:19:29 +02:00
|
|
|
/*
|
|
|
|
* What follows is a list of ALL possible macros.
|
2010-06-26 04:20:06 +02:00
|
|
|
*/
|
|
|
|
enum mdoct {
|
|
|
|
MDOC_Ap = 0,
|
|
|
|
MDOC_Dd,
|
|
|
|
MDOC_Dt,
|
|
|
|
MDOC_Os,
|
|
|
|
MDOC_Sh,
|
|
|
|
MDOC_Ss,
|
|
|
|
MDOC_Pp,
|
|
|
|
MDOC_D1,
|
|
|
|
MDOC_Dl,
|
|
|
|
MDOC_Bd,
|
|
|
|
MDOC_Ed,
|
|
|
|
MDOC_Bl,
|
|
|
|
MDOC_El,
|
|
|
|
MDOC_It,
|
|
|
|
MDOC_Ad,
|
|
|
|
MDOC_An,
|
|
|
|
MDOC_Ar,
|
|
|
|
MDOC_Cd,
|
|
|
|
MDOC_Cm,
|
|
|
|
MDOC_Dv,
|
|
|
|
MDOC_Er,
|
|
|
|
MDOC_Ev,
|
|
|
|
MDOC_Ex,
|
|
|
|
MDOC_Fa,
|
|
|
|
MDOC_Fd,
|
|
|
|
MDOC_Fl,
|
|
|
|
MDOC_Fn,
|
|
|
|
MDOC_Ft,
|
|
|
|
MDOC_Ic,
|
|
|
|
MDOC_In,
|
|
|
|
MDOC_Li,
|
|
|
|
MDOC_Nd,
|
|
|
|
MDOC_Nm,
|
|
|
|
MDOC_Op,
|
|
|
|
MDOC_Ot,
|
|
|
|
MDOC_Pa,
|
|
|
|
MDOC_Rv,
|
|
|
|
MDOC_St,
|
|
|
|
MDOC_Va,
|
|
|
|
MDOC_Vt,
|
|
|
|
MDOC_Xr,
|
|
|
|
MDOC__A,
|
|
|
|
MDOC__B,
|
|
|
|
MDOC__D,
|
|
|
|
MDOC__I,
|
|
|
|
MDOC__J,
|
|
|
|
MDOC__N,
|
|
|
|
MDOC__O,
|
|
|
|
MDOC__P,
|
|
|
|
MDOC__R,
|
|
|
|
MDOC__T,
|
|
|
|
MDOC__V,
|
|
|
|
MDOC_Ac,
|
|
|
|
MDOC_Ao,
|
|
|
|
MDOC_Aq,
|
|
|
|
MDOC_At,
|
|
|
|
MDOC_Bc,
|
|
|
|
MDOC_Bf,
|
|
|
|
MDOC_Bo,
|
|
|
|
MDOC_Bq,
|
|
|
|
MDOC_Bsx,
|
|
|
|
MDOC_Bx,
|
|
|
|
MDOC_Db,
|
|
|
|
MDOC_Dc,
|
|
|
|
MDOC_Do,
|
|
|
|
MDOC_Dq,
|
|
|
|
MDOC_Ec,
|
|
|
|
MDOC_Ef,
|
|
|
|
MDOC_Em,
|
|
|
|
MDOC_Eo,
|
|
|
|
MDOC_Fx,
|
|
|
|
MDOC_Ms,
|
|
|
|
MDOC_No,
|
|
|
|
MDOC_Ns,
|
|
|
|
MDOC_Nx,
|
|
|
|
MDOC_Ox,
|
|
|
|
MDOC_Pc,
|
|
|
|
MDOC_Pf,
|
|
|
|
MDOC_Po,
|
|
|
|
MDOC_Pq,
|
|
|
|
MDOC_Qc,
|
|
|
|
MDOC_Ql,
|
|
|
|
MDOC_Qo,
|
|
|
|
MDOC_Qq,
|
|
|
|
MDOC_Re,
|
|
|
|
MDOC_Rs,
|
|
|
|
MDOC_Sc,
|
|
|
|
MDOC_So,
|
|
|
|
MDOC_Sq,
|
|
|
|
MDOC_Sm,
|
|
|
|
MDOC_Sx,
|
|
|
|
MDOC_Sy,
|
|
|
|
MDOC_Tn,
|
|
|
|
MDOC_Ux,
|
|
|
|
MDOC_Xc,
|
|
|
|
MDOC_Xo,
|
|
|
|
MDOC_Fo,
|
|
|
|
MDOC_Fc,
|
|
|
|
MDOC_Oo,
|
|
|
|
MDOC_Oc,
|
|
|
|
MDOC_Bk,
|
|
|
|
MDOC_Ek,
|
|
|
|
MDOC_Bt,
|
|
|
|
MDOC_Hf,
|
|
|
|
MDOC_Fr,
|
|
|
|
MDOC_Ud,
|
|
|
|
MDOC_Lb,
|
|
|
|
MDOC_Lp,
|
|
|
|
MDOC_Lk,
|
|
|
|
MDOC_Mt,
|
|
|
|
MDOC_Brq,
|
|
|
|
MDOC_Bro,
|
|
|
|
MDOC_Brc,
|
|
|
|
MDOC__C,
|
|
|
|
MDOC_Es,
|
|
|
|
MDOC_En,
|
|
|
|
MDOC_Dx,
|
|
|
|
MDOC__Q,
|
|
|
|
MDOC_br,
|
|
|
|
MDOC_sp,
|
|
|
|
MDOC__U,
|
|
|
|
MDOC_Ta,
|
|
|
|
MDOC_MAX
|
|
|
|
};
|
|
|
|
|
2011-09-26 18:19:29 +02:00
|
|
|
/*
|
|
|
|
* What follows is a list of ALL possible macro arguments.
|
|
|
|
*/
|
|
|
|
enum mdocargt {
|
|
|
|
MDOC_Split,
|
|
|
|
MDOC_Nosplit,
|
|
|
|
MDOC_Ragged,
|
|
|
|
MDOC_Unfilled,
|
|
|
|
MDOC_Literal,
|
|
|
|
MDOC_File,
|
|
|
|
MDOC_Offset,
|
|
|
|
MDOC_Bullet,
|
|
|
|
MDOC_Dash,
|
|
|
|
MDOC_Hyphen,
|
|
|
|
MDOC_Item,
|
|
|
|
MDOC_Enum,
|
|
|
|
MDOC_Tag,
|
|
|
|
MDOC_Diag,
|
|
|
|
MDOC_Hang,
|
|
|
|
MDOC_Ohang,
|
|
|
|
MDOC_Inset,
|
|
|
|
MDOC_Column,
|
|
|
|
MDOC_Width,
|
|
|
|
MDOC_Compact,
|
|
|
|
MDOC_Std,
|
|
|
|
MDOC_Filled,
|
|
|
|
MDOC_Words,
|
|
|
|
MDOC_Emphasis,
|
|
|
|
MDOC_Symbolic,
|
|
|
|
MDOC_Nested,
|
|
|
|
MDOC_Centred,
|
|
|
|
MDOC_ARG_MAX
|
|
|
|
};
|
2010-06-26 04:20:06 +02:00
|
|
|
|
2011-09-26 18:19:29 +02:00
|
|
|
/*
|
|
|
|
* Type of a syntax node.
|
|
|
|
*/
|
2010-06-26 04:20:06 +02:00
|
|
|
enum mdoc_type {
|
|
|
|
MDOC_TEXT,
|
|
|
|
MDOC_ELEM,
|
|
|
|
MDOC_HEAD,
|
|
|
|
MDOC_TAIL,
|
|
|
|
MDOC_BODY,
|
|
|
|
MDOC_BLOCK,
|
2011-09-26 18:19:29 +02:00
|
|
|
MDOC_TBL,
|
2010-06-26 04:20:06 +02:00
|
|
|
MDOC_ROOT
|
|
|
|
};
|
|
|
|
|
2011-09-26 18:19:29 +02:00
|
|
|
/*
|
|
|
|
* Section (named/unnamed) of `Sh'. Note that these appear in the
|
|
|
|
* conventional order imposed by mdoc.7.
|
|
|
|
*/
|
2010-06-26 04:20:06 +02:00
|
|
|
enum mdoc_sec {
|
2011-09-26 18:19:29 +02:00
|
|
|
SEC_NONE = 0, /* No section, yet. */
|
2010-06-26 04:20:06 +02:00
|
|
|
SEC_NAME,
|
|
|
|
SEC_LIBRARY,
|
|
|
|
SEC_SYNOPSIS,
|
|
|
|
SEC_DESCRIPTION,
|
|
|
|
SEC_IMPLEMENTATION,
|
|
|
|
SEC_RETURN_VALUES,
|
|
|
|
SEC_ENVIRONMENT,
|
|
|
|
SEC_FILES,
|
|
|
|
SEC_EXIT_STATUS,
|
|
|
|
SEC_EXAMPLES,
|
|
|
|
SEC_DIAGNOSTICS,
|
|
|
|
SEC_COMPATIBILITY,
|
|
|
|
SEC_ERRORS,
|
|
|
|
SEC_SEE_ALSO,
|
|
|
|
SEC_STANDARDS,
|
|
|
|
SEC_HISTORY,
|
|
|
|
SEC_AUTHORS,
|
|
|
|
SEC_CAVEATS,
|
|
|
|
SEC_BUGS,
|
|
|
|
SEC_SECURITY,
|
2011-09-26 18:19:29 +02:00
|
|
|
SEC_CUSTOM, /* User-defined. */
|
2010-06-26 04:20:06 +02:00
|
|
|
SEC__MAX
|
|
|
|
};
|
|
|
|
|
2011-09-26 18:19:29 +02:00
|
|
|
/*
|
|
|
|
* Information from prologue.
|
|
|
|
*/
|
2010-06-26 04:20:06 +02:00
|
|
|
struct mdoc_meta {
|
2011-09-26 18:19:29 +02:00
|
|
|
char *msec; /* `Dt' section (1, 3p, etc.) */
|
|
|
|
char *vol; /* `Dt' volume (implied) */
|
|
|
|
char *arch; /* `Dt' arch (i386, etc.) */
|
|
|
|
time_t date; /* `Dd' normalised date */
|
|
|
|
char *title; /* `Dt' title (FOO, etc.) */
|
|
|
|
char *os; /* `Os' system (OpenBSD, etc.) */
|
|
|
|
char *name; /* leading `Nm' name */
|
2010-06-26 04:20:06 +02:00
|
|
|
};
|
|
|
|
|
2011-09-26 18:19:29 +02:00
|
|
|
/*
|
|
|
|
* An argument to a macro (multiple values = `-column xxx yyy').
|
|
|
|
*/
|
2010-06-26 04:20:06 +02:00
|
|
|
struct mdoc_argv {
|
2011-09-26 18:19:29 +02:00
|
|
|
enum mdocargt arg; /* type of argument */
|
2010-06-26 04:20:06 +02:00
|
|
|
int line;
|
|
|
|
int pos;
|
2011-09-26 18:19:29 +02:00
|
|
|
size_t sz; /* elements in "value" */
|
|
|
|
char **value; /* argument strings */
|
2010-06-26 04:20:06 +02:00
|
|
|
};
|
|
|
|
|
2011-09-26 18:19:29 +02:00
|
|
|
/*
|
|
|
|
* Reference-counted macro arguments. These are refcounted because
|
|
|
|
* blocks have multiple instances of the same arguments spread across
|
|
|
|
* the HEAD, BODY, TAIL, and BLOCK node types.
|
|
|
|
*/
|
2010-06-26 04:20:06 +02:00
|
|
|
struct mdoc_arg {
|
|
|
|
size_t argc;
|
|
|
|
struct mdoc_argv *argv;
|
|
|
|
unsigned int refcnt;
|
|
|
|
};
|
|
|
|
|
2011-09-26 18:19:29 +02:00
|
|
|
/*
|
|
|
|
* Indicates that a BODY's formatting has ended, but the scope is still
|
|
|
|
* open. Used for syntax-broken blocks.
|
|
|
|
*/
|
|
|
|
enum mdoc_endbody {
|
|
|
|
ENDBODY_NOT = 0,
|
|
|
|
ENDBODY_SPACE, /* is broken: append a space */
|
|
|
|
ENDBODY_NOSPACE /* is broken: don't append a space */
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Normalised `Bl' list type.
|
|
|
|
*/
|
2010-06-26 04:20:06 +02:00
|
|
|
enum mdoc_list {
|
|
|
|
LIST__NONE = 0,
|
|
|
|
LIST_bullet,
|
|
|
|
LIST_column,
|
|
|
|
LIST_dash,
|
|
|
|
LIST_diag,
|
|
|
|
LIST_enum,
|
|
|
|
LIST_hang,
|
|
|
|
LIST_hyphen,
|
|
|
|
LIST_inset,
|
|
|
|
LIST_item,
|
|
|
|
LIST_ohang,
|
2011-09-26 18:19:29 +02:00
|
|
|
LIST_tag,
|
|
|
|
LIST_MAX
|
2010-06-26 04:20:06 +02:00
|
|
|
};
|
|
|
|
|
2011-09-26 18:19:29 +02:00
|
|
|
/*
|
|
|
|
* Normalised `Bd' display type.
|
|
|
|
*/
|
2010-06-26 04:20:06 +02:00
|
|
|
enum mdoc_disp {
|
|
|
|
DISP__NONE = 0,
|
|
|
|
DISP_centred,
|
|
|
|
DISP_ragged,
|
|
|
|
DISP_unfilled,
|
|
|
|
DISP_filled,
|
|
|
|
DISP_literal
|
|
|
|
};
|
|
|
|
|
2011-09-26 18:19:29 +02:00
|
|
|
/*
|
|
|
|
* Normalised `An' splitting argument.
|
|
|
|
*/
|
|
|
|
enum mdoc_auth {
|
|
|
|
AUTH__NONE = 0,
|
|
|
|
AUTH_split,
|
|
|
|
AUTH_nosplit
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Normalised `Bf' font type.
|
|
|
|
*/
|
|
|
|
enum mdoc_font {
|
|
|
|
FONT__NONE = 0,
|
|
|
|
FONT_Em,
|
|
|
|
FONT_Li,
|
|
|
|
FONT_Sy
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Normalised arguments for `Bd'.
|
|
|
|
*/
|
2010-06-26 04:20:06 +02:00
|
|
|
struct mdoc_bd {
|
|
|
|
const char *offs; /* -offset */
|
|
|
|
enum mdoc_disp type; /* -ragged, etc. */
|
|
|
|
int comp; /* -compact */
|
|
|
|
};
|
|
|
|
|
2011-09-26 18:19:29 +02:00
|
|
|
/*
|
|
|
|
* Normalised arguments for `Bl'.
|
|
|
|
*/
|
2010-06-26 04:20:06 +02:00
|
|
|
struct mdoc_bl {
|
|
|
|
const char *width; /* -width */
|
|
|
|
const char *offs; /* -offset */
|
|
|
|
enum mdoc_list type; /* -tag, -enum, etc. */
|
|
|
|
int comp; /* -compact */
|
2011-09-26 18:19:29 +02:00
|
|
|
size_t ncols; /* -column arg count */
|
|
|
|
const char **cols; /* -column val ptr */
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Normalised arguments for `Bf'.
|
|
|
|
*/
|
|
|
|
struct mdoc_bf {
|
|
|
|
enum mdoc_font font; /* font */
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Normalised arguments for `An'.
|
|
|
|
*/
|
|
|
|
struct mdoc_an {
|
|
|
|
enum mdoc_auth auth; /* -split, etc. */
|
|
|
|
};
|
|
|
|
|
|
|
|
struct mdoc_rs {
|
|
|
|
struct mdoc_node *child_J; /* pointer to %J */
|
2010-06-26 04:20:06 +02:00
|
|
|
};
|
|
|
|
|
2011-09-26 18:19:29 +02:00
|
|
|
/*
|
|
|
|
* Consists of normalised node arguments. These should be used instead
|
|
|
|
* of iterating through the mdoc_arg pointers of a node: defaults are
|
|
|
|
* provided, etc.
|
|
|
|
*/
|
|
|
|
union mdoc_data {
|
|
|
|
struct mdoc_an An;
|
|
|
|
struct mdoc_bd Bd;
|
|
|
|
struct mdoc_bf Bf;
|
|
|
|
struct mdoc_bl Bl;
|
|
|
|
struct mdoc_rs Rs;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Single node in tree-linked AST.
|
|
|
|
*/
|
2010-06-26 04:20:06 +02:00
|
|
|
struct mdoc_node {
|
|
|
|
struct mdoc_node *parent; /* parent AST node */
|
|
|
|
struct mdoc_node *child; /* first child AST node */
|
2011-09-26 18:19:29 +02:00
|
|
|
struct mdoc_node *last; /* last child AST node */
|
2010-06-26 04:20:06 +02:00
|
|
|
struct mdoc_node *next; /* sibling AST node */
|
|
|
|
struct mdoc_node *prev; /* prior sibling AST node */
|
|
|
|
int nchild; /* number children */
|
|
|
|
int line; /* parse line */
|
|
|
|
int pos; /* parse column */
|
|
|
|
enum mdoct tok; /* tok or MDOC__MAX if none */
|
|
|
|
int flags;
|
|
|
|
#define MDOC_VALID (1 << 0) /* has been validated */
|
|
|
|
#define MDOC_EOS (1 << 2) /* at sentence boundary */
|
|
|
|
#define MDOC_LINE (1 << 3) /* first macro/text on line */
|
2011-09-26 18:19:29 +02:00
|
|
|
#define MDOC_SYNPRETTY (1 << 4) /* SYNOPSIS-style formatting */
|
|
|
|
#define MDOC_ENDED (1 << 5) /* rendering has been ended */
|
2010-06-26 04:20:06 +02:00
|
|
|
enum mdoc_type type; /* AST node type */
|
|
|
|
enum mdoc_sec sec; /* current named section */
|
2011-09-26 18:19:29 +02:00
|
|
|
union mdoc_data *norm; /* normalised args */
|
|
|
|
/* FIXME: these can be union'd to shave a few bytes. */
|
|
|
|
struct mdoc_arg *args; /* BLOCK/ELEM */
|
|
|
|
struct mdoc_node *pending; /* BLOCK */
|
|
|
|
struct mdoc_node *head; /* BLOCK */
|
|
|
|
struct mdoc_node *body; /* BLOCK */
|
|
|
|
struct mdoc_node *tail; /* BLOCK */
|
|
|
|
char *string; /* TEXT */
|
|
|
|
const struct tbl_span *span; /* TBL */
|
|
|
|
enum mdoc_endbody end; /* BODY */
|
2010-06-26 04:20:06 +02:00
|
|
|
};
|
|
|
|
|
2011-09-26 18:19:29 +02:00
|
|
|
/*
|
|
|
|
* Names of macros. Index is enum mdoct. Indexing into this returns
|
|
|
|
* the normalised name, e.g., mdoc_macronames[MDOC_Sh] -> "Sh".
|
|
|
|
*/
|
2010-06-26 04:20:06 +02:00
|
|
|
extern const char *const *mdoc_macronames;
|
2011-09-26 18:19:29 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Names of macro args. Index is enum mdocargt. Indexing into this
|
|
|
|
* returns the normalised name, e.g., mdoc_argnames[MDOC_File] ->
|
|
|
|
* "file".
|
|
|
|
*/
|
2010-06-26 04:20:06 +02:00
|
|
|
extern const char *const *mdoc_argnames;
|
|
|
|
|
|
|
|
__BEGIN_DECLS
|
|
|
|
|
|
|
|
struct mdoc;
|
|
|
|
|
|
|
|
void mdoc_free(struct mdoc *);
|
2011-09-26 18:19:29 +02:00
|
|
|
struct mdoc *mdoc_alloc(struct regset *, void *, mandocmsg);
|
2010-06-26 04:20:06 +02:00
|
|
|
void mdoc_reset(struct mdoc *);
|
|
|
|
int mdoc_parseln(struct mdoc *, int, char *, int);
|
|
|
|
const struct mdoc_node *mdoc_node(const struct mdoc *);
|
|
|
|
const struct mdoc_meta *mdoc_meta(const struct mdoc *);
|
|
|
|
int mdoc_endparse(struct mdoc *);
|
2011-09-26 18:19:29 +02:00
|
|
|
int mdoc_addspan(struct mdoc *,
|
|
|
|
const struct tbl_span *);
|
2010-06-26 04:20:06 +02:00
|
|
|
|
|
|
|
__END_DECLS
|
|
|
|
|
|
|
|
#endif /*!MDOC_H*/
|