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

Diff for /mandoc/roff_term.c between version 1.14 and 1.20

version 1.14, 2017/06/24 14:38:33 version 1.20, 2020/06/22 19:20:40
Line 1 
Line 1 
 /*      $Id$ */  /* $Id$ */
 /*  /*
  * Copyright (c) 2010, 2014, 2015, 2017 Ingo Schwarze <schwarze@openbsd.org>   * Copyright (c) 2010,2014,2015,2017-2019 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 14 
Line 14 
  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF   * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.   * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  */   */
   #include "config.h"
   
 #include <sys/types.h>  #include <sys/types.h>
   
 #include <assert.h>  #include <assert.h>
 #include <stddef.h>  #include <stdio.h>
   #include <string.h>
   
 #include "mandoc.h"  #include "mandoc.h"
 #include "roff.h"  #include "roff.h"
Line 41  static void   roff_term_pre_ti(ROFF_TERM_ARGS);
Line 44  static void   roff_term_pre_ti(ROFF_TERM_ARGS);
 static  const roff_term_pre_fp roff_term_pre_acts[ROFF_MAX] = {  static  const roff_term_pre_fp roff_term_pre_acts[ROFF_MAX] = {
         roff_term_pre_br,  /* br */          roff_term_pre_br,  /* br */
         roff_term_pre_ce,  /* ce */          roff_term_pre_ce,  /* ce */
           roff_term_pre_br,  /* fi */
         roff_term_pre_ft,  /* ft */          roff_term_pre_ft,  /* ft */
         roff_term_pre_ll,  /* ll */          roff_term_pre_ll,  /* ll */
         roff_term_pre_mc,  /* mc */          roff_term_pre_mc,  /* mc */
           roff_term_pre_br,  /* nf */
         roff_term_pre_po,  /* po */          roff_term_pre_po,  /* po */
         roff_term_pre_ce,  /* rj */          roff_term_pre_ce,  /* rj */
         roff_term_pre_sp,  /* sp */          roff_term_pre_sp,  /* sp */
Line 66  roff_term_pre_br(ROFF_TERM_ARGS)
Line 71  roff_term_pre_br(ROFF_TERM_ARGS)
         if (p->flags & TERMP_BRIND) {          if (p->flags & TERMP_BRIND) {
                 p->tcol->offset = p->tcol->rmargin;                  p->tcol->offset = p->tcol->rmargin;
                 p->tcol->rmargin = p->maxrmargin;                  p->tcol->rmargin = p->maxrmargin;
                   p->trailspace = 0;
                 p->flags &= ~(TERMP_NOBREAK | TERMP_BRIND);                  p->flags &= ~(TERMP_NOBREAK | TERMP_BRIND);
                   p->flags |= TERMP_NOSPACE;
         }          }
 }  }
   
Line 74  static void
Line 81  static void
 roff_term_pre_ce(ROFF_TERM_ARGS)  roff_term_pre_ce(ROFF_TERM_ARGS)
 {  {
         const struct roff_node  *nc1, *nc2;          const struct roff_node  *nc1, *nc2;
         size_t                   len, lm;  
   
         roff_term_pre_br(p, n);          roff_term_pre_br(p, n);
         lm = p->tcol->offset;          p->flags |= n->tok == ROFF_ce ? TERMP_CENTER : TERMP_RIGHT;
         nc1 = n->child->next;          nc1 = n->child->next;
         while (nc1 != NULL) {          while (nc1 != NULL) {
                 nc2 = nc1;                  nc2 = nc1;
                 len = 0;  
                 do {                  do {
                         if (nc2->type == ROFFT_TEXT) {  
                                 if (len)  
                                         len++;  
                                 len += term_strlen(p, nc2->string);  
                         }  
                         nc2 = nc2->next;                          nc2 = nc2->next;
                 } while (nc2 != NULL && (nc2->type != ROFFT_TEXT ||                  } while (nc2 != NULL && (nc2->type != ROFFT_TEXT ||
                     (nc2->flags & NODE_LINE) == 0));                      (nc2->flags & NODE_LINE) == 0));
                 p->tcol->offset = len >= p->tcol->rmargin ? 0 :  
                     lm + len >= p->tcol->rmargin ? p->tcol->rmargin - len :  
                     n->tok == ROFF_rj ? p->tcol->rmargin - len :  
                     (lm + p->tcol->rmargin - len) / 2;  
                 while (nc1 != nc2) {                  while (nc1 != nc2) {
                         if (nc1->type == ROFFT_TEXT)                          if (nc1->type == ROFFT_TEXT)
                                 term_word(p, nc1->string);                                  term_word(p, nc1->string);
Line 105  roff_term_pre_ce(ROFF_TERM_ARGS)
Line 101  roff_term_pre_ce(ROFF_TERM_ARGS)
                 p->flags |= TERMP_NOSPACE;                  p->flags |= TERMP_NOSPACE;
                 term_flushln(p);                  term_flushln(p);
         }          }
         p->tcol->offset = lm;          p->flags &= ~(TERMP_CENTER | TERMP_RIGHT);
 }  }
   
 static void  static void
 roff_term_pre_ft(ROFF_TERM_ARGS)  roff_term_pre_ft(ROFF_TERM_ARGS)
 {  {
         switch (*n->child->string) {          const char      *cp;
         case '4':  
         case '3':          cp = n->child->string;
         case 'B':          switch (mandoc_font(cp, (int)strlen(cp))) {
           case ESCAPE_FONTBOLD:
                 term_fontrepl(p, TERMFONT_BOLD);                  term_fontrepl(p, TERMFONT_BOLD);
                 break;                  break;
         case '2':          case ESCAPE_FONTITALIC:
         case 'I':  
                 term_fontrepl(p, TERMFONT_UNDER);                  term_fontrepl(p, TERMFONT_UNDER);
                 break;                  break;
         case 'P':          case ESCAPE_FONTBI:
                   term_fontrepl(p, TERMFONT_BI);
                   break;
           case ESCAPE_FONTPREV:
                 term_fontlast(p);                  term_fontlast(p);
                 break;                  break;
         case '1':          case ESCAPE_FONTROMAN:
         case 'C':          case ESCAPE_FONTCW:
         case 'R':  
                 term_fontrepl(p, TERMFONT_NONE);                  term_fontrepl(p, TERMFONT_NONE);
                 break;                  break;
         default:          default:

Legend:
Removed from v.1.14  
changed lines
  Added in v.1.20

CVSweb