[BACK]Return to libmandoc.h CVS log [TXT][DIR] Up to [cvsweb.bsd.lv] / mandoc

Annotation of mandoc/libmandoc.h, Revision 1.15

1.15    ! kristaps    1: /*     $Id: libmandoc.h,v 1.14 2011/03/22 09:48:13 kristaps Exp $ */
1.1       kristaps    2: /*
1.15    ! kristaps    3:  * Copyright (c) 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
1.1       kristaps    4:  *
                      5:  * Permission to use, copy, modify, and distribute this software for any
                      6:  * purpose with or without fee is hereby granted, provided that the above
                      7:  * copyright notice and this permission notice appear in all copies.
                      8:  *
                      9:  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
                     10:  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
                     11:  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
                     12:  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
                     13:  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
                     14:  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
                     15:  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
                     16:  */
                     17: #ifndef LIBMANDOC_H
                     18: #define LIBMANDOC_H
                     19:
1.14      kristaps   20: enum   rofferr {
                     21:        ROFF_CONT, /* continue processing line */
                     22:        ROFF_RERUN, /* re-run roff interpreter with offset */
                     23:        ROFF_APPEND, /* re-run main parser, appending next line */
                     24:        ROFF_REPARSE, /* re-run main parser on the result */
                     25:        ROFF_SO, /* include another file */
                     26:        ROFF_IGN, /* ignore current line */
                     27:        ROFF_TBL, /* a table row was successfully parsed */
                     28:        ROFF_EQN, /* an equation was successfully parsed */
                     29:        ROFF_ERR /* badness: puke and stop */
                     30: };
                     31:
                     32: /*
                     33:  * Available registers (set in libroff, accessed elsewhere).
                     34:  */
                     35: enum   regs {
                     36:        REG_nS = 0,
                     37:        REG__MAX
                     38: };
                     39:
                     40: /*
                     41:  * A register (struct reg) can consist of many types: this consists of
                     42:  * normalised types from the original string form.
                     43:  */
                     44: union  regval {
                     45:        unsigned  u; /* unsigned integer */
                     46: };
                     47:
                     48: /*
                     49:  * A single register entity.  If "set" is zero, the value of the
                     50:  * register should be the default one, which is per-register.  It's
                     51:  * assumed that callers know which type in "v" corresponds to which
                     52:  * register value.
                     53:  */
                     54: struct reg {
                     55:        int               set; /* whether set or not */
                     56:        union regval      v; /* parsed data */
                     57: };
                     58:
                     59: /*
                     60:  * The primary interface to setting register values is in libroff,
                     61:  * although libmdoc and libman from time to time will manipulate
                     62:  * registers (such as `.Sh SYNOPSIS' enabling REG_nS).
                     63:  */
                     64: struct regset {
                     65:        struct reg        regs[REG__MAX];
                     66: };
                     67:
1.1       kristaps   68: __BEGIN_DECLS
                     69:
1.14      kristaps   70: struct roff;
                     71: struct mdoc;
                     72: struct man;
                     73:
                     74: void            mandoc_msg(enum mandocerr, struct mparse *,
                     75:                        int, int, const char *);
                     76: void            mandoc_vmsg(enum mandocerr, struct mparse *,
                     77:                        int, int, const char *, ...);
                     78: int             mandoc_special(char *);
                     79: char            *mandoc_strdup(const char *);
                     80: char            *mandoc_getarg(struct mparse *, char **, int, int *);
                     81: char            *mandoc_normdate(struct mparse *, char *, int, int);
                     82: int             mandoc_eos(const char *, size_t, int);
                     83: int             mandoc_hyph(const char *, const char *);
                     84:
                     85: void            mdoc_free(struct mdoc *);
                     86: struct mdoc    *mdoc_alloc(struct regset *, struct mparse *);
                     87: void            mdoc_reset(struct mdoc *);
                     88: int             mdoc_parseln(struct mdoc *, int, char *, int);
                     89: int             mdoc_endparse(struct mdoc *);
                     90: int             mdoc_addspan(struct mdoc *, const struct tbl_span *);
                     91: int             mdoc_addeqn(struct mdoc *, const struct eqn *);
                     92:
                     93: void            man_free(struct man *);
                     94: struct man     *man_alloc(struct regset *, struct mparse *);
                     95: void            man_reset(struct man *);
                     96: int             man_parseln(struct man *, int, char *, int);
                     97: int             man_endparse(struct man *);
                     98: int             man_addspan(struct man *, const struct tbl_span *);
                     99: int             man_addeqn(struct man *, const struct eqn *);
                    100:
                    101: void            roff_free(struct roff *);
                    102: struct roff    *roff_alloc(struct regset *, struct mparse *);
                    103: void            roff_reset(struct roff *);
                    104: enum rofferr    roff_parseln(struct roff *, int,
                    105:                        char **, size_t *, int, int *);
                    106: void             roff_endparse(struct roff *);
                    107:
                    108: const struct tbl_span *roff_span(const struct roff *);
                    109: const struct eqn *roff_eqn(const struct roff *);
                    110:
1.1       kristaps  111:
                    112: __END_DECLS
                    113:
                    114: #endif /*!LIBMANDOC_H*/

CVSweb