[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.243

version 1.235, 2020/03/13 15:32:28 version 1.243, 2023/10/24 20:53:12
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 225  print_bvspace(struct termp *p, struct roff_node *n, in
Line 226  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 330  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 517  pre_IP(DECL_ARGS)
Line 534  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 608  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 900  print_man_node(DECL_ARGS)
Line 917  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 968  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 997  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 1038  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 1156  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.243

CVSweb