xref: /openbsd/usr.bin/mandoc/html.h (revision e5dd7070)
1 /* $OpenBSD: html.h,v 1.70 2020/04/18 20:28:46 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_MARK,
55 	TAG_MATH,
56 	TAG_MROW,
57 	TAG_MI,
58 	TAG_MN,
59 	TAG_MO,
60 	TAG_MSUP,
61 	TAG_MSUB,
62 	TAG_MSUBSUP,
63 	TAG_MFRAC,
64 	TAG_MSQRT,
65 	TAG_MFENCED,
66 	TAG_MTABLE,
67 	TAG_MTR,
68 	TAG_MTD,
69 	TAG_MUNDEROVER,
70 	TAG_MUNDER,
71 	TAG_MOVER,
72 	TAG_MAX
73 };
74 
75 struct	tag {
76 	struct tag	 *next;
77 	int		  refcnt;
78 	int		  closed;
79 	enum htmltag	  tag;
80 };
81 
82 struct	html {
83 	int		  flags;
84 #define	HTML_NOSPACE	 (1 << 0) /* suppress next space */
85 #define	HTML_IGNDELIM	 (1 << 1)
86 #define	HTML_KEEP	 (1 << 2)
87 #define	HTML_PREKEEP	 (1 << 3)
88 #define	HTML_NONOSPACE	 (1 << 4) /* never add spaces */
89 #define	HTML_SKIPCHAR	 (1 << 6) /* skip the next character */
90 #define	HTML_NOSPLIT	 (1 << 7) /* do not break line before .An */
91 #define	HTML_SPLIT	 (1 << 8) /* break line before .An */
92 #define	HTML_NONEWLINE	 (1 << 9) /* No line break in nofill mode. */
93 #define	HTML_BUFFER	 (1 << 10) /* Collect a word to see if it fits. */
94 #define	HTML_TOCDONE	 (1 << 11) /* The TOC was already written. */
95 	size_t		  indent; /* current output indentation level */
96 	int		  noindent; /* indent disabled by <pre> */
97 	size_t		  col; /* current output byte position */
98 	size_t		  bufcol; /* current buf byte position */
99 	char		  buf[80]; /* output buffer */
100 	struct tag	 *tag; /* last open tag */
101 	struct rofftbl	  tbl; /* current table */
102 	struct tag	 *tblt; /* current open table scope */
103 	char		 *base_man1; /* bases for manpage href */
104 	char		 *base_man2;
105 	char		 *base_includes; /* base for include href */
106 	char		 *style; /* style-sheet URI */
107 	struct tag	 *metaf; /* current open font scope */
108 	enum mandoc_esc	  metal; /* last used font */
109 	enum mandoc_esc	  metac; /* current font mode */
110 	int		  oflags; /* output options */
111 #define	HTML_FRAGMENT	 (1 << 0) /* don't emit HTML/HEAD/BODY */
112 #define	HTML_TOC	 (1 << 1) /* emit a table of contents */
113 };
114 
115 
116 struct	roff_node;
117 struct	tbl_span;
118 struct	eqn_box;
119 
120 void		  roff_html_pre(struct html *, const struct roff_node *);
121 
122 void		  print_gen_comment(struct html *, struct roff_node *);
123 void		  print_gen_decls(struct html *);
124 void		  print_gen_head(struct html *);
125 struct tag	 *print_otag(struct html *, enum htmltag, const char *, ...);
126 struct tag	 *print_otag_id(struct html *, enum htmltag, const char *,
127 			struct roff_node *);
128 void		  print_tagq(struct html *, const struct tag *);
129 void		  print_stagq(struct html *, const struct tag *);
130 void		  print_tagged_text(struct html *, const char *,
131 			struct roff_node *);
132 void		  print_text(struct html *, const char *);
133 void		  print_tblclose(struct html *);
134 void		  print_tbl(struct html *, const struct tbl_span *);
135 void		  print_eqn(struct html *, const struct eqn_box *);
136 void		  print_endline(struct html *);
137 
138 void		  html_close_paragraph(struct html *);
139 enum roff_tok	  html_fillmode(struct html *, enum roff_tok);
140 char		 *html_make_id(const struct roff_node *, int);
141 int		  html_setfont(struct html *, enum mandoc_esc);
142