version 1.24, 2009/11/16 08:46:59 |
version 1.28, 2010/03/22 14:03:03 |
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
*/ |
*/ |
|
#ifdef HAVE_CONFIG_H |
|
#include "config.h" |
|
#endif |
|
|
#include <sys/types.h> |
#include <sys/types.h> |
|
|
#include <assert.h> |
#include <assert.h> |
Line 66 static int man_SH_pre(MAN_ARGS); |
|
Line 70 static int man_SH_pre(MAN_ARGS); |
|
static int man_SM_pre(MAN_ARGS); |
static int man_SM_pre(MAN_ARGS); |
static int man_SS_pre(MAN_ARGS); |
static int man_SS_pre(MAN_ARGS); |
|
|
#ifdef __linux__ |
|
extern size_t strlcpy(char *, const char *, size_t); |
|
extern size_t strlcat(char *, const char *, size_t); |
|
#endif |
|
|
|
static const struct htmlman mans[MAN_MAX] = { |
static const struct htmlman mans[MAN_MAX] = { |
{ man_br_pre, NULL }, /* br */ |
{ man_br_pre, NULL }, /* br */ |
{ NULL, NULL }, /* TH */ |
{ NULL, NULL }, /* TH */ |
Line 115 html_man(void *arg, const struct man *m) |
|
Line 114 html_man(void *arg, const struct man *m) |
|
|
|
h = (struct html *)arg; |
h = (struct html *)arg; |
|
|
print_gen_doctype(h); |
print_gen_decls(h); |
|
|
t = print_otag(h, TAG_HTML, 0, NULL); |
t = print_otag(h, TAG_HTML, 0, NULL); |
print_man(man_meta(m), man_node(m), h); |
print_man(man_meta(m), man_node(m), h); |
Line 182 print_man_node(MAN_ARGS) |
|
Line 181 print_man_node(MAN_ARGS) |
|
|
|
bufinit(h); |
bufinit(h); |
|
|
|
/* |
|
* FIXME: embedded elements within next-line scopes (e.g., `br' |
|
* within an empty `B') will cause formatting to be forgotten |
|
* due to scope closing out. |
|
*/ |
|
|
switch (n->type) { |
switch (n->type) { |
case (MAN_ROOT): |
case (MAN_ROOT): |
child = man_root_pre(m, n, h); |
child = man_root_pre(m, n, h); |
Line 568 man_IP_pre(MAN_ARGS) |
|
Line 573 man_IP_pre(MAN_ARGS) |
|
SCALE_HS_INIT(&su, INDENT); |
SCALE_HS_INIT(&su, INDENT); |
width = 0; |
width = 0; |
|
|
|
/* Width is the last token. */ |
|
|
if (MAN_IP == n->tok && NULL != nn) |
if (MAN_IP == n->tok && NULL != nn) |
if (NULL != (nn = nn->next)) { |
if (NULL != (nn = nn->next)) { |
for ( ; nn->next; nn = nn->next) |
for ( ; nn->next; nn = nn->next) |
Line 575 man_IP_pre(MAN_ARGS) |
|
Line 582 man_IP_pre(MAN_ARGS) |
|
width = a2width(nn, &su); |
width = a2width(nn, &su); |
} |
} |
|
|
if (MAN_TP == n->tok && NULL != nn) |
/* Width is the first token. */ |
width = a2width(nn, &su); |
|
|
|
|
if (MAN_TP == n->tok && NULL != nn) { |
|
/* Skip past non-text children. */ |
|
while (nn && MAN_TEXT != nn->type) |
|
nn = nn->next; |
|
if (nn) |
|
width = a2width(nn, &su); |
|
} |
|
|
if (MAN_BLOCK == n->type) { |
if (MAN_BLOCK == n->type) { |
bufcat_su(h, "margin-left", &su); |
bufcat_su(h, "margin-left", &su); |
SCALE_VS_INIT(&su, 1); |
SCALE_VS_INIT(&su, 1); |
Line 601 man_IP_pre(MAN_ARGS) |
|
Line 615 man_IP_pre(MAN_ARGS) |
|
PAIR_STYLE_INIT(&tag, h); |
PAIR_STYLE_INIT(&tag, h); |
print_otag(h, TAG_DIV, 1, &tag); |
print_otag(h, TAG_DIV, 1, &tag); |
|
|
/* With a length string, manually omit the last child. */ |
/* |
|
* Without a length string, we can print all of our children. |
|
*/ |
|
|
if ( ! width) |
if ( ! width) |
return(1); |
return(1); |
|
|
|
/* |
|
* When a length has been specified, we need to carefully print |
|
* our child context: IP gets all children printed but the last |
|
* (the width), while TP gets all children printed but the first |
|
* (the width). |
|
*/ |
|
|
if (MAN_IP == n->tok) |
if (MAN_IP == n->tok) |
for (nn = n->child; nn->next; nn = nn->next) |
for (nn = n->child; nn->next; nn = nn->next) |