diff options
author | Kristaps Dzonsons <kristaps@bsd.lv> | 2011-04-04 16:48:18 +0000 |
---|---|---|
committer | Kristaps Dzonsons <kristaps@bsd.lv> | 2011-04-04 16:48:18 +0000 |
commit | d5a7714d266d3c899764ccc8fed227d6c2c98f32 (patch) | |
tree | 98d8a836fe623c596409dc731d98cbc08885d4f5 /mdoc_html.c | |
parent | 77be3823bab219163ead178ad2719d16ea5ebe77 (diff) | |
download | mandoc-d5a7714d266d3c899764ccc8fed227d6c2c98f32.tar.gz |
Have `Fd' in -T[x]html generate an "include" link if it detects one
being used.
Diffstat (limited to 'mdoc_html.c')
-rw-r--r-- | mdoc_html.c | 56 |
1 files changed, 52 insertions, 4 deletions
diff --git a/mdoc_html.c b/mdoc_html.c index 3039edeb..c5505071 100644 --- a/mdoc_html.c +++ b/mdoc_html.c @@ -1405,13 +1405,61 @@ mdoc_fa_pre(MDOC_ARGS) static int mdoc_fd_pre(MDOC_ARGS) { - struct htmlpair tag; + struct htmlpair tag[2]; + char buf[BUFSIZ]; + size_t sz; + int i; + struct tag *t; synopsis_pre(h, n); - PAIR_CLASS_INIT(&tag, "macro"); - print_otag(h, TAG_B, 1, &tag); - return(1); + if (NULL == (n = n->child)) + return(0); + + assert(MDOC_TEXT == n->type); + + if (strcmp(n->string, "#include")) { + PAIR_CLASS_INIT(&tag[0], "macro"); + print_otag(h, TAG_B, 1, tag); + return(1); + } + + PAIR_CLASS_INIT(&tag[0], "includes"); + print_otag(h, TAG_B, 1, tag); + print_text(h, n->string); + + if (NULL != (n = n->next)) { + assert(MDOC_TEXT == n->type); + strlcpy(buf, '<' == *n->string || '"' == *n->string ? + n->string + 1 : n->string, BUFSIZ); + + sz = strlen(buf); + if (sz && ('>' == buf[sz - 1] || '"' == buf[sz - 1])) + buf[sz - 1] = '\0'; + + PAIR_CLASS_INIT(&tag[0], "link-includes"); + bufinit(h); + + i = 1; + if (h->base_includes) { + buffmt_includes(h, buf); + PAIR_HREF_INIT(&tag[i], h->buf); + i++; + } + + t = print_otag(h, TAG_A, i, tag); + print_text(h, n->string); + print_tagq(h, t); + + n = n->next; + } + + for ( ; n; n = n->next) { + assert(MDOC_TEXT == n->type); + print_text(h, n->string); + } + + return(0); } |