]> git.cameronkatri.com Git - mandoc.git/blobdiff - man_term.c
Version.
[mandoc.git] / man_term.c
index b07602d3f1226c2e90017ce591c6a3c3ec9e215b..8b1c623696b473d4824176691f6b03b772055ca9 100644 (file)
@@ -1,4 +1,4 @@
-/*     $Id: man_term.c,v 1.13 2009/06/15 20:26:47 kristaps Exp $ */
+/*     $Id: man_term.c,v 1.16 2009/06/18 20:46:19 kristaps Exp $ */
 /*
  * Copyright (c) 2008, 2009 Kristaps Dzonsons <kristaps@kth.se>
  *
@@ -40,6 +40,7 @@ struct        termact {
 static int               pre_B(DECL_ARGS);
 static int               pre_BI(DECL_ARGS);
 static int               pre_BR(DECL_ARGS);
+static int               pre_br(DECL_ARGS);
 static int               pre_I(DECL_ARGS);
 static int               pre_IB(DECL_ARGS);
 static int               pre_IP(DECL_ARGS);
@@ -57,7 +58,7 @@ static        void              post_SH(DECL_ARGS);
 static void              post_SS(DECL_ARGS);
 
 static const struct termact termacts[MAN_MAX] = {
-       { NULL, NULL }, /* __ */
+       { pre_br, NULL }, /* br */
        { NULL, NULL }, /* TH */
        { pre_SH, post_SH }, /* SH */
        { pre_SS, post_SS }, /* SS */
@@ -78,7 +79,6 @@ static const struct termact termacts[MAN_MAX] = {
        { pre_I, post_I }, /* I */
        { pre_IR, NULL }, /* IR */
        { pre_RI, NULL }, /* RI */
-       { pre_PP, NULL }, /* br */
        { NULL, NULL }, /* na */
        { pre_I, post_I }, /* i */
 };
@@ -97,7 +97,10 @@ man_run(struct termp *p, const struct man *m)
 
        print_head(p, man_meta(m));
        p->flags |= TERMP_NOSPACE;
-       print_body(p, man_node(m), man_meta(m));
+       assert(man_node(m));
+       assert(MAN_ROOT == man_node(m)->type);
+       if (man_node(m)->child)
+               print_body(p, man_node(m)->child, man_meta(m));
        print_foot(p, man_meta(m));
 
        return(1);
@@ -258,6 +261,16 @@ post_B(DECL_ARGS)
 }
 
 
+/* ARGSUSED */
+static int
+pre_br(DECL_ARGS)
+{
+
+       term_newln(p);
+       return(0);
+}
+
+
 /* ARGSUSED */
 static int
 pre_PP(DECL_ARGS)
@@ -312,6 +325,7 @@ pre_TP(DECL_ARGS)
        size_t           offs;
 
        term_vspace(p);
+
        p->offset = INDENT;
 
        if (NULL == (nn = n->child))