[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.214 and 1.220

version 1.214, 2018/08/17 20:33:37 version 1.220, 2018/08/26 16:21:24
Line 78  static int    pre_PP(DECL_ARGS);
Line 78  static int    pre_PP(DECL_ARGS);
 static  int               pre_RS(DECL_ARGS);  static  int               pre_RS(DECL_ARGS);
 static  int               pre_SH(DECL_ARGS);  static  int               pre_SH(DECL_ARGS);
 static  int               pre_SS(DECL_ARGS);  static  int               pre_SS(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_alternate(DECL_ARGS);  static  int               pre_alternate(DECL_ARGS);
Line 90  static void    post_HP(DECL_ARGS);
Line 91  static void    post_HP(DECL_ARGS);
 static  void              post_RS(DECL_ARGS);  static  void              post_RS(DECL_ARGS);
 static  void              post_SH(DECL_ARGS);  static  void              post_SH(DECL_ARGS);
 static  void              post_SS(DECL_ARGS);  static  void              post_SS(DECL_ARGS);
   static  void              post_SY(DECL_ARGS);
 static  void              post_TP(DECL_ARGS);  static  void              post_TP(DECL_ARGS);
 static  void              post_UR(DECL_ARGS);  static  void              post_UR(DECL_ARGS);
   
Line 115  static const struct man_term_act man_term_acts[MAN_MAX
Line 117  static const struct man_term_act man_term_acts[MAN_MAX
         { pre_I, NULL, 0 }, /* I */          { pre_I, NULL, 0 }, /* I */
         { pre_alternate, NULL, 0 }, /* IR */          { pre_alternate, NULL, 0 }, /* IR */
         { pre_alternate, NULL, 0 }, /* RI */          { pre_alternate, NULL, 0 }, /* RI */
         { pre_literal, NULL, 0 }, /* nf */          { pre_literal, NULL, MAN_NOTEXT }, /* nf */
         { pre_literal, NULL, 0 }, /* fi */          { pre_literal, NULL, MAN_NOTEXT }, /* fi */
         { 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, 0 }, /* DT */
Line 124  static const struct man_term_act man_term_acts[MAN_MAX
Line 126  static const struct man_term_act man_term_acts[MAN_MAX
         { pre_PD, NULL, MAN_NOTEXT }, /* PD */          { pre_PD, NULL, MAN_NOTEXT }, /* PD */
         { pre_ign, NULL, 0 }, /* AT */          { pre_ign, NULL, 0 }, /* AT */
         { pre_in, NULL, MAN_NOTEXT }, /* in */          { pre_in, NULL, MAN_NOTEXT }, /* in */
           { pre_SY, post_SY, 0 }, /* SY */
           { NULL, NULL, 0 }, /* YS */
         { pre_OP, NULL, 0 }, /* OP */          { pre_OP, NULL, 0 }, /* OP */
         { pre_literal, NULL, 0 }, /* EX */          { pre_literal, NULL, 0 }, /* EX */
         { pre_literal, NULL, 0 }, /* EE */          { pre_literal, NULL, 0 }, /* EE */
Line 342  pre_OP(DECL_ARGS)
Line 346  pre_OP(DECL_ARGS)
 {  {
   
         term_word(p, "[");          term_word(p, "[");
         p->flags |= TERMP_NOSPACE;          p->flags |= TERMP_KEEP | TERMP_NOSPACE;
   
         if (NULL != (n = n->child)) {          if (NULL != (n = n->child)) {
                 term_fontrepl(p, TERMFONT_BOLD);                  term_fontrepl(p, TERMFONT_BOLD);
Line 354  pre_OP(DECL_ARGS)
Line 358  pre_OP(DECL_ARGS)
         }          }
   
         term_fontrepl(p, TERMFONT_NONE);          term_fontrepl(p, TERMFONT_NONE);
           p->flags &= ~TERMP_KEEP;
         p->flags |= TERMP_NOSPACE;          p->flags |= TERMP_NOSPACE;
         term_word(p, "]");          term_word(p, "]");
         return 0;          return 0;
Line 849  post_RS(DECL_ARGS)
Line 854  post_RS(DECL_ARGS)
 }  }
   
 static int  static int
   pre_SY(DECL_ARGS)
   {
           const struct roff_node  *nn;
           int                      len;
   
           switch (n->type) {
           case ROFFT_BLOCK:
                   if (n->prev == NULL || n->prev->tok != MAN_SY)
                           print_bvspace(p, n, mt->pardist);
                   return 1;
           case ROFFT_HEAD:
           case ROFFT_BODY:
                   break;
           default:
                   abort();
           }
   
           nn = n->parent->head->child;
           len = nn == NULL ? 1 : term_strlen(p, nn->string) + 1;
   
           switch (n->type) {
           case ROFFT_HEAD:
                   p->tcol->offset = mt->offset;
                   p->tcol->rmargin = mt->offset + len;
                   p->flags |= TERMP_NOBREAK;
                   term_fontrepl(p, TERMFONT_BOLD);
                   break;
           case ROFFT_BODY:
                   mt->lmargin[mt->lmargincur] = len;
                   p->tcol->offset = mt->offset + len;
                   p->tcol->rmargin = p->maxrmargin;
                   p->flags |= TERMP_NOSPACE;
                   break;
           default:
                   abort();
           }
           return 1;
   }
   
   static void
   post_SY(DECL_ARGS)
   {
           switch (n->type) {
           case ROFFT_HEAD:
                   term_flushln(p);
                   p->flags &= ~TERMP_NOBREAK;
                   break;
           case ROFFT_BODY:
                   term_newln(p);
                   p->tcol->offset = mt->offset;
                   break;
           default:
                   break;
           }
   }
   
   static int
 pre_UR(DECL_ARGS)  pre_UR(DECL_ARGS)
 {  {
   
Line 923  print_man_node(DECL_ARGS)
Line 985  print_man_node(DECL_ARGS)
         }          }
   
         act = man_term_act(n->tok);          act = man_term_act(n->tok);
         if ((act->flags & MAN_NOTEXT) == 0)          if ((act->flags & MAN_NOTEXT) == 0 && n->tok != MAN_SM)
                 term_fontrepl(p, TERMFONT_NONE);                  term_fontrepl(p, TERMFONT_NONE);
   
         c = 1;          c = 1;
Line 935  print_man_node(DECL_ARGS)
Line 997  print_man_node(DECL_ARGS)
   
         if (act->post != NULL)          if (act->post != NULL)
                 (*act->post)(p, mt, n, meta);                  (*act->post)(p, mt, n, meta);
         if ((act->flags & MAN_NOTEXT) == 0)          if ((act->flags & MAN_NOTEXT) == 0 && n->tok != MAN_SM)
                 term_fontrepl(p, TERMFONT_NONE);                  term_fontrepl(p, TERMFONT_NONE);
   
 out:  out:

Legend:
Removed from v.1.214  
changed lines
  Added in v.1.220

CVSweb