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

Diff for /mandoc/term.c between version 1.172 and 1.179

version 1.172, 2010/09/23 20:26:00 version 1.179, 2011/03/17 08:49:34
Line 1 
Line 1 
 /*      $Id$ */  /*      $Id$ */
 /*  /*
  * Copyright (c) 2008, 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>   * Copyright (c) 2008, 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2010 Ingo Schwarze <schwarze@openbsd.org>   * Copyright (c) 2010, 2011 Ingo Schwarze <schwarze@openbsd.org>
  *   *
  * Permission to use, copy, modify, and distribute this software for any   * Permission to use, copy, modify, and distribute this software for any
  * purpose with or without fee is hereby granted, provided that the above   * purpose with or without fee is hereby granted, provided that the above
Line 80  term_alloc(enum termenc enc)
Line 80  term_alloc(enum termenc enc)
 {  {
         struct termp    *p;          struct termp    *p;
   
         p = calloc(1, sizeof(struct termp));          p = mandoc_calloc(1, sizeof(struct termp));
         if (NULL == p) {  
                 perror(NULL);  
                 exit((int)MANDOCLEVEL_SYSERR);  
         }  
   
         p->enc = enc;          p->enc = enc;
         return(p);          return(p);
 }  }
Line 146  term_flushln(struct termp *p)
Line 141  term_flushln(struct termp *p)
          * an indentation, but can be, for tagged lists or columns, a           * an indentation, but can be, for tagged lists or columns, a
          * small set of values.           * small set of values.
          */           */
           assert  (p->rmargin >= p->offset);
           dv     = p->rmargin - p->offset;
           maxvis = (int)dv > p->overstep ? dv - (size_t)p->overstep : 0;
           dv     = p->maxrmargin - p->offset;
           mmax   = (int)dv > p->overstep ? dv - (size_t)p->overstep : 0;
   
         assert(p->offset < p->rmargin);  
   
         maxvis = (int)(p->rmargin - p->offset) - p->overstep < 0 ?  
                 /* LINTED */  
                 0 : p->rmargin - p->offset - p->overstep;  
         mmax = (int)(p->maxrmargin - p->offset) - p->overstep < 0 ?  
                 /* LINTED */  
                 0 : p->maxrmargin - p->offset - p->overstep;  
   
         bp = TERMP_NOBREAK & p->flags ? mmax : maxvis;          bp = TERMP_NOBREAK & p->flags ? mmax : maxvis;
   
         /*          /*
          * Indent the first line of a paragraph.           * Indent the first line of a paragraph.
          */           */
         vbl = p->flags & TERMP_NOLPAD ? 0 : p->offset;          vbl = p->flags & TERMP_NOLPAD ? (size_t)0 : p->offset;
   
         vis = vend = i = 0;          vis = vend = 0;
           i = 0;
   
         while (i < (int)p->col) {          while (i < (int)p->col) {
                 /*                  /*
Line 184  term_flushln(struct termp *p)
Line 176  term_flushln(struct termp *p)
                  * space is printed according to regular spacing rules).                   * space is printed according to regular spacing rules).
                  */                   */
   
                 /* LINTED */  
                 for (j = i, jhy = 0; j < (int)p->col; j++) {                  for (j = i, jhy = 0; j < (int)p->col; j++) {
                         if ((j && ' ' == p->buf[j]) || '\t' == p->buf[j])                          if ((j && ' ' == p->buf[j]) || '\t' == p->buf[j])
                                 break;                                  break;
Line 223  term_flushln(struct termp *p)
Line 214  term_flushln(struct termp *p)
   
                         /* Remove the p->overstep width. */                          /* Remove the p->overstep width. */
   
                         bp += (int)/* LINTED */                          bp += (size_t)p->overstep;
                                 p->overstep;  
                         p->overstep = 0;                          p->overstep = 0;
                 }                  }
   
Line 238  term_flushln(struct termp *p)
Line 228  term_flushln(struct termp *p)
                                 j = i;                                  j = i;
                                 while (' ' == p->buf[i])                                  while (' ' == p->buf[i])
                                         i++;                                          i++;
                                 dv = (i - j) * (*p->width)(p, ' ');                                  dv = (size_t)(i - j) * (*p->width)(p, ' ');
                                 vbl += dv;                                  vbl += dv;
                                 vend += dv;                                  vend += dv;
                                 break;                                  break;
Line 287  term_flushln(struct termp *p)
Line 277  term_flushln(struct termp *p)
   
         if (TERMP_HANG & p->flags) {          if (TERMP_HANG & p->flags) {
                 /* We need one blank after the tag. */                  /* We need one blank after the tag. */
                 p->overstep = /* LINTED */                  p->overstep = (int)(vis - maxvis + (*p->width)(p, ' '));
                         vis - maxvis + (*p->width)(p, ' ');  
   
                 /*                  /*
                  * Behave exactly the same way as groff:                   * Behave exactly the same way as groff:
Line 302  term_flushln(struct termp *p)
Line 291  term_flushln(struct termp *p)
                  */                   */
                 if (p->overstep >= -1) {                  if (p->overstep >= -1) {
                         assert((int)maxvis + p->overstep >= 0);                          assert((int)maxvis + p->overstep >= 0);
                         /* LINTED */                          maxvis += (size_t)p->overstep;
                         maxvis += p->overstep;  
                 } else                  } else
                         p->overstep = 0;                          p->overstep = 0;
   
Line 311  term_flushln(struct termp *p)
Line 299  term_flushln(struct termp *p)
                 return;                  return;
   
         /* Right-pad. */          /* Right-pad. */
         if (maxvis > vis + /* LINTED */          if (maxvis > vis +
                         ((TERMP_TWOSPACE & p->flags) ?              ((TERMP_TWOSPACE & p->flags) ? (*p->width)(p, ' ') : 0)) {
                          (*p->width)(p, ' ') : 0)) {  
                 p->viscol += maxvis - vis;                  p->viscol += maxvis - vis;
                 (*p->advance)(p, maxvis - vis);                  (*p->advance)(p, maxvis - vis);
                 vis += (maxvis - vis);                  vis += (maxvis - vis);
Line 361  term_vspace(struct termp *p)
Line 348  term_vspace(struct termp *p)
   
   
 static void  static void
   numbered(struct termp *p, const char *word, size_t len)
   {
           const char      *rhs;
   
           rhs = chars_num2char(word, len);
           if (rhs)
                   encode(p, rhs, 1);
   }
   
   
   static void
 spec(struct termp *p, enum roffdeco d, const char *word, size_t len)  spec(struct termp *p, enum roffdeco d, const char *word, size_t len)
 {  {
         const char      *rhs;          const char      *rhs;
Line 505  term_word(struct termp *p, const char *word)
Line 503  term_word(struct termp *p, const char *word)
         else          else
                 p->flags |= TERMP_NOSPACE;                  p->flags |= TERMP_NOSPACE;
   
         p->flags &= ~TERMP_SENTENCE;          p->flags &= ~(TERMP_SENTENCE | TERMP_IGNDELIM);
   
         while (*word) {          while (*word) {
                 if ((ssz = strcspn(word, "\\")) > 0)                  if ((ssz = strcspn(word, "\\")) > 0)
                         encode(p, word, ssz);                          encode(p, word, ssz);
   
                 word += ssz;                  word += (int)ssz;
                 if ('\\' != *word)                  if ('\\' != *word)
                         continue;                          continue;
   
Line 519  term_word(struct termp *p, const char *word)
Line 517  term_word(struct termp *p, const char *word)
                 word += a2roffdeco(&deco, &seq, &ssz);                  word += a2roffdeco(&deco, &seq, &ssz);
   
                 switch (deco) {                  switch (deco) {
                   case (DECO_NUMBERED):
                           numbered(p, seq, ssz);
                           break;
                 case (DECO_RESERVED):                  case (DECO_RESERVED):
                         res(p, seq, ssz);                          res(p, seq, ssz);
                         break;                          break;
Line 573  adjbuf(struct termp *p, size_t sz)
Line 574  adjbuf(struct termp *p, size_t sz)
         while (sz >= p->maxcols)          while (sz >= p->maxcols)
                 p->maxcols <<= 2;                  p->maxcols <<= 2;
   
         p->buf = realloc(p->buf, p->maxcols);          p->buf = mandoc_realloc(p->buf, p->maxcols);
         if (NULL == p->buf) {  
                 perror(NULL);  
                 exit((int)MANDOCLEVEL_SYSERR);  
         }  
 }  }
   
   
Line 685  term_strlen(const struct termp *p, const char *cp)
Line 682  term_strlen(const struct termp *p, const char *cp)
                         if (rhs)                          if (rhs)
                                 for (i = 0; i < rsz; i++)                                  for (i = 0; i < rsz; i++)
                                         sz += (*p->width)(p, *rhs++);                                          sz += (*p->width)(p, *rhs++);
                   } else if (ASCII_NBRSP == *cp) {
                           sz += (*p->width)(p, ' ');
                           cp++;
                   } else if (ASCII_HYPH == *cp) {
                           sz += (*p->width)(p, '-');
                           cp++;
                 } else                  } else
                         sz += (*p->width)(p, *cp++);                          sz += (*p->width)(p, *cp++);
   

Legend:
Removed from v.1.172  
changed lines
  Added in v.1.179

CVSweb