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

Diff for /mandoc/man_html.c between version 1.44 and 1.45

version 1.44, 2010/07/22 23:53:54 version 1.45, 2010/07/23 12:27:28
Line 40 
Line 40 
   
 #define MAN_ARGS          const struct man_meta *m, \  #define MAN_ARGS          const struct man_meta *m, \
                           const struct man_node *n, \                            const struct man_node *n, \
                             struct mhtml *mh, \
                           struct html *h                            struct html *h
   
   struct  mhtml {
           int               fl;
   #define MANH_LITERAL     (1 << 0) /* literal context */
   };
   
 struct  htmlman {  struct  htmlman {
         int             (*pre)(MAN_ARGS);          int             (*pre)(MAN_ARGS);
         int             (*post)(MAN_ARGS);          int             (*post)(MAN_ARGS);
Line 58  static int    a2width(const struct man_node *,
Line 64  static int    a2width(const struct man_node *,
 static  int               man_alt_pre(MAN_ARGS);  static  int               man_alt_pre(MAN_ARGS);
 static  int               man_br_pre(MAN_ARGS);  static  int               man_br_pre(MAN_ARGS);
 static  int               man_ign_pre(MAN_ARGS);  static  int               man_ign_pre(MAN_ARGS);
   static  int               man_in_pre(MAN_ARGS);
   static  int               man_literal_pre(MAN_ARGS);
 static  void              man_root_post(MAN_ARGS);  static  void              man_root_post(MAN_ARGS);
 static  int               man_root_pre(MAN_ARGS);  static  int               man_root_pre(MAN_ARGS);
 static  int               man_B_pre(MAN_ARGS);  static  int               man_B_pre(MAN_ARGS);
Line 96  static const struct htmlman mans[MAN_MAX] = {
Line 104  static const struct htmlman mans[MAN_MAX] = {
         { NULL, NULL }, /* na */          { NULL, NULL }, /* na */
         { NULL, NULL }, /* i */          { NULL, NULL }, /* i */
         { man_br_pre, NULL }, /* sp */          { man_br_pre, NULL }, /* sp */
         { NULL, NULL }, /* nf */          { man_literal_pre, NULL }, /* nf */
         { NULL, NULL }, /* fi */          { man_literal_pre, NULL }, /* fi */
         { NULL, NULL }, /* r */          { NULL, NULL }, /* r */
         { NULL, NULL }, /* RE */          { NULL, NULL }, /* RE */
         { man_RS_pre, NULL }, /* RS */          { man_RS_pre, NULL }, /* RS */
Line 105  static const struct htmlman mans[MAN_MAX] = {
Line 113  static const struct htmlman mans[MAN_MAX] = {
         { man_ign_pre, NULL }, /* UC */          { man_ign_pre, NULL }, /* UC */
         { man_ign_pre, NULL }, /* PD */          { man_ign_pre, NULL }, /* PD */
         { man_br_pre, NULL }, /* Sp */          { man_br_pre, NULL }, /* Sp */
         { man_ign_pre, NULL }, /* Vb */          { man_literal_pre, NULL }, /* Vb */
         { NULL, NULL }, /* Ve */          { man_literal_pre, NULL }, /* Ve */
         { man_ign_pre, NULL }, /* AT */          { man_ign_pre, NULL }, /* AT */
         { NULL, NULL }, /* in */          { man_in_pre, NULL }, /* in */
 };  };
   
   
Line 117  html_man(void *arg, const struct man *m)
Line 125  html_man(void *arg, const struct man *m)
 {  {
         struct html     *h;          struct html     *h;
         struct tag      *t;          struct tag      *t;
           struct mhtml     mh;
   
         h = (struct html *)arg;          h = (struct html *)arg;
   
         print_gen_decls(h);          print_gen_decls(h);
   
           memset(&mh, 0, sizeof(struct mhtml));
   
         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), &mh, h);
         print_tagq(h, t);          print_tagq(h, t);
   
         printf("\n");          printf("\n");
Line 138  print_man(MAN_ARGS) 
Line 149  print_man(MAN_ARGS) 
   
         t = print_otag(h, TAG_HEAD, 0, NULL);          t = print_otag(h, TAG_HEAD, 0, NULL);
   
         print_man_head(m, n, h);          print_man_head(m, n, mh, h);
         print_tagq(h, t);          print_tagq(h, t);
         t = print_otag(h, TAG_BODY, 0, NULL);          t = print_otag(h, TAG_BODY, 0, NULL);
   
Line 146  print_man(MAN_ARGS) 
Line 157  print_man(MAN_ARGS) 
         tag.val = "body";          tag.val = "body";
         print_otag(h, TAG_DIV, 1, &tag);          print_otag(h, TAG_DIV, 1, &tag);
   
         print_man_nodelist(m, n, h);          print_man_nodelist(m, n, mh, h);
   
         print_tagq(h, t);          print_tagq(h, t);
 }  }
Line 170  static void
Line 181  static void
 print_man_nodelist(MAN_ARGS)  print_man_nodelist(MAN_ARGS)
 {  {
   
         print_man_node(m, n, h);          print_man_node(m, n, mh, h);
         if (n->next)          if (n->next)
                 print_man_nodelist(m, n->next, h);                  print_man_nodelist(m, n->next, mh, h);
 }  }
   
   
Line 195  print_man_node(MAN_ARGS)
Line 206  print_man_node(MAN_ARGS)
   
         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, mh, h);
                 break;                  break;
         case (MAN_TEXT):          case (MAN_TEXT):
                 print_text(h, n->string);                  print_text(h, n->string);
   
                   if (MANH_LITERAL & mh->fl)
                           print_otag(h, TAG_BR, 0, NULL);
   
                 return;                  return;
         default:          default:
                 /*                  /*
Line 213  print_man_node(MAN_ARGS)
Line 228  print_man_node(MAN_ARGS)
                         t = h->tags.head;                          t = h->tags.head;
                 }                  }
                 if (mans[n->tok].pre)                  if (mans[n->tok].pre)
                         child = (*mans[n->tok].pre)(m, n, h);                          child = (*mans[n->tok].pre)(m, n, mh, h);
                 break;                  break;
         }          }
   
         if (child && n->child)          if (child && n->child)
                 print_man_nodelist(m, n->child, h);                  print_man_nodelist(m, n->child, mh, h);
   
         /* This will automatically close out any font scope. */          /* This will automatically close out any font scope. */
         print_stagq(h, t);          print_stagq(h, t);
Line 227  print_man_node(MAN_ARGS)
Line 242  print_man_node(MAN_ARGS)
   
         switch (n->type) {          switch (n->type) {
         case (MAN_ROOT):          case (MAN_ROOT):
                 man_root_post(m, n, h);                  man_root_post(m, n, mh, h);
                 break;                  break;
         case (MAN_TEXT):          case (MAN_TEXT):
                 break;                  break;
         default:          default:
                 if (mans[n->tok].post)                  if (mans[n->tok].post)
                         (*mans[n->tok].post)(m, n, h);                          (*mans[n->tok].post)(m, n, mh, h);
                 break;                  break;
         }          }
 }  }
Line 454  man_alt_pre(MAN_ARGS)
Line 469  man_alt_pre(MAN_ARGS)
                  * closed out with the scope.                   * closed out with the scope.
                  */                   */
                 t = print_ofont(h, fp);                  t = print_ofont(h, fp);
                 print_man_node(m, nn, h);                  print_man_node(m, nn, mh, h);
                 print_tagq(h, t);                  print_tagq(h, t);
         }          }
   
Line 648  man_IP_pre(MAN_ARGS)
Line 663  man_IP_pre(MAN_ARGS)
   
         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)
                         print_man_node(m, nn, h);                          print_man_node(m, nn, mh, h);
         if (MAN_TP == n->tok)          if (MAN_TP == n->tok)
                 for (nn = n->child->next; nn; nn = nn->next)                  for (nn = n->child->next; nn; nn = nn->next)
                         print_man_node(m, nn, h);                          print_man_node(m, nn, mh, h);
   
         return(0);          return(0);
 }  }
Line 713  man_I_pre(MAN_ARGS)
Line 728  man_I_pre(MAN_ARGS)
   
         print_ofont(h, HTMLFONT_ITALIC);          print_ofont(h, HTMLFONT_ITALIC);
         return(1);          return(1);
   }
   
   
   /* ARGSUSED */
   static int
   man_literal_pre(MAN_ARGS)
   {
   
           switch (n->tok) {
           case (MAN_nf):
                   /* FALLTHROUGH */
           case (MAN_Vb):
                   print_otag(h, TAG_BR, 0, NULL);
                   mh->fl |= MANH_LITERAL;
                   return(MAN_Vb != n->tok);
           default:
                   mh->fl &= ~MANH_LITERAL;
                   break;
           }
   
           return(1);
   }
   
   
   /* ARGSUSED */
   static int
   man_in_pre(MAN_ARGS)
   {
   
           print_otag(h, TAG_BR, 0, NULL);
           return(0);
 }  }
   
   

Legend:
Removed from v.1.44  
changed lines
  Added in v.1.45

CVSweb