1 /* $Id: tree.c,v 1.53 2014/07/02 07:10:38 schwarze Exp $ */
3 * Copyright (c) 2008, 2009, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
4 * Copyright (c) 2013, 2014 Ingo Schwarze <schwarze@openbsd.org>
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.
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.
33 static void print_box(const struct eqn_box
*, int);
34 static void print_man(const struct man_node
*, int);
35 static void print_mdoc(const struct mdoc_node
*, int);
36 static void print_span(const struct tbl_span
*, int);
40 tree_mdoc(void *arg
, const struct mdoc
*mdoc
)
43 print_mdoc(mdoc_node(mdoc
), 0);
47 tree_man(void *arg
, const struct man
*man
)
50 print_man(man_node(man
), 0);
54 print_mdoc(const struct mdoc_node
*n
, int indent
)
59 struct mdoc_argv
*argv
;
104 p
= mdoc_macronames
[n
->tok
];
107 p
= mdoc_macronames
[n
->tok
];
110 p
= mdoc_macronames
[n
->tok
];
113 p
= mdoc_macronames
[n
->tok
];
115 argv
= n
->args
->argv
;
116 argc
= n
->args
->argc
;
120 p
= mdoc_macronames
[n
->tok
];
122 argv
= n
->args
->argv
;
123 argc
= n
->args
->argc
;
139 assert(NULL
== p
&& NULL
== t
);
140 print_span(n
->span
, indent
);
142 assert(NULL
== p
&& NULL
== t
);
143 print_box(n
->eqn
->root
, indent
);
145 for (i
= 0; i
< indent
; i
++)
148 printf("%s (%s)", p
, t
);
150 for (i
= 0; i
< (int)argc
; i
++) {
151 printf(" -%s", mdoc_argnames
[argv
[i
].arg
]);
154 for (j
= 0; j
< (int)argv
[i
].sz
; j
++)
155 printf(" [%s]", argv
[i
].value
[j
]);
161 if (MDOC_LINE
& n
->flags
)
163 printf("%d:%d", n
->line
, n
->pos
+ 1);
164 if (n
->lastline
!= n
->line
)
165 printf("-%d", n
->lastline
);
170 print_mdoc(n
->child
, indent
+ 1);
172 print_mdoc(n
->next
, indent
);
176 print_man(const struct man_node
*n
, int indent
)
227 p
= man_macronames
[n
->tok
];
242 assert(NULL
== p
&& NULL
== t
);
243 print_span(n
->span
, indent
);
245 assert(NULL
== p
&& NULL
== t
);
246 print_box(n
->eqn
->root
, indent
);
248 for (i
= 0; i
< indent
; i
++)
250 printf("%s (%s) ", p
, t
);
251 if (MAN_LINE
& n
->flags
)
253 printf("%d:%d\n", n
->line
, n
->pos
+ 1);
257 print_man(n
->child
, indent
+ 1);
259 print_man(n
->next
, indent
);
263 print_box(const struct eqn_box
*ep
, int indent
)
270 for (i
= 0; i
< indent
; i
++)
293 printf("%s(%d, %d, %d, %d, %d, \"%s\", \"%s\") %s\n",
294 t
, EQN_DEFSIZE
== ep
->size
? 0 : ep
->size
,
295 ep
->pos
+ 1, ep
->font
, ep
->mark
, ep
->pile
,
296 ep
->left
? ep
->left
: "",
297 ep
->right
? ep
->right
: "",
298 ep
->text
? ep
->text
: "");
300 print_box(ep
->first
, indent
+ 1);
301 print_box(ep
->next
, indent
);
305 print_span(const struct tbl_span
*sp
, int indent
)
307 const struct tbl_dat
*dp
;
310 for (i
= 0; i
< indent
; i
++)
317 case TBL_SPAN_DHORIZ
:
324 for (dp
= sp
->first
; dp
; dp
= dp
->next
) {
328 case TBL_DATA_NHORIZ
:
331 case TBL_DATA_DHORIZ
:
333 case TBL_DATA_NDHORIZ
:
339 printf("[\"%s\"", dp
->string
? dp
->string
: "");
341 printf("(%d)", dp
->spans
);
342 if (NULL
== dp
->layout
)
348 printf("(tbl) %d:1\n", sp
->line
);