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

Diff for /mandoc/man_term.c between version 1.215 and 1.225

version 1.215, 2018/08/18 02:08:27 version 1.225, 2018/12/31 11:01:37
Line 27 
Line 27 
 #include <string.h>  #include <string.h>
   
 #include "mandoc_aux.h"  #include "mandoc_aux.h"
 #include "mandoc.h"  
 #include "roff.h"  #include "roff.h"
 #include "man.h"  #include "man.h"
 #include "out.h"  #include "out.h"
Line 37 
Line 36 
 #define MAXMARGINS        64 /* maximum number of indented scopes */  #define MAXMARGINS        64 /* maximum number of indented scopes */
   
 struct  mtermp {  struct  mtermp {
         int               fl;  
 #define MANT_LITERAL     (1 << 0)  
         int               lmargin[MAXMARGINS]; /* margins (incl. vis. page) */          int               lmargin[MAXMARGINS]; /* margins (incl. vis. page) */
         int               lmargincur; /* index of current margin */          int               lmargincur; /* index of current margin */
         int               lmarginsz; /* actual number of nested margins */          int               lmarginsz; /* actual number of nested margins */
Line 81  static int    pre_SS(DECL_ARGS);
Line 78  static int    pre_SS(DECL_ARGS);
 static  int               pre_SY(DECL_ARGS);  static  int               pre_SY(DECL_ARGS);
 static  int               pre_TP(DECL_ARGS);  static  int               pre_TP(DECL_ARGS);
 static  int               pre_UR(DECL_ARGS);  static  int               pre_UR(DECL_ARGS);
   static  int               pre_abort(DECL_ARGS);
 static  int               pre_alternate(DECL_ARGS);  static  int               pre_alternate(DECL_ARGS);
 static  int               pre_ign(DECL_ARGS);  static  int               pre_ign(DECL_ARGS);
 static  int               pre_in(DECL_ARGS);  static  int               pre_in(DECL_ARGS);
Line 101  static const struct man_term_act man_term_acts[MAN_MAX
Line 99  static const struct man_term_act man_term_acts[MAN_MAX
         { pre_SS, post_SS, 0 }, /* SS */          { pre_SS, post_SS, 0 }, /* SS */
         { pre_TP, post_TP, 0 }, /* TP */          { pre_TP, post_TP, 0 }, /* TP */
         { pre_TP, post_TP, 0 }, /* TQ */          { pre_TP, post_TP, 0 }, /* TQ */
         { pre_PP, NULL, 0 }, /* LP */          { pre_abort, NULL, 0 }, /* LP */
         { pre_PP, NULL, 0 }, /* PP */          { pre_PP, NULL, 0 }, /* PP */
         { pre_PP, NULL, 0 }, /* P */          { pre_abort, NULL, 0 }, /* P */
         { pre_IP, post_IP, 0 }, /* IP */          { pre_IP, post_IP, 0 }, /* IP */
         { pre_HP, post_HP, 0 }, /* HP */          { pre_HP, post_HP, 0 }, /* HP */
         { NULL, NULL, 0 }, /* SM */          { NULL, NULL, 0 }, /* SM */
Line 117  static const struct man_term_act man_term_acts[MAN_MAX
Line 115  static const struct man_term_act man_term_acts[MAN_MAX
         { pre_I, NULL, 0 }, /* I */          { pre_I, NULL, 0 }, /* I */
         { pre_alternate, NULL, 0 }, /* IR */          { pre_alternate, NULL, 0 }, /* IR */
         { pre_alternate, NULL, 0 }, /* RI */          { pre_alternate, NULL, 0 }, /* RI */
         { pre_literal, NULL, 0 }, /* nf */  
         { pre_literal, NULL, 0 }, /* fi */  
         { NULL, NULL, 0 }, /* RE */          { NULL, NULL, 0 }, /* RE */
         { pre_RS, post_RS, 0 }, /* RS */          { pre_RS, post_RS, 0 }, /* RS */
         { pre_DT, NULL, 0 }, /* DT */          { pre_DT, NULL, 0 }, /* DT */
Line 147  man_term_act(enum roff_tok tok)
Line 143  man_term_act(enum roff_tok tok)
 }  }
   
 void  void
 terminal_man(void *arg, const struct roff_man *man)  terminal_man(void *arg, const struct roff_meta *man)
 {  {
         struct termp            *p;          struct termp            *p;
         struct roff_node        *n;          struct roff_node        *n;
Line 176  terminal_man(void *arg, const struct roff_man *man)
Line 172  terminal_man(void *arg, const struct roff_man *man)
                             !strcmp(n->child->child->string, "SYNOPSIS")) {                              !strcmp(n->child->child->string, "SYNOPSIS")) {
                                 if (n->child->next->child != NULL)                                  if (n->child->next->child != NULL)
                                         print_man_nodelist(p, &mt,                                          print_man_nodelist(p, &mt,
                                             n->child->next->child,                                              n->child->next->child, man);
                                             &man->meta);  
                                 term_newln(p);                                  term_newln(p);
                                 break;                                  break;
                         }                          }
                         n = n->next;                          n = n->next;
                 }                  }
         } else {          } else {
                 term_begin(p, print_man_head, print_man_foot, &man->meta);                  term_begin(p, print_man_head, print_man_foot, man);
                 p->flags |= TERMP_NOSPACE;                  p->flags |= TERMP_NOSPACE;
                 if (n != NULL)                  if (n != NULL)
                         print_man_nodelist(p, &mt, n, &man->meta);                          print_man_nodelist(p, &mt, n, man);
                 term_end(p);                  term_end(p);
         }          }
         p->defindent = save_defindent;          p->defindent = save_defindent;
Line 222  print_bvspace(struct termp *p, const struct roff_node 
Line 217  print_bvspace(struct termp *p, const struct roff_node 
   
   
 static int  static int
   pre_abort(DECL_ARGS)
   {
           abort();
   }
   
   static int
 pre_ign(DECL_ARGS)  pre_ign(DECL_ARGS)
 {  {
   
Line 239  pre_I(DECL_ARGS)
Line 240  pre_I(DECL_ARGS)
 static int  static int
 pre_literal(DECL_ARGS)  pre_literal(DECL_ARGS)
 {  {
   
         term_newln(p);          term_newln(p);
   
         if (n->tok == MAN_nf || n->tok == MAN_EX)  
                 mt->fl |= MANT_LITERAL;  
         else  
                 mt->fl &= ~MANT_LITERAL;  
   
         /*          /*
          * Unlike .IP and .TP, .HP does not have a HEAD.           * Unlike .IP and .TP, .HP does not have a HEAD.
          * So in case a second call to term_flushln() is needed,           * So in case a second call to term_flushln() is needed,
Line 259  pre_literal(DECL_ARGS)
Line 254  pre_literal(DECL_ARGS)
                 p->flags &= ~(TERMP_NOBREAK | TERMP_BRIND);                  p->flags &= ~(TERMP_NOBREAK | TERMP_BRIND);
                 p->flags |= TERMP_NOSPACE;                  p->flags |= TERMP_NOSPACE;
         }          }
   
         return 0;          return 0;
 }  }
   
Line 284  pre_alternate(DECL_ARGS)
Line 278  pre_alternate(DECL_ARGS)
 {  {
         enum termfont            font[2];          enum termfont            font[2];
         struct roff_node        *nn;          struct roff_node        *nn;
         int                      savelit, i;          int                      i;
   
         switch (n->tok) {          switch (n->tok) {
         case MAN_RB:          case MAN_RB:
Line 314  pre_alternate(DECL_ARGS)
Line 308  pre_alternate(DECL_ARGS)
         default:          default:
                 abort();                  abort();
         }          }
           for (i = 0, nn = n->child; nn != NULL; nn = nn->next, i = 1 - i) {
         savelit = MANT_LITERAL & mt->fl;  
         mt->fl &= ~MANT_LITERAL;  
   
         for (i = 0, nn = n->child; nn; nn = nn->next, i = 1 - i) {  
                 term_fontrepl(p, font[i]);                  term_fontrepl(p, font[i]);
                 if (savelit && NULL == nn->next)  
                         mt->fl |= MANT_LITERAL;  
                 assert(nn->type == ROFFT_TEXT);                  assert(nn->type == ROFFT_TEXT);
                 term_word(p, nn->string);                  term_word(p, nn->string);
                 if (nn->flags & NODE_EOS)                  if (nn->flags & NODE_EOS)
Line 329  pre_alternate(DECL_ARGS)
Line 317  pre_alternate(DECL_ARGS)
                 if (nn->next)                  if (nn->next)
                         p->flags |= TERMP_NOSPACE;                          p->flags |= TERMP_NOSPACE;
         }          }
   
         return 0;          return 0;
 }  }
   
Line 346  pre_OP(DECL_ARGS)
Line 333  pre_OP(DECL_ARGS)
 {  {
   
         term_word(p, "[");          term_word(p, "[");
         p->flags |= TERMP_NOSPACE;          p->flags |= TERMP_KEEP | TERMP_NOSPACE;
   
         if (NULL != (n = n->child)) {          if (NULL != (n = n->child)) {
                 term_fontrepl(p, TERMFONT_BOLD);                  term_fontrepl(p, TERMFONT_BOLD);
Line 358  pre_OP(DECL_ARGS)
Line 345  pre_OP(DECL_ARGS)
         }          }
   
         term_fontrepl(p, TERMFONT_NONE);          term_fontrepl(p, TERMFONT_NONE);
           p->flags &= ~TERMP_KEEP;
         p->flags |= TERMP_NOSPACE;          p->flags |= TERMP_NOSPACE;
         term_word(p, "]");          term_word(p, "]");
         return 0;          return 0;
Line 431  pre_HP(DECL_ARGS)
Line 419  pre_HP(DECL_ARGS)
                 return 0;                  return 0;
         }          }
   
         if ( ! (MANT_LITERAL & mt->fl)) {          if ((n->flags & NODE_NOFILL) == 0) {
                 p->flags |= TERMP_NOBREAK | TERMP_BRIND;                  p->flags |= TERMP_NOBREAK | TERMP_BRIND;
                 p->trailspace = 2;                  p->trailspace = 2;
         }          }
Line 504  pre_IP(DECL_ARGS)
Line 492  pre_IP(DECL_ARGS)
 {  {
         struct roffsu            su;          struct roffsu            su;
         const struct roff_node  *nn;          const struct roff_node  *nn;
         int                      len, savelit;          int                      len;
   
         switch (n->type) {          switch (n->type) {
         case ROFFT_BODY:          case ROFFT_BODY:
Line 538  pre_IP(DECL_ARGS)
Line 526  pre_IP(DECL_ARGS)
         case ROFFT_HEAD:          case ROFFT_HEAD:
                 p->tcol->offset = mt->offset;                  p->tcol->offset = mt->offset;
                 p->tcol->rmargin = mt->offset + len;                  p->tcol->rmargin = mt->offset + len;
   
                 savelit = MANT_LITERAL & mt->fl;  
                 mt->fl &= ~MANT_LITERAL;  
   
                 if (n->child)                  if (n->child)
                         print_man_node(p, mt, n->child, meta);                          print_man_node(p, mt, n->child, meta);
   
                 if (savelit)  
                         mt->fl |= MANT_LITERAL;  
   
                 return 0;                  return 0;
         case ROFFT_BODY:          case ROFFT_BODY:
                 p->tcol->offset = mt->offset + len;                  p->tcol->offset = mt->offset + len;
Line 556  pre_IP(DECL_ARGS)
Line 536  pre_IP(DECL_ARGS)
         default:          default:
                 break;                  break;
         }          }
   
         return 1;          return 1;
 }  }
   
 static void  static void
 post_IP(DECL_ARGS)  post_IP(DECL_ARGS)
 {  {
   
         switch (n->type) {          switch (n->type) {
         case ROFFT_HEAD:          case ROFFT_HEAD:
                 term_flushln(p);                  term_flushln(p);
Line 585  pre_TP(DECL_ARGS)
Line 563  pre_TP(DECL_ARGS)
 {  {
         struct roffsu            su;          struct roffsu            su;
         struct roff_node        *nn;          struct roff_node        *nn;
         int                      len, savelit;          int                      len;
   
         switch (n->type) {          switch (n->type) {
         case ROFFT_HEAD:          case ROFFT_HEAD:
Line 622  pre_TP(DECL_ARGS)
Line 600  pre_TP(DECL_ARGS)
                 p->tcol->offset = mt->offset;                  p->tcol->offset = mt->offset;
                 p->tcol->rmargin = mt->offset + len;                  p->tcol->rmargin = mt->offset + len;
   
                 savelit = MANT_LITERAL & mt->fl;  
                 mt->fl &= ~MANT_LITERAL;  
   
                 /* Don't print same-line elements. */                  /* Don't print same-line elements. */
                 nn = n->child;                  nn = n->child;
                 while (NULL != nn && 0 == (NODE_LINE & nn->flags))                  while (NULL != nn && 0 == (NODE_LINE & nn->flags))
Line 634  pre_TP(DECL_ARGS)
Line 609  pre_TP(DECL_ARGS)
                         print_man_node(p, mt, nn, meta);                          print_man_node(p, mt, nn, meta);
                         nn = nn->next;                          nn = nn->next;
                 }                  }
   
                 if (savelit)  
                         mt->fl |= MANT_LITERAL;  
                 return 0;                  return 0;
         case ROFFT_BODY:          case ROFFT_BODY:
                 p->tcol->offset = mt->offset + len;                  p->tcol->offset = mt->offset + len;
Line 647  pre_TP(DECL_ARGS)
Line 619  pre_TP(DECL_ARGS)
         default:          default:
                 break;                  break;
         }          }
   
         return 1;          return 1;
 }  }
   
 static void  static void
 post_TP(DECL_ARGS)  post_TP(DECL_ARGS)
 {  {
   
         switch (n->type) {          switch (n->type) {
         case ROFFT_HEAD:          case ROFFT_HEAD:
                 term_flushln(p);                  term_flushln(p);
Line 675  pre_SS(DECL_ARGS)
Line 645  pre_SS(DECL_ARGS)
   
         switch (n->type) {          switch (n->type) {
         case ROFFT_BLOCK:          case ROFFT_BLOCK:
                 mt->fl &= ~MANT_LITERAL;  
                 mt->lmargin[mt->lmargincur] = term_len(p, p->defindent);                  mt->lmargin[mt->lmargincur] = term_len(p, p->defindent);
                 mt->offset = term_len(p, p->defindent);                  mt->offset = term_len(p, p->defindent);
   
Line 738  pre_SH(DECL_ARGS)
Line 707  pre_SH(DECL_ARGS)
   
         switch (n->type) {          switch (n->type) {
         case ROFFT_BLOCK:          case ROFFT_BLOCK:
                 mt->fl &= ~MANT_LITERAL;  
                 mt->lmargin[mt->lmargincur] = term_len(p, p->defindent);                  mt->lmargin[mt->lmargincur] = term_len(p, p->defindent);
                 mt->offset = term_len(p, p->defindent);                  mt->offset = term_len(p, p->defindent);
   
Line 860  pre_SY(DECL_ARGS)
Line 828  pre_SY(DECL_ARGS)
   
         switch (n->type) {          switch (n->type) {
         case ROFFT_BLOCK:          case ROFFT_BLOCK:
                 print_bvspace(p, n, mt->pardist);                  if (n->prev == NULL || n->prev->tok != MAN_SY)
                           print_bvspace(p, n, mt->pardist);
                 return 1;                  return 1;
         case ROFFT_HEAD:          case ROFFT_HEAD:
         case ROFFT_BODY:          case ROFFT_BODY:
Line 870  pre_SY(DECL_ARGS)
Line 839  pre_SY(DECL_ARGS)
         }          }
   
         nn = n->parent->head->child;          nn = n->parent->head->child;
         len = nn == NULL ? 0 : term_strlen(p, nn->string) + 1;          len = nn == NULL ? 1 : term_strlen(p, nn->string) + 1;
   
         switch (n->type) {          switch (n->type) {
         case ROFFT_HEAD:          case ROFFT_HEAD:
Line 983  print_man_node(DECL_ARGS)
Line 952  print_man_node(DECL_ARGS)
         }          }
   
         act = man_term_act(n->tok);          act = man_term_act(n->tok);
         if ((act->flags & MAN_NOTEXT) == 0)          if ((act->flags & MAN_NOTEXT) == 0 && n->tok != MAN_SM)
                 term_fontrepl(p, TERMFONT_NONE);                  term_fontrepl(p, TERMFONT_NONE);
   
         c = 1;          c = 1;
Line 995  print_man_node(DECL_ARGS)
Line 964  print_man_node(DECL_ARGS)
   
         if (act->post != NULL)          if (act->post != NULL)
                 (*act->post)(p, mt, n, meta);                  (*act->post)(p, mt, n, meta);
         if ((act->flags & MAN_NOTEXT) == 0)          if ((act->flags & MAN_NOTEXT) == 0 && n->tok != MAN_SM)
                 term_fontrepl(p, TERMFONT_NONE);                  term_fontrepl(p, TERMFONT_NONE);
   
 out:  out:
Line 1006  out:
Line 975  out:
          * -man doesn't have nested macros, we don't need to be           * -man doesn't have nested macros, we don't need to be
          * more specific than this.           * more specific than this.
          */           */
         if (mt->fl & MANT_LITERAL &&          if (n->flags & NODE_NOFILL &&
             ! (p->flags & (TERMP_NOBREAK | TERMP_NONEWLINE)) &&              ! (p->flags & (TERMP_NOBREAK | TERMP_NONEWLINE)) &&
             (n->next == NULL || n->next->flags & NODE_LINE)) {              (n->next == NULL || n->next->flags & NODE_LINE)) {
                 p->flags |= TERMP_BRNEVER | TERMP_NOSPACE;                  p->flags |= TERMP_BRNEVER | TERMP_NOSPACE;

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

CVSweb