]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - contrib/mandoc/html.h
ifconfig(8): wordsmith -G and -g descriptions
[FreeBSD/FreeBSD.git] / contrib / mandoc / html.h
1 /* $Id: html.h,v 1.109 2021/09/09 14:47:24 schwarze Exp $ */
2 /*
3  * Copyright (c) 2017, 2018, 2019, 2020 Ingo Schwarze <schwarze@openbsd.org>
4  * Copyright (c) 2008-2011, 2014 Kristaps Dzonsons <kristaps@bsd.lv>
5  *
6  * Permission to use, copy, modify, and distribute this software for any
7  * purpose with or without fee is hereby granted, provided that the above
8  * copyright notice and this permission notice appear in all copies.
9  *
10  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17  *
18  * Internal interfaces for mandoc(1) HTML formatters.
19  * For use by the individual HTML formatters only.
20  */
21
22 enum    htmltag {
23         TAG_HTML,
24         TAG_HEAD,
25         TAG_META,
26         TAG_LINK,
27         TAG_STYLE,
28         TAG_TITLE,
29         TAG_BODY,
30         TAG_DIV,
31         TAG_SECTION,
32         TAG_TABLE,
33         TAG_TR,
34         TAG_TD,
35         TAG_LI,
36         TAG_UL,
37         TAG_OL,
38         TAG_DL,
39         TAG_DT,
40         TAG_DD,
41         TAG_H1,
42         TAG_H2,
43         TAG_P,
44         TAG_PRE,
45         TAG_A,
46         TAG_B,
47         TAG_CITE,
48         TAG_CODE,
49         TAG_I,
50         TAG_SMALL,
51         TAG_SPAN,
52         TAG_VAR,
53         TAG_BR,
54         TAG_HR,
55         TAG_MARK,
56         TAG_MATH,
57         TAG_MROW,
58         TAG_MI,
59         TAG_MN,
60         TAG_MO,
61         TAG_MSUP,
62         TAG_MSUB,
63         TAG_MSUBSUP,
64         TAG_MFRAC,
65         TAG_MSQRT,
66         TAG_MFENCED,
67         TAG_MTABLE,
68         TAG_MTR,
69         TAG_MTD,
70         TAG_MUNDEROVER,
71         TAG_MUNDER,
72         TAG_MOVER,
73         TAG_MAX
74 };
75
76 struct  tag {
77         struct tag       *next;
78         int               refcnt;
79         int               closed;
80         enum htmltag      tag;
81 };
82
83 struct  html {
84         int               flags;
85 #define HTML_NOSPACE     (1 << 0) /* suppress next space */
86 #define HTML_IGNDELIM    (1 << 1)
87 #define HTML_KEEP        (1 << 2)
88 #define HTML_PREKEEP     (1 << 3)
89 #define HTML_NONOSPACE   (1 << 4) /* never add spaces */
90 #define HTML_SKIPCHAR    (1 << 6) /* skip the next character */
91 #define HTML_NOSPLIT     (1 << 7) /* do not break line before .An */
92 #define HTML_SPLIT       (1 << 8) /* break line before .An */
93 #define HTML_NONEWLINE   (1 << 9) /* No line break in nofill mode. */
94 #define HTML_BUFFER      (1 << 10) /* Collect a word to see if it fits. */
95 #define HTML_TOCDONE     (1 << 11) /* The TOC was already written. */
96         size_t            indent; /* current output indentation level */
97         int               noindent; /* indent disabled by <pre> */
98         size_t            col; /* current output byte position */
99         size_t            bufcol; /* current buf byte position */
100         char              buf[80]; /* output buffer */
101         struct tag       *tag; /* last open tag */
102         struct rofftbl    tbl; /* current table */
103         struct tag       *tblt; /* current open table scope */
104         char             *base_man1; /* bases for manpage href */
105         char             *base_man2;
106         char             *base_includes; /* base for include href */
107         char             *style; /* style-sheet URI */
108         struct tag       *metaf; /* current open font scope */
109         enum mandoc_esc   metal; /* last used font */
110         enum mandoc_esc   metac; /* current font mode */
111         int               oflags; /* output options */
112 #define HTML_FRAGMENT    (1 << 0) /* don't emit HTML/HEAD/BODY */
113 #define HTML_TOC         (1 << 1) /* emit a table of contents */
114 };
115
116
117 struct  roff_node;
118 struct  tbl_span;
119 struct  eqn_box;
120
121 void              roff_html_pre(struct html *, const struct roff_node *);
122
123 void              print_gen_comment(struct html *, struct roff_node *);
124 void              print_gen_decls(struct html *);
125 void              print_gen_head(struct html *);
126 struct tag       *print_otag(struct html *, enum htmltag, const char *, ...);
127 struct tag       *print_otag_id(struct html *, enum htmltag, const char *,
128                         struct roff_node *);
129 void              print_tagq(struct html *, const struct tag *);
130 void              print_stagq(struct html *, const struct tag *);
131 void              print_tagged_text(struct html *, const char *,
132                         struct roff_node *);
133 void              print_text(struct html *, const char *);
134 void              print_tblclose(struct html *);
135 void              print_tbl(struct html *, const struct tbl_span *);
136 void              print_eqn(struct html *, const struct eqn_box *);
137 void              print_endline(struct html *);
138
139 void              html_close_paragraph(struct html *);
140 enum roff_tok     html_fillmode(struct html *, enum roff_tok);
141 char             *html_make_id(const struct roff_node *, int);
142 int               html_setfont(struct html *, enum mandoc_esc);