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

Diff for /mandoc/mdoc_man.c between version 1.11 and 1.13

version 1.11, 2012/07/07 13:46:59 version 1.13, 2012/07/07 13:57:19
Line 18 
Line 18 
 #include "config.h"  #include "config.h"
 #endif  #endif
   
   #include <assert.h>
 #include <stdio.h>  #include <stdio.h>
 #include <string.h>  #include <string.h>
   
Line 32 
Line 33 
                   struct mman *mm                    struct mman *mm
   
 struct  mman {  struct  mman {
           int               mode_space; /* spacing mode: 1 = on */
         int               need_space; /* next word needs prior ws */          int               need_space; /* next word needs prior ws */
           int               mode_keep; /* currently inside a keep */
         int               need_nl; /* next word needs prior nl */          int               need_nl; /* next word needs prior nl */
 };  };
   
Line 47  struct manact {
Line 50  struct manact {
 static  int       cond_body(DECL_ARGS);  static  int       cond_body(DECL_ARGS);
 static  int       cond_head(DECL_ARGS);  static  int       cond_head(DECL_ARGS);
 static  void      post_bd(DECL_ARGS);  static  void      post_bd(DECL_ARGS);
   static  void      post_bk(DECL_ARGS);
 static  void      post_dl(DECL_ARGS);  static  void      post_dl(DECL_ARGS);
 static  void      post_enc(DECL_ARGS);  static  void      post_enc(DECL_ARGS);
 static  void      post_nm(DECL_ARGS);  static  void      post_nm(DECL_ARGS);
Line 56  static void   post_sect(DECL_ARGS);
Line 60  static void   post_sect(DECL_ARGS);
 static  void      post_sp(DECL_ARGS);  static  void      post_sp(DECL_ARGS);
 static  int       pre_ap(DECL_ARGS);  static  int       pre_ap(DECL_ARGS);
 static  int       pre_bd(DECL_ARGS);  static  int       pre_bd(DECL_ARGS);
   static  int       pre_bk(DECL_ARGS);
 static  int       pre_br(DECL_ARGS);  static  int       pre_br(DECL_ARGS);
 static  int       pre_bx(DECL_ARGS);  static  int       pre_bx(DECL_ARGS);
 static  int       pre_dl(DECL_ARGS);  static  int       pre_dl(DECL_ARGS);
Line 64  static int   pre_it(DECL_ARGS);
Line 69  static int   pre_it(DECL_ARGS);
 static  int       pre_nm(DECL_ARGS);  static  int       pre_nm(DECL_ARGS);
 static  int       pre_ns(DECL_ARGS);  static  int       pre_ns(DECL_ARGS);
 static  int       pre_pp(DECL_ARGS);  static  int       pre_pp(DECL_ARGS);
   static  int       pre_sm(DECL_ARGS);
 static  int       pre_sp(DECL_ARGS);  static  int       pre_sp(DECL_ARGS);
 static  int       pre_sect(DECL_ARGS);  static  int       pre_sect(DECL_ARGS);
 static  int       pre_ux(DECL_ARGS);  static  int       pre_ux(DECL_ARGS);
Line 168  static const struct manact manacts[MDOC_MAX + 1] = {
Line 174  static const struct manact manacts[MDOC_MAX + 1] = {
         { NULL, NULL, NULL, NULL, NULL }, /* Sc */          { NULL, NULL, NULL, NULL, NULL }, /* Sc */
         { cond_body, pre_enc, post_enc, "`", "'" }, /* So */          { cond_body, pre_enc, post_enc, "`", "'" }, /* So */
         { cond_body, pre_enc, post_enc, "`", "'" }, /* Sq */          { cond_body, pre_enc, post_enc, "`", "'" }, /* Sq */
         { NULL, NULL, NULL, NULL, NULL }, /* _Sm */          { NULL, pre_sm, NULL, NULL, NULL }, /* Sm */
         { NULL, pre_enc, post_enc, "\\fI", "\\fP" }, /* Sx */          { NULL, pre_enc, post_enc, "\\fI", "\\fP" }, /* Sx */
         { NULL, pre_enc, post_enc, "\\fB", "\\fP" }, /* Sy */          { NULL, pre_enc, post_enc, "\\fB", "\\fP" }, /* Sy */
         { NULL, pre_enc, post_enc, "\\fR", "\\fP" }, /* Tn */          { NULL, pre_enc, post_enc, "\\fR", "\\fP" }, /* Tn */
Line 179  static const struct manact manacts[MDOC_MAX + 1] = {
Line 185  static const struct manact manacts[MDOC_MAX + 1] = {
         { NULL, NULL, NULL, NULL, NULL }, /* _Fc */          { NULL, NULL, NULL, NULL, NULL }, /* _Fc */
         { cond_body, pre_enc, post_enc, "[", "]" }, /* Oo */          { cond_body, pre_enc, post_enc, "[", "]" }, /* Oo */
         { NULL, NULL, NULL, NULL, NULL }, /* Oc */          { NULL, NULL, NULL, NULL, NULL }, /* Oc */
         { NULL, NULL, NULL, NULL, NULL }, /* _Bk */          { NULL, pre_bk, post_bk, NULL, NULL }, /* Bk */
         { NULL, NULL, NULL, NULL, NULL }, /* _Ek */          { NULL, NULL, NULL, NULL, NULL }, /* Ek */
         { NULL, pre_ux, NULL, "is currently in beta test.", NULL }, /* Bt */          { NULL, pre_ux, NULL, "is currently in beta test.", NULL }, /* Bt */
         { NULL, NULL, NULL, NULL, NULL }, /* Hf */          { NULL, NULL, NULL, NULL, NULL }, /* Hf */
         { NULL, NULL, NULL, NULL, NULL }, /* Fr */          { NULL, NULL, NULL, NULL, NULL }, /* Fr */
Line 222  print_word(struct mman *mm, const char *s)
Line 228  print_word(struct mman *mm, const char *s)
                  * (2) a word that is non-punctuation; and                   * (2) a word that is non-punctuation; and
                  * (3) if punctuation, non-terminating puncutation.                   * (3) if punctuation, non-terminating puncutation.
                  */                   */
                 if (NULL == strchr(".,:;)]?!", s[0]) || '\0' != s[1])                  if (NULL == strchr(".,:;)]?!", s[0]) || '\0' != s[1]) {
                         putchar(' ');                          if (mm->mode_keep) {
                                   putchar('\\');
                                   putchar('~');
                           } else
                                   putchar(' ');
                   }
   
         /*          /*
          * Reassign needing space if we're not following opening           * Reassign needing space if we're not following opening
          * punctuation.           * punctuation.
          */           */
         mm->need_space =          mm->need_space = mm->mode_space &&
                 ('(' != s[0] && '[' != s[0]) || '\0' != s[1];                  (('(' != s[0] && '[' != s[0]) || '\0' != s[1]);
   
         for ( ; *s; s++) {          for ( ; *s; s++) {
                 switch (*s) {                  switch (*s) {
Line 298  man_mdoc(void *arg, const struct mdoc *mdoc)
Line 309  man_mdoc(void *arg, const struct mdoc *mdoc)
   
         memset(&mm, 0, sizeof(struct mman));          memset(&mm, 0, sizeof(struct mman));
   
           mm.mode_space = 1;
         mm.need_nl = 1;          mm.need_nl = 1;
         print_node(m, n, &mm);          print_node(m, n, &mm);
         putchar('\n');          putchar('\n');
Line 501  post_bd(DECL_ARGS)
Line 513  post_bd(DECL_ARGS)
 }  }
   
 static int  static int
   pre_bk(DECL_ARGS)
   {
   
           switch (n->type) {
           case (MDOC_BLOCK):
                   return(1);
           case (MDOC_BODY):
                   mm->mode_keep = 1;
                   return(1);
           default:
                   return(0);
           }
   }
   
   static void
   post_bk(DECL_ARGS)
   {
   
           if (MDOC_BODY == n->type)
                   mm->mode_keep = 0;
   }
   
   static int
 pre_br(DECL_ARGS)  pre_br(DECL_ARGS)
 {  {
   
Line 628  pre_pp(DECL_ARGS)
Line 663  pre_pp(DECL_ARGS)
                 print_word(mm, ".PP");                  print_word(mm, ".PP");
         mm->need_nl = 1;          mm->need_nl = 1;
         return(MDOC_Rs == n->tok);          return(MDOC_Rs == n->tok);
   }
   
   static int
   pre_sm(DECL_ARGS)
   {
   
           assert(n->child && MDOC_TEXT == n->child->type);
           if (0 == strcmp("on", n->child->string))
                   mm->mode_space = 1;
           else
                   mm->mode_space = 0;
           return(0);
 }  }
   
 static int  static int

Legend:
Removed from v.1.11  
changed lines
  Added in v.1.13

CVSweb