Annotation of mandoc/roff_validate.c, Revision 1.6
1.6 ! schwarze 1: /* $Id$ */
1.1 schwarze 2: /*
3: * Copyright (c) 2010, 2017 Ingo Schwarze <schwarze@openbsd.org>
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: #include <sys/types.h>
18:
19: #include <assert.h>
20: #include <stddef.h>
21:
22: #include "mandoc.h"
23: #include "roff.h"
24: #include "libmandoc.h"
25: #include "roff_int.h"
26:
27: #define ROFF_VALID_ARGS struct roff_man *man, struct roff_node *n
28:
29: typedef void (*roff_valid_fp)(ROFF_VALID_ARGS);
30:
31: static void roff_valid_ft(ROFF_VALID_ARGS);
32:
33: static const roff_valid_fp roff_valids[ROFF_MAX] = {
34: NULL, /* br */
35: roff_valid_ft, /* ft */
1.2 schwarze 36: NULL, /* ll */
1.6 ! schwarze 37: NULL, /* mc */
1.3 schwarze 38: NULL, /* sp */
1.4 schwarze 39: NULL, /* ta */
1.5 schwarze 40: NULL, /* ti */
1.1 schwarze 41: };
42:
43:
44: void
45: roff_validate(struct roff_man *man)
46: {
47: struct roff_node *n;
48:
49: n = man->last;
50: assert(n->tok < ROFF_MAX);
51: if (roff_valids[n->tok] != NULL)
52: (*roff_valids[n->tok])(man, n);
53: }
54:
55: static void
56: roff_valid_ft(ROFF_VALID_ARGS)
57: {
58: char *cp;
59:
60: if (n->child == NULL) {
61: man->next = ROFF_NEXT_CHILD;
62: roff_word_alloc(man, n->line, n->pos, "P");
63: man->last = n;
64: return;
65: }
66:
67: cp = n->child->string;
68: switch (*cp) {
69: case '1':
70: case '2':
71: case '3':
72: case '4':
73: case 'I':
74: case 'P':
75: case 'R':
76: if (cp[1] == '\0')
77: return;
78: break;
79: case 'B':
80: if (cp[1] == '\0' || (cp[1] == 'I' && cp[2] == '\0'))
81: return;
82: break;
83: case 'C':
84: if (cp[1] == 'W' && cp[2] == '\0')
85: return;
86: break;
87: default:
88: break;
89: }
90:
91: mandoc_vmsg(MANDOCERR_FT_BAD, man->parse,
92: n->line, n->pos, "ft %s", cp);
93: roff_node_delete(man, n);
94: }
CVSweb