[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.224 and 1.225

version 1.224, 2018/12/31 07:08:12 version 1.225, 2018/12/31 11:01:37
Line 36 
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 242  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_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 262  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 287  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 317  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 332  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 435  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 508  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 542  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 560  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 589  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 626  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 638  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 651  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 679  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 742  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 982  print_man_node(DECL_ARGS)
Line 946  print_man_node(DECL_ARGS)
                 break;                  break;
         }          }
   
         if (n->tok == ROFF_nf)  
                 n->tok = MAN_EX;  
         else if (n->tok == ROFF_fi)  
                 n->tok = MAN_EE;  
   
         if (n->tok < ROFF_MAX) {          if (n->tok < ROFF_MAX) {
                 roff_term_pre(p, n);                  roff_term_pre(p, n);
                 return;                  return;
Line 1016  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.224  
changed lines
  Added in v.1.225

CVSweb