[BACK]Return to docbook2mdoc.c CVS log [TXT][DIR] Up to [cvsweb.bsd.lv] / docbook2mdoc

Diff for /docbook2mdoc/docbook2mdoc.c between version 1.109 and 1.110

version 1.109, 2019/04/12 10:34:48 version 1.110, 2019/04/12 11:19:31
Line 150  pnode_printpara(struct format *f, struct pnode *n)
Line 150  pnode_printpara(struct format *f, struct pnode *n)
         macro_line(f, "Pp");          macro_line(f, "Pp");
 }  }
   
   static void
   pnode_printrefnamediv(struct format *f, struct pnode *n)
   {
           struct pnode    *nc, *nn;
           int              comma;
   
           macro_line(f, "Sh NAME");
           comma = 0;
           TAILQ_FOREACH_SAFE(nc, &n->childq, child, nn) {
                   if (nc->node != NODE_REFNAME)
                           continue;
                   if (comma)
                           macro_addarg(f, ",", ARG_SPACE);
                   macro_open(f, "Nm");
                   macro_addnode(f, nc, ARG_SPACE);
                   pnode_unlink(nc);
                   comma = 1;
           }
           macro_close(f);
   }
   
 /*  /*
  * If the SYNOPSIS macro has a superfluous title, kill it.   * If the SYNOPSIS macro has a superfluous title, kill it.
  */   */
Line 964  pnode_print(struct format *f, struct pnode *n)
Line 985  pnode_print(struct format *f, struct pnode *n)
                 pnode_unlinksub(n);                  pnode_unlinksub(n);
                 break;                  break;
         case NODE_REFNAME:          case NODE_REFNAME:
                 /* Suppress non-text children... */                  /* More often, these appear inside NODE_REFNAMEDIV. */
                 macro_open(f, "Nm");                  macro_open(f, "Nm");
                 macro_addnode(f, n, ARG_SPACE | ARG_SINGLE);  
                 pnode_unlinksub(n);  
                 break;                  break;
         case NODE_REFNAMEDIV:          case NODE_REFNAMEDIV:
                 macro_line(f, "Sh NAME");                  pnode_printrefnamediv(f, n);
                 break;                  break;
         case NODE_REFPURPOSE:          case NODE_REFPURPOSE:
                 macro_open(f, "Nd");                  macro_open(f, "Nd");
Line 1071  pnode_print(struct format *f, struct pnode *n)
Line 1090  pnode_print(struct format *f, struct pnode *n)
                         macro_close(f);                          macro_close(f);
                 sv = f->linestate;                  sv = f->linestate;
                 macro_open(f, "Qc");                  macro_open(f, "Qc");
                 if (sv == LINE_NEW)  
                         macro_close(f);  
                 break;  
         case NODE_REFNAME:  
                 /*  
                  * If we're in the NAME macro and we have multiple  
                  * <refname> macros in sequence, then print out a  
                  * trailing comma before the newline.  
                  */  
                 if (n->parent != NULL &&  
                     n->parent->node == NODE_REFNAMEDIV &&  
                     TAILQ_NEXT(n, child) != NULL &&  
                     TAILQ_NEXT(n, child)->node == NODE_REFNAME)  
                         macro_addarg(f, ",", ARG_SPACE);  
                 if (sv == LINE_NEW)                  if (sv == LINE_NEW)
                         macro_close(f);                          macro_close(f);
                 break;                  break;

Legend:
Removed from v.1.109  
changed lines
  Added in v.1.110

CVSweb