[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.115 and 1.116

version 1.115, 2011/07/22 10:50:46 version 1.116, 2011/09/18 21:08:34
Line 33 
Line 33 
 #include "term.h"  #include "term.h"
 #include "main.h"  #include "main.h"
   
 #define INDENT            7  #define INDENT            7 /* fixed-width char full-indent */
 #define HALFINDENT        3  #define HALFINDENT        3 /* fixed-width char half-indent */
   #define MAXMARGINS        64 /* maximum number of indented scopes */
   
 /* FIXME: have PD set the default vspace width. */  /* FIXME: have PD set the default vspace width. */
   
 struct  mtermp {  struct  mtermp {
         int               fl;          int               fl;
 #define MANT_LITERAL     (1 << 0)  #define MANT_LITERAL     (1 << 0)
         /*          size_t            lmargin[MAXMARGINS]; /* margins (incl. visible page) */
          * Default amount to indent the left margin after leading text          int               lmargincur; /* index of current margin */
          * has been printed (e.g., `HP' left-indent, `TP' and `IP' body          int               lmarginsz; /* actual number of nested margins */
          * indent).  This needs to be saved because `HP' and so on, if          size_t            offset; /* default offset to visible page */
          * not having a specified value, must default.  
          *  
          * Note that this is the indentation AFTER the left offset, so  
          * the total offset is usually offset + lmargin.  
          */  
         size_t            lmargin;  
         /*  
          * The default offset, i.e., the amount between any text and the  
          * page boundary.  
          */  
         size_t            offset;  
 };  };
   
 #define DECL_ARGS         struct termp *p, \  #define DECL_ARGS         struct termp *p, \
Line 164  terminal_man(void *arg, const struct man *man)
Line 154  terminal_man(void *arg, const struct man *man)
         term_begin(p, print_man_head, print_man_foot, m);          term_begin(p, print_man_head, print_man_foot, m);
         p->flags |= TERMP_NOSPACE;          p->flags |= TERMP_NOSPACE;
   
         mt.fl = 0;          memset(&mt, 0, sizeof(struct mtermp));
         mt.lmargin = term_len(p, INDENT);  
           mt.lmargin[mt.lmargincur] = term_len(p, INDENT);
         mt.offset = term_len(p, INDENT);          mt.offset = term_len(p, INDENT);
   
         if (n->child)          if (n->child)
Line 456  pre_HP(DECL_ARGS)
Line 447  pre_HP(DECL_ARGS)
                 return(0);                  return(0);
         }          }
   
         len = mt->lmargin;          len = mt->lmargin[mt->lmargincur];
         ival = -1;          ival = -1;
   
         /* Calculate offset. */          /* Calculate offset. */
Line 472  pre_HP(DECL_ARGS)
Line 463  pre_HP(DECL_ARGS)
         p->rmargin = mt->offset + len;          p->rmargin = mt->offset + len;
   
         if (ival >= 0)          if (ival >= 0)
                 mt->lmargin = (size_t)ival;                  mt->lmargin[mt->lmargincur] = (size_t)ival;
   
         return(1);          return(1);
 }  }
Line 507  pre_PP(DECL_ARGS)
Line 498  pre_PP(DECL_ARGS)
   
         switch (n->type) {          switch (n->type) {
         case (MAN_BLOCK):          case (MAN_BLOCK):
                 mt->lmargin = term_len(p, INDENT);                  mt->lmargin[mt->lmargincur] = term_len(p, INDENT);
                 print_bvspace(p, n);                  print_bvspace(p, n);
                 break;                  break;
         default:          default:
Line 542  pre_IP(DECL_ARGS)
Line 533  pre_IP(DECL_ARGS)
                 return(1);                  return(1);
         }          }
   
         len = mt->lmargin;          len = mt->lmargin[mt->lmargincur];
         ival = -1;          ival = -1;
   
         /* Calculate the offset from the optional second argument. */          /* Calculate the offset from the optional second argument. */
Line 563  pre_IP(DECL_ARGS)
Line 554  pre_IP(DECL_ARGS)
                         break;                          break;
   
                 /* Set the saved left-margin. */                  /* Set the saved left-margin. */
                 mt->lmargin = (size_t)ival;                  mt->lmargin[mt->lmargincur] = (size_t)ival;
   
                 savelit = MANT_LITERAL & mt->fl;                  savelit = MANT_LITERAL & mt->fl;
                 mt->fl &= ~MANT_LITERAL;                  mt->fl &= ~MANT_LITERAL;
Line 631  pre_TP(DECL_ARGS)
Line 622  pre_TP(DECL_ARGS)
                 return(1);                  return(1);
         }          }
   
         len = (size_t)mt->lmargin;          len = (size_t)mt->lmargin[mt->lmargincur];
         ival = -1;          ival = -1;
   
         /* Calculate offset. */          /* Calculate offset. */
   
         if (NULL != (nn = n->parent->head->child)) {          if (NULL != (nn = n->parent->head->child))
                 while (nn && MAN_TEXT != nn->type)                  if (nn->parent->line == nn->line)
                         nn = nn->next;  
                 if (nn && nn->next)  
                         if ((ival = a2width(p, nn->string)) >= 0)                          if ((ival = a2width(p, nn->string)) >= 0)
                                 len = (size_t)ival;                                  len = (size_t)ival;
         }  
   
         switch (n->type) {          switch (n->type) {
         case (MAN_HEAD):          case (MAN_HEAD):
Line 663  pre_TP(DECL_ARGS)
Line 651  pre_TP(DECL_ARGS)
   
                 if (savelit)                  if (savelit)
                         mt->fl |= MANT_LITERAL;                          mt->fl |= MANT_LITERAL;
   
                 if (ival >= 0)                  if (ival >= 0)
                         mt->lmargin = (size_t)ival;                          mt->lmargin[mt->lmargincur] = (size_t)ival;
   
                 return(0);                  return(0);
         case (MAN_BODY):          case (MAN_BODY):
Line 710  pre_SS(DECL_ARGS)
Line 697  pre_SS(DECL_ARGS)
         switch (n->type) {          switch (n->type) {
         case (MAN_BLOCK):          case (MAN_BLOCK):
                 mt->fl &= ~MANT_LITERAL;                  mt->fl &= ~MANT_LITERAL;
                 mt->lmargin = term_len(p, INDENT);                  mt->lmargin[mt->lmargincur] = term_len(p, INDENT);
                 mt->offset = term_len(p, INDENT);                  mt->offset = term_len(p, INDENT);
                 /* If following a prior empty `SS', no vspace. */                  /* If following a prior empty `SS', no vspace. */
                 if (n->prev && MAN_SS == n->prev->tok)                  if (n->prev && MAN_SS == n->prev->tok)
Line 761  pre_SH(DECL_ARGS)
Line 748  pre_SH(DECL_ARGS)
         switch (n->type) {          switch (n->type) {
         case (MAN_BLOCK):          case (MAN_BLOCK):
                 mt->fl &= ~MANT_LITERAL;                  mt->fl &= ~MANT_LITERAL;
                 mt->lmargin = term_len(p, INDENT);                  mt->lmargin[mt->lmargincur] = term_len(p, INDENT);
                 mt->offset = term_len(p, INDENT);                  mt->offset = term_len(p, INDENT);
                 /* If following a prior empty `SH', no vspace. */                  /* If following a prior empty `SH', no vspace. */
                 if (n->prev && MAN_SH == n->prev->tok)                  if (n->prev && MAN_SH == n->prev->tok)
Line 830  pre_RS(DECL_ARGS)
Line 817  pre_RS(DECL_ARGS)
         mt->offset += sz;          mt->offset += sz;
         p->offset = mt->offset;          p->offset = mt->offset;
   
           if (++mt->lmarginsz < MAXMARGINS)
                   mt->lmargincur = mt->lmarginsz;
   
           mt->lmargin[mt->lmargincur] = mt->lmargin[mt->lmargincur - 1];
         return(1);          return(1);
 }  }
   
Line 858  post_RS(DECL_ARGS)
Line 849  post_RS(DECL_ARGS)
   
         mt->offset = mt->offset < sz ?  0 : mt->offset - sz;          mt->offset = mt->offset < sz ?  0 : mt->offset - sz;
         p->offset = mt->offset;          p->offset = mt->offset;
   
           if (--mt->lmarginsz < MAXMARGINS)
                   mt->lmargincur = mt->lmarginsz;
 }  }
   
 static void  static void

Legend:
Removed from v.1.115  
changed lines
  Added in v.1.116

CVSweb