[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.235 and 1.244

version 1.235, 2020/03/13 15:32:28 version 1.244, 2023/11/13 19:13:01
Line 1 
Line 1 
 /* $Id$ */  /* $Id$ */
 /*  /*
  * Copyright (c) 2010-2015, 2017-2020 Ingo Schwarze <schwarze@openbsd.org>   * Copyright (c) 2010-15,2017-20,2022-23 Ingo Schwarze <schwarze@openbsd.org>
  * Copyright (c) 2008-2012 Kristaps Dzonsons <kristaps@bsd.lv>   * Copyright (c) 2008-2012 Kristaps Dzonsons <kristaps@bsd.lv>
  *   *
  * Permission to use, copy, modify, and distribute this software for any   * Permission to use, copy, modify, and distribute this software for any
Line 74  static int    pre_DT(DECL_ARGS);
Line 74  static int    pre_DT(DECL_ARGS);
 static  int               pre_HP(DECL_ARGS);  static  int               pre_HP(DECL_ARGS);
 static  int               pre_I(DECL_ARGS);  static  int               pre_I(DECL_ARGS);
 static  int               pre_IP(DECL_ARGS);  static  int               pre_IP(DECL_ARGS);
   static  int               pre_MR(DECL_ARGS);
 static  int               pre_OP(DECL_ARGS);  static  int               pre_OP(DECL_ARGS);
 static  int               pre_PD(DECL_ARGS);  static  int               pre_PD(DECL_ARGS);
 static  int               pre_PP(DECL_ARGS);  static  int               pre_PP(DECL_ARGS);
Line 83  static int    pre_SS(DECL_ARGS);
Line 84  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 103  static const struct man_term_act man_term_acts[MAN_MAX
Line 103  static const struct man_term_act man_term_acts[MAN_MAX
         { pre_SS, post_SH, 0 }, /* SS */          { pre_SS, post_SH, 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_abort, NULL, 0 }, /* LP */          { pre_PP, NULL, 0 }, /* LP */
         { pre_PP, NULL, 0 }, /* PP */          { pre_PP, NULL, 0 }, /* PP */
         { pre_abort, NULL, 0 }, /* P */          { pre_PP, 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 121  static const struct man_term_act man_term_acts[MAN_MAX
Line 121  static const struct man_term_act man_term_acts[MAN_MAX
         { pre_alternate, NULL, 0 }, /* RI */          { pre_alternate, NULL, 0 }, /* RI */
         { 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, MAN_NOTEXT }, /* DT */
         { pre_ign, NULL, MAN_NOTEXT }, /* UC */          { pre_ign, NULL, MAN_NOTEXT }, /* UC */
         { pre_PD, NULL, MAN_NOTEXT }, /* PD */          { pre_PD, NULL, MAN_NOTEXT }, /* PD */
         { pre_ign, NULL, 0 }, /* AT */          { pre_ign, NULL, MAN_NOTEXT }, /* AT */
         { pre_in, NULL, MAN_NOTEXT }, /* in */          { pre_in, NULL, MAN_NOTEXT }, /* in */
         { pre_SY, post_SY, 0 }, /* SY */          { pre_SY, post_SY, 0 }, /* SY */
         { NULL, NULL, 0 }, /* YS */          { NULL, NULL, 0 }, /* YS */
Line 135  static const struct man_term_act man_term_acts[MAN_MAX
Line 135  static const struct man_term_act man_term_acts[MAN_MAX
         { NULL, NULL, 0 }, /* UE */          { NULL, NULL, 0 }, /* UE */
         { pre_UR, post_UR, 0 }, /* MT */          { pre_UR, post_UR, 0 }, /* MT */
         { NULL, NULL, 0 }, /* ME */          { NULL, NULL, 0 }, /* ME */
           { pre_MR, NULL, 0 }, /* MR */
 };  };
 static const struct man_term_act *man_term_act(enum roff_tok);  static const struct man_term_act *man_term_act(enum roff_tok);
   
Line 152  terminal_man(void *arg, const struct roff_meta *man)
Line 153  terminal_man(void *arg, const struct roff_meta *man)
         struct mtermp            mt;          struct mtermp            mt;
         struct termp            *p;          struct termp            *p;
         struct roff_node        *n, *nc, *nn;          struct roff_node        *n, *nc, *nn;
         size_t                   save_defindent;  
   
         p = (struct termp *)arg;          p = (struct termp *)arg;
         save_defindent = p->defindent;  
         if (p->synopsisonly == 0 && p->defindent == 0)  
                 p->defindent = 7;  
         p->tcol->rmargin = p->maxrmargin = p->defrmargin;          p->tcol->rmargin = p->maxrmargin = p->defrmargin;
         term_tab_set(p, NULL);          term_tab_set(p, NULL);
         term_tab_set(p, "T");          term_tab_set(p, "T");
         term_tab_set(p, ".5i");          term_tab_set(p, ".5i");
   
         memset(&mt, 0, sizeof(mt));          memset(&mt, 0, sizeof(mt));
         mt.lmargin[mt.lmargincur] = term_len(p, p->defindent);          mt.lmargin[mt.lmargincur] = term_len(p, 7);
         mt.offset = term_len(p, p->defindent);          mt.offset = term_len(p, p->defindent);
         mt.pardist = 1;          mt.pardist = 1;
   
Line 194  terminal_man(void *arg, const struct roff_meta *man)
Line 191  terminal_man(void *arg, const struct roff_meta *man)
                         print_man_nodelist(p, &mt, n, man);                          print_man_nodelist(p, &mt, n, man);
                 term_end(p);                  term_end(p);
         }          }
         p->defindent = save_defindent;  
 }  }
   
 /*  /*
Line 225  print_bvspace(struct termp *p, struct roff_node *n, in
Line 221  print_bvspace(struct termp *p, struct roff_node *n, in
                 term_vspace(p);                  term_vspace(p);
 }  }
   
   
 static int  static int
 pre_abort(DECL_ARGS)  
 {  
         abort();  
 }  
   
 static int  
 pre_ign(DECL_ARGS)  pre_ign(DECL_ARGS)
 {  {
         return 0;          return 0;
Line 336  pre_B(DECL_ARGS)
Line 325  pre_B(DECL_ARGS)
 }  }
   
 static int  static int
   pre_MR(DECL_ARGS)
   {
           term_fontrepl(p, TERMFONT_NONE);
           n = n->child;
           if (n != NULL) {
                   term_word(p, n->string);   /* name */
                   p->flags |= TERMP_NOSPACE;
           }
           term_word(p, "(");
           p->flags |= TERMP_NOSPACE;
           if (n != NULL && (n = n->next) != NULL) {
                   term_word(p, n->string);   /* section */
                   p->flags |= TERMP_NOSPACE;
           }
           term_word(p, ")");
           if (n != NULL && (n = n->next) != NULL) {
                   p->flags |= TERMP_NOSPACE;
                   term_word(p, n->string);   /* suffix */
           }
           return 0;
   }
   
   static int
 pre_OP(DECL_ARGS)  pre_OP(DECL_ARGS)
 {  {
         term_word(p, "[");          term_word(p, "[");
Line 487  pre_PP(DECL_ARGS)
Line 499  pre_PP(DECL_ARGS)
 {  {
         switch (n->type) {          switch (n->type) {
         case ROFFT_BLOCK:          case ROFFT_BLOCK:
                 mt->lmargin[mt->lmargincur] = term_len(p, p->defindent);                  mt->lmargin[mt->lmargincur] = term_len(p, 7);
                 print_bvspace(p, n, mt->pardist);                  print_bvspace(p, n, mt->pardist);
                 break;                  break;
         case ROFFT_HEAD:          case ROFFT_HEAD:
Line 517  pre_IP(DECL_ARGS)
Line 529  pre_IP(DECL_ARGS)
                 p->trailspace = 1;                  p->trailspace = 1;
                 break;                  break;
         case ROFFT_BODY:          case ROFFT_BODY:
                 p->flags |= TERMP_NOSPACE;                  p->flags |= TERMP_NOSPACE | TERMP_NONEWLINE;
                 break;                  break;
         default:          default:
                 abort();                  abort();
Line 591  pre_TP(DECL_ARGS)
Line 603  pre_TP(DECL_ARGS)
                 p->trailspace = 1;                  p->trailspace = 1;
                 break;                  break;
         case ROFFT_BODY:          case ROFFT_BODY:
                 p->flags |= TERMP_NOSPACE;                  p->flags |= TERMP_NOSPACE | TERMP_NONEWLINE;
                 break;                  break;
         default:          default:
                 abort();                  abort();
Line 663  pre_SS(DECL_ARGS)
Line 675  pre_SS(DECL_ARGS)
   
         switch (n->type) {          switch (n->type) {
         case ROFFT_BLOCK:          case ROFFT_BLOCK:
                 mt->lmargin[mt->lmargincur] = term_len(p, p->defindent);                  mt->lmargin[mt->lmargincur] = term_len(p, 7);
                 mt->offset = term_len(p, p->defindent);                  mt->offset = term_len(p, p->defindent);
   
                 /*                  /*
Line 704  pre_SH(DECL_ARGS)
Line 716  pre_SH(DECL_ARGS)
   
         switch (n->type) {          switch (n->type) {
         case ROFFT_BLOCK:          case ROFFT_BLOCK:
                 mt->lmargin[mt->lmargincur] = term_len(p, p->defindent);                  mt->lmargin[mt->lmargincur] = term_len(p, 7);
                 mt->offset = term_len(p, p->defindent);                  mt->offset = term_len(p, p->defindent);
   
                 /*                  /*
Line 788  pre_RS(DECL_ARGS)
Line 800  pre_RS(DECL_ARGS)
         if (++mt->lmarginsz < MAXMARGINS)          if (++mt->lmarginsz < MAXMARGINS)
                 mt->lmargincur = mt->lmarginsz;                  mt->lmargincur = mt->lmarginsz;
   
         mt->lmargin[mt->lmargincur] = term_len(p, p->defindent);          mt->lmargin[mt->lmargincur] = term_len(p, 7);
         return 1;          return 1;
 }  }
   
Line 900  print_man_node(DECL_ARGS)
Line 912  print_man_node(DECL_ARGS)
         const struct man_term_act *act;          const struct man_term_act *act;
         int c;          int c;
   
           /*
            * In no-fill mode, break the output line at the beginning
            * of new input lines except after \c, and nowhere else.
            */
   
           if (n->flags & NODE_NOFILL) {
                   if (n->flags & NODE_LINE &&
                       (p->flags & TERMP_NONEWLINE) == 0)
                           term_newln(p);
                   p->flags |= TERMP_BRNEVER;
           } else {
                   if (n->flags & NODE_LINE)
                           term_tab_ref(p);
                   p->flags &= ~TERMP_BRNEVER;
           }
   
         if (n->flags & NODE_ID)          if (n->flags & NODE_ID)
                 term_tag_write(n, p->line);                  term_tag_write(n, p->line);
   
Line 935  print_man_node(DECL_ARGS)
Line 963  print_man_node(DECL_ARGS)
                 return;                  return;
         case ROFFT_TBL:          case ROFFT_TBL:
                 if (p->tbl.cols == NULL)                  if (p->tbl.cols == NULL)
                         term_vspace(p);                          term_newln(p);
                 term_tbl(p, n->span);                  term_tbl(p, n->span);
                 return;                  return;
         default:          default:
Line 964  print_man_node(DECL_ARGS)
Line 992  print_man_node(DECL_ARGS)
                 term_fontrepl(p, TERMFONT_NONE);                  term_fontrepl(p, TERMFONT_NONE);
   
 out:  out:
         /*          if (n->parent->tok == MAN_HP && n->parent->type == ROFFT_BODY &&
          * If we're in a literal context, make sure that words              n->prev == NULL && n->flags & NODE_NOFILL) {
          * together on the same line stay together.  This is a                  term_newln(p);
          * POST-printing call, so we check the NEXT word.  Since                  p->tcol->offset = p->tcol->rmargin;
          * -man doesn't have nested macros, we don't need to be                  p->tcol->rmargin = p->maxrmargin;
          * more specific than this.  
          */  
         if (n->flags & NODE_NOFILL &&  
             ! (p->flags & (TERMP_NOBREAK | TERMP_NONEWLINE)) &&  
             (n->next == NULL || n->next->flags & NODE_LINE)) {  
                 p->flags |= TERMP_BRNEVER | TERMP_NOSPACE;  
                 if (n->string != NULL && *n->string != '\0')  
                         term_flushln(p);  
                 else  
                         term_newln(p);  
                 p->flags &= ~TERMP_BRNEVER;  
                 if (p->tcol->rmargin < p->maxrmargin &&  
                     n->parent->tok == MAN_HP) {  
                         p->tcol->offset = p->tcol->rmargin;  
                         p->tcol->rmargin = p->maxrmargin;  
                 }  
         }          }
         if (n->flags & NODE_EOS)          if (n->flags & NODE_EOS)
                 p->flags |= TERMP_SENTENCE;                  p->flags |= TERMP_SENTENCE;
Line 1021  print_man_foot(struct termp *p, const struct roff_meta
Line 1033  print_man_foot(struct termp *p, const struct roff_meta
          */           */
   
         if ( ! p->mdocstyle) {          if ( ! p->mdocstyle) {
                 if (meta->hasbody) {  
                         term_vspace(p);  
                         term_vspace(p);  
                 }  
                 mandoc_asprintf(&title, "%s(%s)",                  mandoc_asprintf(&title, "%s(%s)",
                     meta->title, meta->msec);                      meta->title, meta->msec);
         } else if (meta->os != NULL) {          } else if (meta->os != NULL) {
Line 1143  print_man_head(struct termp *p, const struct roff_meta
Line 1151  print_man_head(struct termp *p, const struct roff_meta
          */           */
   
         term_vspace(p);          term_vspace(p);
         if ( ! p->mdocstyle) {  
                 term_vspace(p);  
                 term_vspace(p);  
         }  
         free(title);          free(title);
 }  }

Legend:
Removed from v.1.235  
changed lines
  Added in v.1.244

CVSweb