version 1.212, 2014/11/27 16:20:31 |
version 1.228, 2015/04/02 22:48:17 |
|
|
/* $Id$ */ |
/* $Id$ */ |
/* |
/* |
* Copyright (c) 2008-2011, 2014 Kristaps Dzonsons <kristaps@bsd.lv> |
* Copyright (c) 2008-2011, 2014 Kristaps Dzonsons <kristaps@bsd.lv> |
* Copyright (c) 2014 Ingo Schwarze <schwarze@openbsd.org> |
* Copyright (c) 2014, 2015 Ingo Schwarze <schwarze@openbsd.org> |
* |
* |
* Permission to use, copy, modify, and distribute this software for any |
* Permission to use, copy, modify, and distribute this software for any |
* purpose with or without fee is hereby granted, provided that the above |
* purpose with or without fee is hereby granted, provided that the above |
* copyright notice and this permission notice appear in all copies. |
* copyright notice and this permission notice appear in all copies. |
* |
* |
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHORS DISCLAIM ALL WARRANTIES |
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR |
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
|
|
#include <string.h> |
#include <string.h> |
#include <unistd.h> |
#include <unistd.h> |
|
|
#include "mandoc.h" |
|
#include "mandoc_aux.h" |
#include "mandoc_aux.h" |
|
#include "roff.h" |
|
#include "mdoc.h" |
#include "out.h" |
#include "out.h" |
#include "html.h" |
#include "html.h" |
#include "mdoc.h" |
|
#include "main.h" |
#include "main.h" |
|
|
#define INDENT 5 |
#define INDENT 5 |
|
|
#define MDOC_ARGS const struct mdoc_meta *meta, \ |
#define MDOC_ARGS const struct mdoc_meta *meta, \ |
const struct mdoc_node *n, \ |
struct roff_node *n, \ |
struct html *h |
struct html *h |
|
|
#ifndef MIN |
#ifndef MIN |
Line 53 static void print_mdoc_head(MDOC_ARGS); |
|
Line 53 static void print_mdoc_head(MDOC_ARGS); |
|
static void print_mdoc_node(MDOC_ARGS); |
static void print_mdoc_node(MDOC_ARGS); |
static void print_mdoc_nodelist(MDOC_ARGS); |
static void print_mdoc_nodelist(MDOC_ARGS); |
static void synopsis_pre(struct html *, |
static void synopsis_pre(struct html *, |
const struct mdoc_node *); |
const struct roff_node *); |
|
|
static void a2width(const char *, struct roffsu *); |
static void a2width(const char *, struct roffsu *); |
|
|
Line 82 static int mdoc_fl_pre(MDOC_ARGS); |
|
Line 82 static int mdoc_fl_pre(MDOC_ARGS); |
|
static int mdoc_fn_pre(MDOC_ARGS); |
static int mdoc_fn_pre(MDOC_ARGS); |
static int mdoc_ft_pre(MDOC_ARGS); |
static int mdoc_ft_pre(MDOC_ARGS); |
static int mdoc_em_pre(MDOC_ARGS); |
static int mdoc_em_pre(MDOC_ARGS); |
|
static void mdoc_eo_post(MDOC_ARGS); |
|
static int mdoc_eo_pre(MDOC_ARGS); |
static int mdoc_er_pre(MDOC_ARGS); |
static int mdoc_er_pre(MDOC_ARGS); |
static int mdoc_ev_pre(MDOC_ARGS); |
static int mdoc_ev_pre(MDOC_ARGS); |
static int mdoc_ex_pre(MDOC_ARGS); |
static int mdoc_ex_pre(MDOC_ARGS); |
Line 190 static const struct htmlmdoc mdocs[MDOC_MAX] = { |
|
Line 192 static const struct htmlmdoc mdocs[MDOC_MAX] = { |
|
{NULL, NULL}, /* Ec */ /* FIXME: no space */ |
{NULL, NULL}, /* Ec */ /* FIXME: no space */ |
{NULL, NULL}, /* Ef */ |
{NULL, NULL}, /* Ef */ |
{mdoc_em_pre, NULL}, /* Em */ |
{mdoc_em_pre, NULL}, /* Em */ |
{mdoc_quote_pre, mdoc_quote_post}, /* Eo */ |
{mdoc_eo_pre, mdoc_eo_post}, /* Eo */ |
{mdoc_xx_pre, NULL}, /* Fx */ |
{mdoc_xx_pre, NULL}, /* Fx */ |
{mdoc_ms_pre, NULL}, /* Ms */ |
{mdoc_ms_pre, NULL}, /* Ms */ |
{mdoc_no_pre, NULL}, /* No */ |
{mdoc_no_pre, NULL}, /* No */ |
|
|
html_mdoc(void *arg, const struct mdoc *mdoc) |
html_mdoc(void *arg, const struct mdoc *mdoc) |
{ |
{ |
|
|
print_mdoc(mdoc_meta(mdoc), mdoc_node(mdoc), |
print_mdoc(mdoc_meta(mdoc), mdoc_node(mdoc)->child, |
(struct html *)arg); |
(struct html *)arg); |
putchar('\n'); |
putchar('\n'); |
} |
} |
|
|
a2width(const char *p, struct roffsu *su) |
a2width(const char *p, struct roffsu *su) |
{ |
{ |
|
|
if ( ! a2roffsu(p, su, SCALE_MAX)) { |
if (a2roffsu(p, su, SCALE_MAX) < 2) { |
su->unit = SCALE_EN; |
su->unit = SCALE_EN; |
su->scale = html_strlen(p); |
su->scale = html_strlen(p); |
} |
} else if (su->scale < 0.0) |
|
su->scale = 0.0; |
} |
} |
|
|
/* |
/* |
* See the same function in mdoc_term.c for documentation. |
* See the same function in mdoc_term.c for documentation. |
*/ |
*/ |
static void |
static void |
synopsis_pre(struct html *h, const struct mdoc_node *n) |
synopsis_pre(struct html *h, const struct roff_node *n) |
{ |
{ |
|
|
if (NULL == n->prev || ! (MDOC_SYNPRETTY & n->flags)) |
if (NULL == n->prev || ! (MDOC_SYNPRETTY & n->flags)) |
|
|
print_mdoc_nodelist(MDOC_ARGS) |
print_mdoc_nodelist(MDOC_ARGS) |
{ |
{ |
|
|
print_mdoc_node(meta, n, h); |
while (n != NULL) { |
if (n->next) |
print_mdoc_node(meta, n, h); |
print_mdoc_nodelist(meta, n->next, h); |
n = n->next; |
|
} |
} |
} |
|
|
static void |
static void |
Line 384 print_mdoc_node(MDOC_ARGS) |
|
Line 388 print_mdoc_node(MDOC_ARGS) |
|
|
|
child = 1; |
child = 1; |
t = h->tags.head; |
t = h->tags.head; |
|
n->flags &= ~MDOC_ENDED; |
|
|
switch (n->type) { |
switch (n->type) { |
case MDOC_ROOT: |
case ROFFT_ROOT: |
child = mdoc_root_pre(meta, n, h); |
child = mdoc_root_pre(meta, n, h); |
break; |
break; |
case MDOC_TEXT: |
case ROFFT_TEXT: |
/* No tables in this mode... */ |
/* No tables in this mode... */ |
assert(NULL == h->tblt); |
assert(NULL == h->tblt); |
|
|
Line 406 print_mdoc_node(MDOC_ARGS) |
|
Line 411 print_mdoc_node(MDOC_ARGS) |
|
if (MDOC_DELIMO & n->flags) |
if (MDOC_DELIMO & n->flags) |
h->flags |= HTML_NOSPACE; |
h->flags |= HTML_NOSPACE; |
return; |
return; |
case MDOC_EQN: |
case ROFFT_EQN: |
|
if (n->flags & MDOC_LINE) |
|
putchar('\n'); |
print_eqn(h, n->eqn); |
print_eqn(h, n->eqn); |
break; |
break; |
case MDOC_TBL: |
case ROFFT_TBL: |
/* |
/* |
* This will take care of initialising all of the table |
* This will take care of initialising all of the table |
* state data for the first table, then tearing it down |
* state data for the first table, then tearing it down |
Line 423 print_mdoc_node(MDOC_ARGS) |
|
Line 430 print_mdoc_node(MDOC_ARGS) |
|
* the "meta" table state. This will be reopened on the |
* the "meta" table state. This will be reopened on the |
* next table element. |
* next table element. |
*/ |
*/ |
if (h->tblt) { |
if (h->tblt != NULL) { |
print_tblclose(h); |
print_tblclose(h); |
t = h->tags.head; |
t = h->tags.head; |
} |
} |
|
assert(h->tblt == NULL); |
assert(NULL == h->tblt); |
if (mdocs[n->tok].pre && (n->end == ENDBODY_NOT || n->child)) |
if (mdocs[n->tok].pre && ENDBODY_NOT == n->end) |
|
child = (*mdocs[n->tok].pre)(meta, n, h); |
child = (*mdocs[n->tok].pre)(meta, n, h); |
break; |
break; |
} |
} |
|
|
if (HTML_KEEP & h->flags) { |
if (h->flags & HTML_KEEP && n->flags & MDOC_LINE) { |
if (n->prev ? (n->prev->lastline != n->line) : |
h->flags &= ~HTML_KEEP; |
(n->parent && n->parent->line != n->line)) { |
h->flags |= HTML_PREKEEP; |
h->flags &= ~HTML_KEEP; |
|
h->flags |= HTML_PREKEEP; |
|
} |
|
} |
} |
|
|
if (child && n->child) |
if (child && n->child) |
Line 448 print_mdoc_node(MDOC_ARGS) |
|
Line 451 print_mdoc_node(MDOC_ARGS) |
|
print_stagq(h, t); |
print_stagq(h, t); |
|
|
switch (n->type) { |
switch (n->type) { |
case MDOC_ROOT: |
case ROFFT_ROOT: |
mdoc_root_post(meta, n, h); |
mdoc_root_post(meta, n, h); |
break; |
break; |
case MDOC_EQN: |
case ROFFT_EQN: |
break; |
break; |
default: |
default: |
if (mdocs[n->tok].post && ENDBODY_NOT == n->end) |
if ( ! mdocs[n->tok].post || n->flags & MDOC_ENDED) |
(*mdocs[n->tok].post)(meta, n, h); |
break; |
|
(*mdocs[n->tok].post)(meta, n, h); |
|
if (n->end != ENDBODY_NOT) |
|
n->body->flags |= MDOC_ENDED; |
|
if (n->end == ENDBODY_NOSPACE) |
|
h->flags |= HTML_NOSPACE; |
break; |
break; |
} |
} |
} |
} |
Line 536 mdoc_sh_pre(MDOC_ARGS) |
|
Line 544 mdoc_sh_pre(MDOC_ARGS) |
|
struct htmlpair tag; |
struct htmlpair tag; |
|
|
switch (n->type) { |
switch (n->type) { |
case MDOC_BLOCK: |
case ROFFT_BLOCK: |
PAIR_CLASS_INIT(&tag, "section"); |
PAIR_CLASS_INIT(&tag, "section"); |
print_otag(h, TAG_DIV, 1, &tag); |
print_otag(h, TAG_DIV, 1, &tag); |
return(1); |
return(1); |
case MDOC_BODY: |
case ROFFT_BODY: |
if (n->sec == SEC_AUTHORS) |
if (n->sec == SEC_AUTHORS) |
h->flags &= ~(HTML_SPLIT|HTML_NOSPLIT); |
h->flags &= ~(HTML_SPLIT|HTML_NOSPLIT); |
return(1); |
return(1); |
Line 551 mdoc_sh_pre(MDOC_ARGS) |
|
Line 559 mdoc_sh_pre(MDOC_ARGS) |
|
bufinit(h); |
bufinit(h); |
bufcat(h, "x"); |
bufcat(h, "x"); |
|
|
for (n = n->child; n && MDOC_TEXT == n->type; ) { |
for (n = n->child; n != NULL && n->type == ROFFT_TEXT; ) { |
bufcat_id(h, n->string); |
bufcat_id(h, n->string); |
if (NULL != (n = n->next)) |
if (NULL != (n = n->next)) |
bufcat_id(h, " "); |
bufcat_id(h, " "); |
Line 571 mdoc_ss_pre(MDOC_ARGS) |
|
Line 579 mdoc_ss_pre(MDOC_ARGS) |
|
{ |
{ |
struct htmlpair tag; |
struct htmlpair tag; |
|
|
if (MDOC_BLOCK == n->type) { |
if (n->type == ROFFT_BLOCK) { |
PAIR_CLASS_INIT(&tag, "subsection"); |
PAIR_CLASS_INIT(&tag, "subsection"); |
print_otag(h, TAG_DIV, 1, &tag); |
print_otag(h, TAG_DIV, 1, &tag); |
return(1); |
return(1); |
} else if (MDOC_BODY == n->type) |
} else if (n->type == ROFFT_BODY) |
return(1); |
return(1); |
|
|
bufinit(h); |
bufinit(h); |
bufcat(h, "x"); |
bufcat(h, "x"); |
|
|
for (n = n->child; n && MDOC_TEXT == n->type; ) { |
for (n = n->child; n != NULL && n->type == ROFFT_TEXT; ) { |
bufcat_id(h, n->string); |
bufcat_id(h, n->string); |
if (NULL != (n = n->next)) |
if (NULL != (n = n->next)) |
bufcat_id(h, " "); |
bufcat_id(h, " "); |
Line 613 mdoc_fl_pre(MDOC_ARGS) |
|
Line 621 mdoc_fl_pre(MDOC_ARGS) |
|
|
|
if ( ! (n->nchild == 0 && |
if ( ! (n->nchild == 0 && |
(n->next == NULL || |
(n->next == NULL || |
n->next->type == MDOC_TEXT || |
n->next->type == ROFFT_TEXT || |
n->next->flags & MDOC_LINE))) |
n->next->flags & MDOC_LINE))) |
h->flags |= HTML_NOSPACE; |
h->flags |= HTML_NOSPACE; |
|
|
Line 625 mdoc_nd_pre(MDOC_ARGS) |
|
Line 633 mdoc_nd_pre(MDOC_ARGS) |
|
{ |
{ |
struct htmlpair tag; |
struct htmlpair tag; |
|
|
if (MDOC_BODY != n->type) |
if (n->type != ROFFT_BODY) |
return(1); |
return(1); |
|
|
/* XXX: this tag in theory can contain block elements. */ |
/* XXX: this tag in theory can contain block elements. */ |
Line 644 mdoc_nm_pre(MDOC_ARGS) |
|
Line 652 mdoc_nm_pre(MDOC_ARGS) |
|
int len; |
int len; |
|
|
switch (n->type) { |
switch (n->type) { |
case MDOC_ELEM: |
case ROFFT_ELEM: |
synopsis_pre(h, n); |
synopsis_pre(h, n); |
PAIR_CLASS_INIT(&tag, "name"); |
PAIR_CLASS_INIT(&tag, "name"); |
print_otag(h, TAG_B, 1, &tag); |
print_otag(h, TAG_B, 1, &tag); |
if (NULL == n->child && meta->name) |
if (NULL == n->child && meta->name) |
print_text(h, meta->name); |
print_text(h, meta->name); |
return(1); |
return(1); |
case MDOC_HEAD: |
case ROFFT_HEAD: |
print_otag(h, TAG_TD, 0, NULL); |
print_otag(h, TAG_TD, 0, NULL); |
if (NULL == n->child && meta->name) |
if (NULL == n->child && meta->name) |
print_text(h, meta->name); |
print_text(h, meta->name); |
return(1); |
return(1); |
case MDOC_BODY: |
case ROFFT_BODY: |
print_otag(h, TAG_TD, 0, NULL); |
print_otag(h, TAG_TD, 0, NULL); |
return(1); |
return(1); |
default: |
default: |
Line 668 mdoc_nm_pre(MDOC_ARGS) |
|
Line 676 mdoc_nm_pre(MDOC_ARGS) |
|
print_otag(h, TAG_TABLE, 1, &tag); |
print_otag(h, TAG_TABLE, 1, &tag); |
|
|
for (len = 0, n = n->child; n; n = n->next) |
for (len = 0, n = n->child; n; n = n->next) |
if (MDOC_TEXT == n->type) |
if (n->type == ROFFT_TEXT) |
len += html_strlen(n->string); |
len += html_strlen(n->string); |
|
|
if (0 == len && meta->name) |
if (0 == len && meta->name) |
Line 814 mdoc_it_pre(MDOC_ARGS) |
|
Line 822 mdoc_it_pre(MDOC_ARGS) |
|
struct roffsu su; |
struct roffsu su; |
enum mdoc_list type; |
enum mdoc_list type; |
struct htmlpair tag[2]; |
struct htmlpair tag[2]; |
const struct mdoc_node *bl; |
const struct roff_node *bl; |
|
|
bl = n->parent; |
bl = n->parent; |
while (bl && MDOC_Bl != bl->tok) |
while (bl && MDOC_Bl != bl->tok) |
Line 829 mdoc_it_pre(MDOC_ARGS) |
|
Line 837 mdoc_it_pre(MDOC_ARGS) |
|
|
|
bufinit(h); |
bufinit(h); |
|
|
if (MDOC_HEAD == n->type) { |
if (n->type == ROFFT_HEAD) { |
switch (type) { |
switch (type) { |
case LIST_bullet: |
case LIST_bullet: |
/* FALLTHROUGH */ |
/* FALLTHROUGH */ |
Line 864 mdoc_it_pre(MDOC_ARGS) |
|
Line 872 mdoc_it_pre(MDOC_ARGS) |
|
default: |
default: |
break; |
break; |
} |
} |
} else if (MDOC_BODY == n->type) { |
} else if (n->type == ROFFT_BODY) { |
switch (type) { |
switch (type) { |
case LIST_bullet: |
case LIST_bullet: |
/* FALLTHROUGH */ |
/* FALLTHROUGH */ |
Line 928 mdoc_bl_pre(MDOC_ARGS) |
|
Line 936 mdoc_bl_pre(MDOC_ARGS) |
|
struct roffsu su; |
struct roffsu su; |
char buf[BUFSIZ]; |
char buf[BUFSIZ]; |
|
|
if (MDOC_BODY == n->type) { |
if (n->type == ROFFT_BODY) { |
if (LIST_column == n->norm->Bl.type) |
if (LIST_column == n->norm->Bl.type) |
print_otag(h, TAG_TBODY, 0, NULL); |
print_otag(h, TAG_TBODY, 0, NULL); |
return(1); |
return(1); |
} |
} |
|
|
if (MDOC_HEAD == n->type) { |
if (n->type == ROFFT_HEAD) { |
if (LIST_column != n->norm->Bl.type) |
if (LIST_column != n->norm->Bl.type) |
return(0); |
return(0); |
|
|
Line 1028 mdoc_ex_pre(MDOC_ARGS) |
|
Line 1036 mdoc_ex_pre(MDOC_ARGS) |
|
|
|
nchild = n->nchild; |
nchild = n->nchild; |
for (n = n->child; n; n = n->next) { |
for (n = n->child; n; n = n->next) { |
assert(MDOC_TEXT == n->type); |
assert(n->type == ROFFT_TEXT); |
|
|
t = print_otag(h, TAG_B, 1, &tag); |
t = print_otag(h, TAG_B, 1, &tag); |
print_text(h, n->string); |
print_text(h, n->string); |
Line 1068 mdoc_d1_pre(MDOC_ARGS) |
|
Line 1076 mdoc_d1_pre(MDOC_ARGS) |
|
struct htmlpair tag[2]; |
struct htmlpair tag[2]; |
struct roffsu su; |
struct roffsu su; |
|
|
if (MDOC_BLOCK != n->type) |
if (n->type != ROFFT_BLOCK) |
return(1); |
return(1); |
|
|
SCALE_VS_INIT(&su, 0); |
SCALE_VS_INIT(&su, 0); |
Line 1118 mdoc_bd_pre(MDOC_ARGS) |
|
Line 1126 mdoc_bd_pre(MDOC_ARGS) |
|
{ |
{ |
struct htmlpair tag[2]; |
struct htmlpair tag[2]; |
int comp, sv; |
int comp, sv; |
const struct mdoc_node *nn; |
struct roff_node *nn; |
struct roffsu su; |
struct roffsu su; |
|
|
if (MDOC_HEAD == n->type) |
if (n->type == ROFFT_HEAD) |
return(0); |
return(0); |
|
|
if (MDOC_BLOCK == n->type) { |
if (n->type == ROFFT_BLOCK) { |
comp = n->norm->Bd.comp; |
comp = n->norm->Bd.comp; |
for (nn = n; nn && ! comp; nn = nn->parent) { |
for (nn = n; nn && ! comp; nn = nn->parent) { |
if (MDOC_BLOCK != nn->type) |
if (nn->type != ROFFT_BLOCK) |
continue; |
continue; |
if (MDOC_Ss == nn->tok || MDOC_Sh == nn->tok) |
if (MDOC_Ss == nn->tok || MDOC_Sh == nn->tok) |
comp = 1; |
comp = 1; |
Line 1198 mdoc_bd_pre(MDOC_ARGS) |
|
Line 1206 mdoc_bd_pre(MDOC_ARGS) |
|
default: |
default: |
break; |
break; |
} |
} |
if (nn->next && nn->next->line == nn->line) |
if (h->flags & HTML_NONEWLINE || |
|
(nn->next && ! (nn->next->flags & MDOC_LINE))) |
continue; |
continue; |
else if (nn->next) |
else if (nn->next) |
print_text(h, "\n"); |
print_text(h, "\n"); |
Line 1248 mdoc_an_pre(MDOC_ARGS) |
|
Line 1257 mdoc_an_pre(MDOC_ARGS) |
|
return(0); |
return(0); |
} |
} |
|
|
if (n->child == NULL) |
|
return(0); |
|
|
|
if (h->flags & HTML_SPLIT) |
if (h->flags & HTML_SPLIT) |
print_otag(h, TAG_BR, 0, NULL); |
print_otag(h, TAG_BR, 0, NULL); |
|
|
Line 1306 mdoc_er_pre(MDOC_ARGS) |
|
Line 1312 mdoc_er_pre(MDOC_ARGS) |
|
static int |
static int |
mdoc_fa_pre(MDOC_ARGS) |
mdoc_fa_pre(MDOC_ARGS) |
{ |
{ |
const struct mdoc_node *nn; |
const struct roff_node *nn; |
struct htmlpair tag; |
struct htmlpair tag; |
struct tag *t; |
struct tag *t; |
|
|
Line 1348 mdoc_fd_pre(MDOC_ARGS) |
|
Line 1354 mdoc_fd_pre(MDOC_ARGS) |
|
if (NULL == (n = n->child)) |
if (NULL == (n = n->child)) |
return(0); |
return(0); |
|
|
assert(MDOC_TEXT == n->type); |
assert(n->type == ROFFT_TEXT); |
|
|
if (strcmp(n->string, "#include")) { |
if (strcmp(n->string, "#include")) { |
PAIR_CLASS_INIT(&tag[0], "macro"); |
PAIR_CLASS_INIT(&tag[0], "macro"); |
Line 1361 mdoc_fd_pre(MDOC_ARGS) |
|
Line 1367 mdoc_fd_pre(MDOC_ARGS) |
|
print_text(h, n->string); |
print_text(h, n->string); |
|
|
if (NULL != (n = n->next)) { |
if (NULL != (n = n->next)) { |
assert(MDOC_TEXT == n->type); |
assert(n->type == ROFFT_TEXT); |
|
|
/* |
/* |
* XXX This is broken and not easy to fix. |
* XXX This is broken and not easy to fix. |
Line 1395 mdoc_fd_pre(MDOC_ARGS) |
|
Line 1401 mdoc_fd_pre(MDOC_ARGS) |
|
} |
} |
|
|
for ( ; n; n = n->next) { |
for ( ; n; n = n->next) { |
assert(MDOC_TEXT == n->type); |
assert(n->type == ROFFT_TEXT); |
print_text(h, n->string); |
print_text(h, n->string); |
} |
} |
|
|
Line 1407 mdoc_vt_pre(MDOC_ARGS) |
|
Line 1413 mdoc_vt_pre(MDOC_ARGS) |
|
{ |
{ |
struct htmlpair tag; |
struct htmlpair tag; |
|
|
if (MDOC_BLOCK == n->type) { |
if (n->type == ROFFT_BLOCK) { |
synopsis_pre(h, n); |
synopsis_pre(h, n); |
return(1); |
return(1); |
} else if (MDOC_ELEM == n->type) { |
} else if (n->type == ROFFT_ELEM) { |
synopsis_pre(h, n); |
synopsis_pre(h, n); |
} else if (MDOC_HEAD == n->type) |
} else if (n->type == ROFFT_HEAD) |
return(0); |
return(0); |
|
|
PAIR_CLASS_INIT(&tag, "type"); |
PAIR_CLASS_INIT(&tag, "type"); |
Line 1562 mdoc_sp_pre(MDOC_ARGS) |
|
Line 1568 mdoc_sp_pre(MDOC_ARGS) |
|
SCALE_VS_INIT(&su, 1); |
SCALE_VS_INIT(&su, 1); |
|
|
if (MDOC_sp == n->tok) { |
if (MDOC_sp == n->tok) { |
if (NULL != (n = n->child)) |
if (NULL != (n = n->child)) { |
if ( ! a2roffsu(n->string, &su, SCALE_VS)) |
if ( ! a2roffsu(n->string, &su, SCALE_VS)) |
SCALE_VS_INIT(&su, atoi(n->string)); |
su.scale = 1.0; |
|
else if (su.scale < 0.0) |
|
su.scale = 0.0; |
|
} |
} else |
} else |
su.scale = 0.0; |
su.scale = 0.0; |
|
|
Line 1588 mdoc_lk_pre(MDOC_ARGS) |
|
Line 1597 mdoc_lk_pre(MDOC_ARGS) |
|
if (NULL == (n = n->child)) |
if (NULL == (n = n->child)) |
return(0); |
return(0); |
|
|
assert(MDOC_TEXT == n->type); |
assert(n->type == ROFFT_TEXT); |
|
|
PAIR_CLASS_INIT(&tag[0], "link-ext"); |
PAIR_CLASS_INIT(&tag[0], "link-ext"); |
PAIR_HREF_INIT(&tag[1], n->string); |
PAIR_HREF_INIT(&tag[1], n->string); |
Line 1613 mdoc_mt_pre(MDOC_ARGS) |
|
Line 1622 mdoc_mt_pre(MDOC_ARGS) |
|
PAIR_CLASS_INIT(&tag[0], "link-mail"); |
PAIR_CLASS_INIT(&tag[0], "link-mail"); |
|
|
for (n = n->child; n; n = n->next) { |
for (n = n->child; n; n = n->next) { |
assert(MDOC_TEXT == n->type); |
assert(n->type == ROFFT_TEXT); |
|
|
bufinit(h); |
bufinit(h); |
bufcat(h, "mailto:"); |
bufcat(h, "mailto:"); |
Line 1634 mdoc_fo_pre(MDOC_ARGS) |
|
Line 1643 mdoc_fo_pre(MDOC_ARGS) |
|
struct htmlpair tag; |
struct htmlpair tag; |
struct tag *t; |
struct tag *t; |
|
|
if (MDOC_BODY == n->type) { |
if (n->type == ROFFT_BODY) { |
h->flags |= HTML_NOSPACE; |
h->flags |= HTML_NOSPACE; |
print_text(h, "("); |
print_text(h, "("); |
h->flags |= HTML_NOSPACE; |
h->flags |= HTML_NOSPACE; |
return(1); |
return(1); |
} else if (MDOC_BLOCK == n->type) { |
} else if (n->type == ROFFT_BLOCK) { |
synopsis_pre(h, n); |
synopsis_pre(h, n); |
return(1); |
return(1); |
} |
} |
|
|
mdoc_fo_post(MDOC_ARGS) |
mdoc_fo_post(MDOC_ARGS) |
{ |
{ |
|
|
if (MDOC_BODY != n->type) |
if (n->type != ROFFT_BODY) |
return; |
return; |
h->flags |= HTML_NOSPACE; |
h->flags |= HTML_NOSPACE; |
print_text(h, ")"); |
print_text(h, ")"); |
Line 1694 mdoc_in_pre(MDOC_ARGS) |
|
Line 1703 mdoc_in_pre(MDOC_ARGS) |
|
h->flags |= HTML_NOSPACE; |
h->flags |= HTML_NOSPACE; |
|
|
if (NULL != (n = n->child)) { |
if (NULL != (n = n->child)) { |
assert(MDOC_TEXT == n->type); |
assert(n->type == ROFFT_TEXT); |
|
|
PAIR_CLASS_INIT(&tag[0], "link-includes"); |
PAIR_CLASS_INIT(&tag[0], "link-includes"); |
|
|
Line 1716 mdoc_in_pre(MDOC_ARGS) |
|
Line 1725 mdoc_in_pre(MDOC_ARGS) |
|
print_text(h, ">"); |
print_text(h, ">"); |
|
|
for ( ; n; n = n->next) { |
for ( ; n; n = n->next) { |
assert(MDOC_TEXT == n->type); |
assert(n->type == ROFFT_TEXT); |
print_text(h, n->string); |
print_text(h, n->string); |
} |
} |
|
|
Line 1815 mdoc_bf_pre(MDOC_ARGS) |
|
Line 1824 mdoc_bf_pre(MDOC_ARGS) |
|
struct htmlpair tag[2]; |
struct htmlpair tag[2]; |
struct roffsu su; |
struct roffsu su; |
|
|
if (MDOC_HEAD == n->type) |
if (n->type == ROFFT_HEAD) |
return(0); |
return(0); |
else if (MDOC_BODY != n->type) |
else if (n->type != ROFFT_BODY) |
return(1); |
return(1); |
|
|
if (FONT_Em == n->norm->Bf.font) |
if (FONT_Em == n->norm->Bf.font) |
|
|
mdoc_pf_post(MDOC_ARGS) |
mdoc_pf_post(MDOC_ARGS) |
{ |
{ |
|
|
h->flags |= HTML_NOSPACE; |
if ( ! (n->next == NULL || n->next->flags & MDOC_LINE)) |
|
h->flags |= HTML_NOSPACE; |
} |
} |
|
|
static int |
static int |
Line 1873 mdoc_rs_pre(MDOC_ARGS) |
|
Line 1883 mdoc_rs_pre(MDOC_ARGS) |
|
{ |
{ |
struct htmlpair tag; |
struct htmlpair tag; |
|
|
if (MDOC_BLOCK != n->type) |
if (n->type != ROFFT_BLOCK) |
return(1); |
return(1); |
|
|
if (n->prev && SEC_SEE_ALSO == n->sec) |
if (n->prev && SEC_SEE_ALSO == n->sec) |
Line 2039 mdoc_bk_pre(MDOC_ARGS) |
|
Line 2049 mdoc_bk_pre(MDOC_ARGS) |
|
{ |
{ |
|
|
switch (n->type) { |
switch (n->type) { |
case MDOC_BLOCK: |
case ROFFT_BLOCK: |
break; |
break; |
case MDOC_HEAD: |
case ROFFT_HEAD: |
return(0); |
return(0); |
case MDOC_BODY: |
case ROFFT_BODY: |
if (n->parent->args || 0 == n->prev->nchild) |
if (n->parent->args || 0 == n->prev->nchild) |
h->flags |= HTML_PREKEEP; |
h->flags |= HTML_PREKEEP; |
break; |
break; |
|
|
mdoc_bk_post(MDOC_ARGS) |
mdoc_bk_post(MDOC_ARGS) |
{ |
{ |
|
|
if (MDOC_BODY == n->type) |
if (n->type == ROFFT_BODY) |
h->flags &= ~(HTML_KEEP | HTML_PREKEEP); |
h->flags &= ~(HTML_KEEP | HTML_PREKEEP); |
} |
} |
|
|
Line 2068 mdoc_quote_pre(MDOC_ARGS) |
|
Line 2078 mdoc_quote_pre(MDOC_ARGS) |
|
{ |
{ |
struct htmlpair tag; |
struct htmlpair tag; |
|
|
if (MDOC_BODY != n->type) |
if (n->type != ROFFT_BODY) |
return(1); |
return(1); |
|
|
switch (n->tok) { |
switch (n->tok) { |
case MDOC_Ao: |
case MDOC_Ao: |
/* FALLTHROUGH */ |
/* FALLTHROUGH */ |
case MDOC_Aq: |
case MDOC_Aq: |
print_text(h, n->parent->prev != NULL && |
print_text(h, n->nchild == 1 && |
n->parent->prev->tok == MDOC_An ? "<" : "\\(la"); |
n->child->tok == MDOC_Mt ? "<" : "\\(la"); |
break; |
break; |
case MDOC_Bro: |
case MDOC_Bro: |
/* FALLTHROUGH */ |
/* FALLTHROUGH */ |
Line 2102 mdoc_quote_pre(MDOC_ARGS) |
|
Line 2112 mdoc_quote_pre(MDOC_ARGS) |
|
return(1); |
return(1); |
print_text(h, n->norm->Es->child->string); |
print_text(h, n->norm->Es->child->string); |
break; |
break; |
case MDOC_Eo: |
|
break; |
|
case MDOC_Do: |
case MDOC_Do: |
/* FALLTHROUGH */ |
/* FALLTHROUGH */ |
case MDOC_Dq: |
case MDOC_Dq: |
|
|
mdoc_quote_post(MDOC_ARGS) |
mdoc_quote_post(MDOC_ARGS) |
{ |
{ |
|
|
if (MDOC_BODY != n->type) |
if (n->type != ROFFT_BODY && n->type != ROFFT_ELEM) |
return; |
return; |
|
|
if (MDOC_En != n->tok) |
h->flags |= HTML_NOSPACE; |
h->flags |= HTML_NOSPACE; |
|
|
|
switch (n->tok) { |
switch (n->tok) { |
case MDOC_Ao: |
case MDOC_Ao: |
/* FALLTHROUGH */ |
/* FALLTHROUGH */ |
case MDOC_Aq: |
case MDOC_Aq: |
print_text(h, n->parent->prev != NULL && |
print_text(h, n->nchild == 1 && |
n->parent->prev->tok == MDOC_An ? ">" : "\\(ra"); |
n->child->tok == MDOC_Mt ? ">" : "\\(ra"); |
break; |
break; |
case MDOC_Bro: |
case MDOC_Bro: |
/* FALLTHROUGH */ |
/* FALLTHROUGH */ |
Line 2170 mdoc_quote_post(MDOC_ARGS) |
|
Line 2177 mdoc_quote_post(MDOC_ARGS) |
|
print_text(h, "\\(rB"); |
print_text(h, "\\(rB"); |
break; |
break; |
case MDOC_En: |
case MDOC_En: |
if (NULL != n->norm->Es && |
if (n->norm->Es == NULL || |
NULL != n->norm->Es->child && |
n->norm->Es->child == NULL || |
NULL != n->norm->Es->child->next) { |
n->norm->Es->child->next == NULL) |
h->flags |= HTML_NOSPACE; |
h->flags &= ~HTML_NOSPACE; |
|
else |
print_text(h, n->norm->Es->child->next->string); |
print_text(h, n->norm->Es->child->next->string); |
} |
|
break; |
break; |
case MDOC_Eo: |
|
break; |
|
case MDOC_Qo: |
case MDOC_Qo: |
/* FALLTHROUGH */ |
/* FALLTHROUGH */ |
case MDOC_Qq: |
case MDOC_Qq: |
Line 2204 mdoc_quote_post(MDOC_ARGS) |
|
Line 2209 mdoc_quote_post(MDOC_ARGS) |
|
abort(); |
abort(); |
/* NOTREACHED */ |
/* NOTREACHED */ |
} |
} |
|
} |
|
|
|
static int |
|
mdoc_eo_pre(MDOC_ARGS) |
|
{ |
|
|
|
if (n->type != ROFFT_BODY) |
|
return(1); |
|
|
|
if (n->end == ENDBODY_NOT && |
|
n->parent->head->child == NULL && |
|
n->child != NULL && |
|
n->child->end != ENDBODY_NOT) |
|
print_text(h, "\\&"); |
|
else if (n->end != ENDBODY_NOT ? n->child != NULL : |
|
n->parent->head->child != NULL && (n->child != NULL || |
|
(n->parent->tail != NULL && n->parent->tail->child != NULL))) |
|
h->flags |= HTML_NOSPACE; |
|
return(1); |
|
} |
|
|
|
static void |
|
mdoc_eo_post(MDOC_ARGS) |
|
{ |
|
int body, tail; |
|
|
|
if (n->type != ROFFT_BODY) |
|
return; |
|
|
|
if (n->end != ENDBODY_NOT) { |
|
h->flags &= ~HTML_NOSPACE; |
|
return; |
|
} |
|
|
|
body = n->child != NULL || n->parent->head->child != NULL; |
|
tail = n->parent->tail != NULL && n->parent->tail->child != NULL; |
|
|
|
if (body && tail) |
|
h->flags |= HTML_NOSPACE; |
|
else if ( ! tail) |
|
h->flags &= ~HTML_NOSPACE; |
} |
} |