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

Diff for /mandoc/mdoc_markdown.c between version 1.16 and 1.19

version 1.16, 2017/04/17 12:53:29 version 1.19, 2017/05/05 02:06:19
Line 19 
Line 19 
 #include <assert.h>  #include <assert.h>
 #include <ctype.h>  #include <ctype.h>
 #include <stdio.h>  #include <stdio.h>
   #include <stdlib.h>
 #include <string.h>  #include <string.h>
   
 #include "mandoc_aux.h"  #include "mandoc_aux.h"
Line 103  static void  md_post_Pf(struct roff_node *);
Line 104  static void  md_post_Pf(struct roff_node *);
 static  void     md_post_Vt(struct roff_node *);  static  void     md_post_Vt(struct roff_node *);
 static  void     md_post__T(struct roff_node *);  static  void     md_post__T(struct roff_node *);
   
 static  const struct md_act md_acts[MDOC_MAX + 1] = {  static  const struct md_act __md_acts[MDOC_MAX - MDOC_Dd] = {
         { NULL, md_pre_Ap, NULL, NULL, NULL }, /* Ap */  
         { NULL, NULL, NULL, NULL, NULL }, /* Dd */          { NULL, NULL, NULL, NULL, NULL }, /* Dd */
         { NULL, NULL, NULL, NULL, NULL }, /* Dt */          { NULL, NULL, NULL, NULL, NULL }, /* Dt */
         { NULL, NULL, NULL, NULL, NULL }, /* Os */          { NULL, NULL, NULL, NULL, NULL }, /* Os */
Line 120  static const struct md_act md_acts[MDOC_MAX + 1] = {
Line 120  static const struct md_act md_acts[MDOC_MAX + 1] = {
         { NULL, md_pre_It, md_post_It, NULL, NULL }, /* It */          { NULL, md_pre_It, md_post_It, NULL, NULL }, /* It */
         { NULL, md_pre_raw, md_post_raw, "*", "*" }, /* Ad */          { NULL, md_pre_raw, md_post_raw, "*", "*" }, /* Ad */
         { NULL, md_pre_An, NULL, NULL, NULL }, /* An */          { NULL, md_pre_An, NULL, NULL, NULL }, /* An */
           { NULL, md_pre_Ap, NULL, NULL, NULL }, /* Ap */
         { NULL, md_pre_raw, md_post_raw, "*", "*" }, /* Ar */          { NULL, md_pre_raw, md_post_raw, "*", "*" }, /* Ar */
         { NULL, md_pre_raw, md_post_raw, "**", "**" }, /* Cd */          { NULL, md_pre_raw, md_post_raw, "**", "**" }, /* Cd */
         { NULL, md_pre_raw, md_post_raw, "**", "**" }, /* Cm */          { NULL, md_pre_raw, md_post_raw, "**", "**" }, /* Cm */
Line 222  static const struct md_act md_acts[MDOC_MAX + 1] = {
Line 223  static const struct md_act md_acts[MDOC_MAX + 1] = {
         { md_cond_body, md_pre_En, md_post_En, NULL, NULL }, /* En */          { md_cond_body, md_pre_En, md_post_En, NULL, NULL }, /* En */
         { NULL, NULL, NULL, NULL, NULL }, /* Dx */          { NULL, NULL, NULL, NULL, NULL }, /* Dx */
         { NULL, NULL, md_post_pc, NULL, NULL }, /* %Q */          { NULL, NULL, md_post_pc, NULL, NULL }, /* %Q */
         { NULL, md_pre_br, NULL, NULL, NULL }, /* br */  
         { NULL, md_pre_Pp, NULL, NULL, NULL }, /* sp */          { NULL, md_pre_Pp, NULL, NULL, NULL }, /* sp */
         { NULL, md_pre_Lk, md_post_pc, NULL, NULL }, /* %U */          { NULL, md_pre_Lk, md_post_pc, NULL, NULL }, /* %U */
         { NULL, NULL, NULL, NULL, NULL }, /* Ta */          { NULL, NULL, NULL, NULL, NULL }, /* Ta */
         { NULL, NULL, NULL, NULL, NULL }, /* ll */          { NULL, NULL, NULL, NULL, NULL }, /* ll */
         { NULL, NULL, NULL, NULL, NULL }, /* ROOT */  
 };  };
   static  const struct md_act *const md_acts = __md_acts - MDOC_Dd;
   
 static  int      outflags;  static  int      outflags;
 #define MD_spc           (1 << 0)  /* Blank character before next word. */  #define MD_spc           (1 << 0)  /* Blank character before next word. */
Line 310  md_node(struct roff_node *n)
Line 310  md_node(struct roff_node *n)
         process_children = 1;          process_children = 1;
         n->flags &= ~NODE_ENDED;          n->flags &= ~NODE_ENDED;
   
         switch (n->type) {          if (n->type == ROFFT_TEXT) {
         case ROFFT_TEXT:  
                 if (n->flags & NODE_DELIMC)                  if (n->flags & NODE_DELIMC)
                         outflags &= ~(MD_spc | MD_spc_force);                          outflags &= ~(MD_spc | MD_spc_force);
                 else if (outflags & MD_Sm)                  else if (outflags & MD_Sm)
Line 321  md_node(struct roff_node *n)
Line 320  md_node(struct roff_node *n)
                         outflags &= ~(MD_spc | MD_spc_force);                          outflags &= ~(MD_spc | MD_spc_force);
                 else if (outflags & MD_Sm)                  else if (outflags & MD_Sm)
                         outflags |= MD_spc;                          outflags |= MD_spc;
                 break;          } else if (n->tok < ROFF_MAX) {
         default:                  switch (n->tok) {
                   case ROFF_br:
                           process_children = md_pre_br(n);
                           break;
                   case ROFF_ft:
                           process_children = 0;
                           break;
                   default:
                           abort();
                   }
           } else {
                   assert(n->tok >= MDOC_Dd && n->tok < MDOC_MAX);
                 act = md_acts + n->tok;                  act = md_acts + n->tok;
                 cond = act->cond == NULL || (*act->cond)(n);                  cond = act->cond == NULL || (*act->cond)(n);
                 if (cond && act->pre != NULL &&                  if (cond && act->pre != NULL &&
                     (n->end == ENDBODY_NOT || n->child != NULL))                      (n->end == ENDBODY_NOT || n->child != NULL))
                         process_children = (*act->pre)(n);                          process_children = (*act->pre)(n);
                 break;  
         }          }
   
         if (process_children && n->child != NULL)          if (process_children && n->child != NULL)

Legend:
Removed from v.1.16  
changed lines
  Added in v.1.19

CVSweb