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

Diff for /mandoc/tbl_html.c between version 1.22 and 1.26

version 1.22, 2017/06/12 20:14:18 version 1.26, 2018/11/25 19:24:20
Line 1 
Line 1 
 /*      $Id$ */  /*      $Id$ */
 /*  /*
  * Copyright (c) 2011 Kristaps Dzonsons <kristaps@bsd.lv>   * Copyright (c) 2011 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2014, 2015, 2017 Ingo Schwarze <schwarze@openbsd.org>   * Copyright (c) 2014, 2015, 2017, 2018 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 49  html_tbl_strlen(const char *p, void *arg)
Line 49  html_tbl_strlen(const char *p, void *arg)
 static size_t  static size_t
 html_tbl_sulen(const struct roffsu *su, void *arg)  html_tbl_sulen(const struct roffsu *su, void *arg)
 {  {
           if (su->scale < 0.0)
                   return 0;
   
         switch (su->unit) {          switch (su->unit) {
         case SCALE_FS:  /* 2^16 basic units */          case SCALE_FS:  /* 2^16 basic units */
                 return su->scale * 65536.0 / 24.0;                  return su->scale * 65536.0 / 24.0;
Line 76  html_tbl_sulen(const struct roffsu *su, void *arg)
Line 79  html_tbl_sulen(const struct roffsu *su, void *arg)
 static void  static void
 html_tblopen(struct html *h, const struct tbl_span *sp)  html_tblopen(struct html *h, const struct tbl_span *sp)
 {  {
         struct tag      *t;  
         int              ic;  
   
         if (h->tbl.cols == NULL) {          if (h->tbl.cols == NULL) {
                 h->tbl.len = html_tbl_len;                  h->tbl.len = html_tbl_len;
                 h->tbl.slen = html_tbl_strlen;                  h->tbl.slen = html_tbl_strlen;
                 h->tbl.sulen = html_tbl_sulen;                  h->tbl.sulen = html_tbl_sulen;
                 tblcalc(&h->tbl, sp, 0, 0);                  tblcalc(&h->tbl, sp, 0, 0);
         }          }
   
         assert(NULL == h->tblt);          assert(NULL == h->tblt);
         h->tblt = print_otag(h, TAG_TABLE, "c", "tbl");          h->tblt = print_otag(h, TAG_TABLE, "c", "tbl");
   
         t = print_otag(h, TAG_COLGROUP, "");  
         for (ic = 0; ic < sp->opts->cols; ic++)  
                 print_otag(h, TAG_COL, "shw", h->tbl.cols[ic].width);  
         print_tagq(h, t);  
 }  }
   
 void  void
Line 107  print_tblclose(struct html *h)
Line 101  print_tblclose(struct html *h)
 void  void
 print_tbl(struct html *h, const struct tbl_span *sp)  print_tbl(struct html *h, const struct tbl_span *sp)
 {  {
         const struct tbl_dat *dp;          const struct tbl_dat    *dp;
         struct tag      *tt;          struct tag              *tt;
         int              ic;          const char              *hspans, *vspans, *halign, *valign;
           char                     hbuf[4], vbuf[4];
   
         /* Inhibit printing of spaces: we do padding ourselves. */          /* Inhibit printing of spaces: we do padding ourselves. */
   
Line 129  print_tbl(struct html *h, const struct tbl_span *sp)
Line 124  print_tbl(struct html *h, const struct tbl_span *sp)
                 print_otag(h, TAG_TD, "?", "colspan", "0");                  print_otag(h, TAG_TD, "?", "colspan", "0");
                 break;                  break;
         default:          default:
                 dp = sp->first;                  for (dp = sp->first; dp != NULL; dp = dp->next) {
                 for (ic = 0; ic < sp->opts->cols; ic++) {  
                         print_stagq(h, tt);                          print_stagq(h, tt);
                         print_otag(h, TAG_TD, "");                          switch (dp->layout->pos) {
                           case TBL_CELL_SPAN:
                         if (dp == NULL || dp->layout->col > ic)                          case TBL_CELL_DOWN:
                                 continue;                                  continue;
                         if (dp->layout->pos != TBL_CELL_DOWN)                          default:
                                 if (dp->string != NULL)                                  break;
                                         print_text(h, dp->string);                          }
                         dp = dp->next;  
                           /* Determine the attribute values. */
   
                           if (dp->hspans > 0) {
                                   (void)snprintf(hbuf, sizeof(hbuf),
                                       "%d", dp->hspans + 1);
                                   hspans = hbuf;
                           } else
                                   hspans = NULL;
                           if (dp->vspans > 0) {
                                   (void)snprintf(vbuf, sizeof(vbuf),
                                       "%d", dp->vspans + 1);
                                   vspans = vbuf;
                           } else
                                   vspans = NULL;
   
                           switch (dp->layout->pos) {
                           case TBL_CELL_CENTRE:
                                   halign = "center";
                                   break;
                           case TBL_CELL_RIGHT:
                           case TBL_CELL_NUMBER:
                                   halign = "right";
                                   break;
                           default:
                                   halign = NULL;
                                   break;
                           }
                           if (dp->layout->flags & TBL_CELL_TALIGN)
                                   valign = "top";
                           else if (dp->layout->flags & TBL_CELL_BALIGN)
                                   valign = "bottom";
                           else
                                   valign = NULL;
   
                           /* Print the element and the attributes. */
   
                           if (halign == NULL && valign == NULL)
                                   print_otag(h, TAG_TD, "??",
                                       "colspan", hspans, "rowspan", vspans);
                           else if (halign == NULL)
                                   print_otag(h, TAG_TD, "??s",
                                       "colspan", hspans, "rowspan", vspans,
                                       "vertical-align", valign);
                           else if (valign == NULL)
                                   print_otag(h, TAG_TD, "??s",
                                       "colspan", hspans, "rowspan", vspans,
                                       "text-align", halign);
                           else
                                   print_otag(h, TAG_TD, "??ss",
                                       "colspan", hspans, "rowspan", vspans,
                                       "vertical-align", valign,
                                       "text-align", halign);
                           if (dp->string != NULL)
                                   print_text(h, dp->string);
                 }                  }
                 break;                  break;
         }          }
Line 154  print_tbl(struct html *h, const struct tbl_span *sp)
Line 202  print_tbl(struct html *h, const struct tbl_span *sp)
                 h->tbl.cols = NULL;                  h->tbl.cols = NULL;
                 print_tblclose(h);                  print_tblclose(h);
         }          }
   
 }  }

Legend:
Removed from v.1.22  
changed lines
  Added in v.1.26

CVSweb