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

Diff for /mandoc/mdoc_html.c between version 1.209 and 1.215

version 1.209, 2014/10/30 20:10:02 version 1.215, 2014/12/01 08:05:52
Line 26 
Line 26 
 #include <string.h>  #include <string.h>
 #include <unistd.h>  #include <unistd.h>
   
 #include "mandoc.h"  
 #include "mandoc_aux.h"  #include "mandoc_aux.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
Line 98  static int    mdoc_mt_pre(MDOC_ARGS);
Line 97  static int    mdoc_mt_pre(MDOC_ARGS);
 static  int               mdoc_ms_pre(MDOC_ARGS);  static  int               mdoc_ms_pre(MDOC_ARGS);
 static  int               mdoc_nd_pre(MDOC_ARGS);  static  int               mdoc_nd_pre(MDOC_ARGS);
 static  int               mdoc_nm_pre(MDOC_ARGS);  static  int               mdoc_nm_pre(MDOC_ARGS);
   static  int               mdoc_no_pre(MDOC_ARGS);
 static  int               mdoc_ns_pre(MDOC_ARGS);  static  int               mdoc_ns_pre(MDOC_ARGS);
 static  int               mdoc_pa_pre(MDOC_ARGS);  static  int               mdoc_pa_pre(MDOC_ARGS);
 static  void              mdoc_pf_post(MDOC_ARGS);  static  void              mdoc_pf_post(MDOC_ARGS);
Line 182  static const struct htmlmdoc mdocs[MDOC_MAX] = {
Line 182  static const struct htmlmdoc mdocs[MDOC_MAX] = {
         {mdoc_quote_pre, mdoc_quote_post}, /* Bq */          {mdoc_quote_pre, mdoc_quote_post}, /* Bq */
         {mdoc_xx_pre, NULL}, /* Bsx */          {mdoc_xx_pre, NULL}, /* Bsx */
         {mdoc_bx_pre, NULL}, /* Bx */          {mdoc_bx_pre, NULL}, /* Bx */
         {NULL, NULL}, /* Db */          {mdoc_skip_pre, NULL}, /* Db */
         {NULL, NULL}, /* Dc */          {NULL, NULL}, /* Dc */
         {mdoc_quote_pre, mdoc_quote_post}, /* Do */          {mdoc_quote_pre, mdoc_quote_post}, /* Do */
         {mdoc_quote_pre, mdoc_quote_post}, /* Dq */          {mdoc_quote_pre, mdoc_quote_post}, /* Dq */
Line 192  static const struct htmlmdoc mdocs[MDOC_MAX] = {
Line 192  static const struct htmlmdoc mdocs[MDOC_MAX] = {
         {mdoc_quote_pre, mdoc_quote_post}, /* Eo */          {mdoc_quote_pre, mdoc_quote_post}, /* Eo */
         {mdoc_xx_pre, NULL}, /* Fx */          {mdoc_xx_pre, NULL}, /* Fx */
         {mdoc_ms_pre, NULL}, /* Ms */          {mdoc_ms_pre, NULL}, /* Ms */
         {mdoc_igndelim_pre, NULL}, /* No */          {mdoc_no_pre, NULL}, /* No */
         {mdoc_ns_pre, NULL}, /* Ns */          {mdoc_ns_pre, NULL}, /* Ns */
         {mdoc_xx_pre, NULL}, /* Nx */          {mdoc_xx_pre, NULL}, /* Nx */
         {mdoc_xx_pre, NULL}, /* Ox */          {mdoc_xx_pre, NULL}, /* Ox */
Line 422  print_mdoc_node(MDOC_ARGS)
Line 422  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;
         }          }
Line 453  print_mdoc_node(MDOC_ARGS)
Line 452  print_mdoc_node(MDOC_ARGS)
         case MDOC_EQN:          case MDOC_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->pending->flags |= MDOC_ENDED;
                   if (n->end == ENDBODY_NOSPACE)
                           h->flags |= HTML_NOSPACE;
                 break;                  break;
         }          }
 }  }
Line 1864  static void
Line 1868  static void
 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 1884  mdoc_rs_pre(MDOC_ARGS)
Line 1889  mdoc_rs_pre(MDOC_ARGS)
 }  }
   
 static int  static int
   mdoc_no_pre(MDOC_ARGS)
   {
           struct htmlpair tag;
   
           PAIR_CLASS_INIT(&tag, "none");
           print_otag(h, TAG_CODE, 1, &tag);
           return(1);
   }
   
   static int
 mdoc_li_pre(MDOC_ARGS)  mdoc_li_pre(MDOC_ARGS)
 {  {
         struct htmlpair tag;          struct htmlpair tag;
Line 2064  mdoc_quote_pre(MDOC_ARGS)
Line 2079  mdoc_quote_pre(MDOC_ARGS)
         case MDOC_Ao:          case MDOC_Ao:
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
         case MDOC_Aq:          case MDOC_Aq:
                 print_text(h, "\\(la");                  print_text(h, n->parent->prev != NULL &&
                       n->parent->prev->tok == MDOC_An ?  "<" : "\\(la");
                 break;                  break;
         case MDOC_Bro:          case MDOC_Bro:
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
Line 2130  static void
Line 2146  static void
 mdoc_quote_post(MDOC_ARGS)  mdoc_quote_post(MDOC_ARGS)
 {  {
   
         if (MDOC_BODY != n->type)          if (n->type != MDOC_BODY && n->type != MDOC_ELEM)
                 return;                  return;
   
         if (MDOC_En != n->tok)          if ( ! (n->tok == MDOC_En ||
               (n->tok == MDOC_Eo && n->end == ENDBODY_SPACE)))
                 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, "\\(ra");                  print_text(h, n->parent->prev != NULL &&
                       n->parent->prev->tok == MDOC_An ?  ">" : "\\(ra");
                 break;                  break;
         case MDOC_Bro:          case MDOC_Bro:
                 /* FALLTHROUGH */                  /* FALLTHROUGH */

Legend:
Removed from v.1.209  
changed lines
  Added in v.1.215

CVSweb