[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.1 and 1.6

version 1.1, 2009/03/26 14:38:11 version 1.6, 2009/04/02 06:51:44
Line 25 
Line 25 
 #include "term.h"  #include "term.h"
 #include "man.h"  #include "man.h"
   
   #ifdef __linux__
   extern  size_t            strlcpy(char *, const char *, size_t);
   extern  size_t            strlcat(char *, const char *, size_t);
   #endif
   
 #define DECL_ARGS         struct termp *p, \  #define DECL_ARGS         struct termp *p, \
                           const struct man_node *n, \                            const struct man_node *n, \
                           const struct man_meta *m                            const struct man_meta *m
Line 35  struct termact {
Line 40  struct termact {
 };  };
   
 static  int               pre_B(DECL_ARGS);  static  int               pre_B(DECL_ARGS);
   static  int               pre_BI(DECL_ARGS);
   static  int               pre_BR(DECL_ARGS);
 static  int               pre_I(DECL_ARGS);  static  int               pre_I(DECL_ARGS);
   static  int               pre_IB(DECL_ARGS);
   static  int               pre_IP(DECL_ARGS);
   static  int               pre_IR(DECL_ARGS);
 static  int               pre_PP(DECL_ARGS);  static  int               pre_PP(DECL_ARGS);
   static  int               pre_RB(DECL_ARGS);
   static  int               pre_RI(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_TP(DECL_ARGS);  static  int               pre_TP(DECL_ARGS);
Line 55  static const struct termact termacts[MAN_MAX] = {
Line 67  static const struct termact termacts[MAN_MAX] = {
         { pre_PP, NULL }, /* LP */          { pre_PP, NULL }, /* LP */
         { pre_PP, NULL }, /* PP */          { pre_PP, NULL }, /* PP */
         { pre_PP, NULL }, /* P */          { pre_PP, NULL }, /* P */
         { NULL, NULL }, /* IP */          { pre_IP, NULL }, /* IP */
         { pre_PP, NULL }, /* HP */ /* XXX */          { pre_PP, NULL }, /* HP */ /* FIXME */
         { NULL, NULL }, /* SM */          { NULL, NULL }, /* SM */
         { pre_B, post_B }, /* SB */          { pre_B, post_B }, /* SB */
         { NULL, NULL }, /* BI */          { pre_BI, NULL }, /* BI */
         { NULL, NULL }, /* IB */          { pre_IB, NULL }, /* IB */
         { NULL, NULL }, /* BR */          { pre_BR, NULL }, /* BR */
         { NULL, NULL }, /* RB */          { pre_RB, NULL }, /* RB */
         { NULL, NULL }, /* R */          { NULL, NULL }, /* R */
         { pre_B, post_B }, /* B */          { pre_B, post_B }, /* B */
         { pre_I, post_I }, /* I */          { pre_I, post_I }, /* I */
         { NULL, NULL }, /* IR */          { pre_IR, NULL }, /* IR */
         { NULL, NULL }, /* RI */          { pre_RI, NULL }, /* RI */
           { pre_PP, NULL }, /* br */
           { NULL, NULL }, /* na */
 };  };
   
 static  void              print_head(struct termp *,  static  void              print_head(struct termp *,
Line 91  man_run(struct termp *p, const struct man *m)
Line 105  man_run(struct termp *p, const struct man *m)
 }  }
   
   
   /* ARGSUSED */
 static int  static int
 pre_I(DECL_ARGS)  pre_I(DECL_ARGS)
 {  {
Line 100  pre_I(DECL_ARGS)
Line 115  pre_I(DECL_ARGS)
 }  }
   
   
   /* ARGSUSED */
 static void  static void
 post_I(DECL_ARGS)  post_I(DECL_ARGS)
 {  {
Line 108  post_I(DECL_ARGS)
Line 124  post_I(DECL_ARGS)
 }  }
   
   
   /* ARGSUSED */
 static int  static int
   pre_IR(DECL_ARGS)
   {
           const struct man_node *nn;
           int              i;
   
           for (i = 0, nn = n->child; nn; nn = nn->next, i++) {
                   if ( ! (i % 2))
                           p->flags |= TERMP_UNDER;
                   if (i > 0)
                           p->flags |= TERMP_NOSPACE;
                   print_node(p, nn, m);
                   if ( ! (i % 2))
                           p->flags &= ~TERMP_UNDER;
           }
           return(0);
   }
   
   
   /* ARGSUSED */
   static int
   pre_IB(DECL_ARGS)
   {
           const struct man_node *nn;
           int              i;
   
           for (i = 0, nn = n->child; nn; nn = nn->next, i++) {
                   p->flags |= i % 2 ? TERMP_BOLD : TERMP_UNDER;
                   if (i > 0)
                           p->flags |= TERMP_NOSPACE;
                   print_node(p, nn, m);
                   p->flags &= i % 2 ? ~TERMP_BOLD : ~TERMP_UNDER;
           }
           return(0);
   }
   
   
   /* ARGSUSED */
   static int
   pre_RB(DECL_ARGS)
   {
           const struct man_node *nn;
           int              i;
   
           for (i = 0, nn = n->child; nn; nn = nn->next, i++) {
                   if (i % 2)
                           p->flags |= TERMP_BOLD;
                   if (i > 0)
                           p->flags |= TERMP_NOSPACE;
                   print_node(p, nn, m);
                   if (i % 2)
                           p->flags &= ~TERMP_BOLD;
           }
           return(0);
   }
   
   
   /* ARGSUSED */
   static int
   pre_RI(DECL_ARGS)
   {
           const struct man_node *nn;
           int              i;
   
           for (i = 0, nn = n->child; nn; nn = nn->next, i++) {
                   if ( ! (i % 2))
                           p->flags |= TERMP_UNDER;
                   if (i > 0)
                           p->flags |= TERMP_NOSPACE;
                   print_node(p, nn, m);
                   if ( ! (i % 2))
                           p->flags &= ~TERMP_UNDER;
           }
           return(0);
   }
   
   
   /* ARGSUSED */
   static int
   pre_BR(DECL_ARGS)
   {
           const struct man_node *nn;
           int              i;
   
           for (i = 0, nn = n->child; nn; nn = nn->next, i++) {
                   if ( ! (i % 2))
                           p->flags |= TERMP_BOLD;
                   if (i > 0)
                           p->flags |= TERMP_NOSPACE;
                   print_node(p, nn, m);
                   if ( ! (i % 2))
                           p->flags &= ~TERMP_BOLD;
           }
           return(0);
   }
   
   
   /* ARGSUSED */
   static int
   pre_BI(DECL_ARGS)
   {
           const struct man_node *nn;
           int              i;
   
           for (i = 0, nn = n->child; nn; nn = nn->next, i++) {
                   p->flags |= i % 2 ? TERMP_UNDER : TERMP_BOLD;
                   if (i > 0)
                           p->flags |= TERMP_NOSPACE;
                   print_node(p, nn, m);
                   p->flags &= i % 2 ? ~TERMP_UNDER : ~TERMP_BOLD;
           }
           return(0);
   }
   
   
   /* ARGSUSED */
   static int
 pre_B(DECL_ARGS)  pre_B(DECL_ARGS)
 {  {
   
Line 117  pre_B(DECL_ARGS)
Line 250  pre_B(DECL_ARGS)
 }  }
   
   
   /* ARGSUSED */
 static void  static void
 post_B(DECL_ARGS)  post_B(DECL_ARGS)
 {  {
Line 125  post_B(DECL_ARGS)
Line 259  post_B(DECL_ARGS)
 }  }
   
   
   /* ARGSUSED */
 static int  static int
 pre_PP(DECL_ARGS)  pre_PP(DECL_ARGS)
 {  {
Line 135  pre_PP(DECL_ARGS)
Line 270  pre_PP(DECL_ARGS)
 }  }
   
   
   /* ARGSUSED */
 static int  static int
   pre_IP(DECL_ARGS)
   {
           const struct man_node *nn;
           size_t           offs;
   
           term_vspace(p);
           p->offset = INDENT;
   
           if (NULL == (nn = n->child))
                   return(1);
   
           /* FIXME - ignore the designator. */
           nn = nn->next;
   
           if (MAN_TEXT != nn->type)
                   errx(1, "expected text line argument");
   
           offs = (size_t)atoi(nn->string);
           nn = nn->next;
   
           p->flags |= TERMP_NOSPACE;
           p->offset += offs;
           return(0);
   }
   
   
   /* ARGSUSED */
   static int
 pre_TP(DECL_ARGS)  pre_TP(DECL_ARGS)
 {  {
         const struct man_node *nn;          const struct man_node *nn;
Line 150  pre_TP(DECL_ARGS)
Line 314  pre_TP(DECL_ARGS)
         if (nn->line == n->line) {          if (nn->line == n->line) {
                 if (MAN_TEXT != nn->type)                  if (MAN_TEXT != nn->type)
                         errx(1, "expected text line argument");                          errx(1, "expected text line argument");
                 offs = atoi(nn->string);                  offs = (size_t)atoi(nn->string);
                 nn = nn->next;                  nn = nn->next;
         } else          } else
                 offs = INDENT;                  offs = INDENT;
Line 165  pre_TP(DECL_ARGS)
Line 329  pre_TP(DECL_ARGS)
 }  }
   
   
   /* ARGSUSED */
 static int  static int
 pre_SS(DECL_ARGS)  pre_SS(DECL_ARGS)
 {  {
Line 175  pre_SS(DECL_ARGS)
Line 340  pre_SS(DECL_ARGS)
 }  }
   
   
   /* ARGSUSED */
 static void  static void
 post_SS(DECL_ARGS)  post_SS(DECL_ARGS)
 {  {
Line 185  post_SS(DECL_ARGS)
Line 351  post_SS(DECL_ARGS)
 }  }
   
   
   /* ARGSUSED */
 static int  static int
 pre_SH(DECL_ARGS)  pre_SH(DECL_ARGS)
 {  {
Line 196  pre_SH(DECL_ARGS)
Line 363  pre_SH(DECL_ARGS)
 }  }
   
   
   /* ARGSUSED */
 static void  static void
 post_SH(DECL_ARGS)  post_SH(DECL_ARGS)
 {  {
Line 210  post_SH(DECL_ARGS)
Line 378  post_SH(DECL_ARGS)
 static void  static void
 print_node(DECL_ARGS)  print_node(DECL_ARGS)
 {  {
         int              c;          int              c, sz;
   
         c = 1;          c = 1;
   
Line 220  print_node(DECL_ARGS)
Line 388  print_node(DECL_ARGS)
                         c = (*termacts[n->tok].pre)(p, n, m);                          c = (*termacts[n->tok].pre)(p, n, m);
                 break;                  break;
         case(MAN_TEXT):          case(MAN_TEXT):
                 if (*n->string) {                  if (0 == *n->string) {
                         term_word(p, n->string);                          term_vspace(p);
                         break;                          break;
                 }                  }
                 term_vspace(p);                  /*
                    * Note!  This is hacky.  Here, we recognise the `\c'
                    * escape embedded in so many -man pages.  It's supposed
                    * to remove the subsequent space, so we mark NOSPACE if
                    * it's encountered in the string.
                    */
                   sz = (int)strlen(n->string);
                   term_word(p, n->string);
                   if (sz >= 2 && n->string[sz - 1] == 'c' &&
                                   n->string[sz - 2] == '\\')
                           p->flags |= TERMP_NOSPACE;
                 break;                  break;
         default:          default:
                 break;                  break;
Line 272  print_foot(struct termp *p, const struct man_meta *met
Line 450  print_foot(struct termp *p, const struct man_meta *met
 #endif  #endif
                 err(1, "strftime");                  err(1, "strftime");
   
         /*  
          * This is /slightly/ different from regular groff output  
          * because we don't have page numbers.  Print the following:  
          *  
          * OS                                            MDOCDATE  
          */  
   
         term_vspace(p);          term_vspace(p);
   
         p->flags |= TERMP_NOSPACE | TERMP_NOBREAK;          p->flags |= TERMP_NOSPACE | TERMP_NOBREAK;
Line 315  print_head(struct termp *p, const struct man_meta *met
Line 486  print_head(struct termp *p, const struct man_meta *met
                 err(1, "malloc");                  err(1, "malloc");
         if (NULL == (title = malloc(p->rmargin)))          if (NULL == (title = malloc(p->rmargin)))
                 err(1, "malloc");                  err(1, "malloc");
   
         /*  
          * The header is strange.  It has three components, which are  
          * really two with the first duplicated.  It goes like this:  
          *  
          * IDENTIFIER              TITLE                   IDENTIFIER  
          *  
          * The IDENTIFIER is NAME(SECTION), which is the command-name  
          * (if given, or "unknown" if not) followed by the manual page  
          * section.  These are given in `Dt'.  The TITLE is a free-form  
          * string depending on the manual volume.  If not specified, it  
          * switches on the manual section.  
          */  
   
         if (meta->vol)          if (meta->vol)
                 (void)strlcpy(buf, meta->vol, p->rmargin);                  (void)strlcpy(buf, meta->vol, p->rmargin);

Legend:
Removed from v.1.1  
changed lines
  Added in v.1.6

CVSweb