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

Diff for /mandoc/tbl_data.c between version 1.24 and 1.29

version 1.24, 2011/03/20 16:02:05 version 1.29, 2014/03/23 11:25:26
Line 26 
Line 26 
 #include <time.h>  #include <time.h>
   
 #include "mandoc.h"  #include "mandoc.h"
   #include "mandoc_aux.h"
 #include "libmandoc.h"  #include "libmandoc.h"
 #include "libroff.h"  #include "libroff.h"
   
 static  int              data(struct tbl_node *, struct tbl_span *,  static  int              getdata(struct tbl_node *, struct tbl_span *,
                                 int, const char *, int *);                                  int, const char *, int *);
 static  struct tbl_span *newspan(struct tbl_node *, int,  static  struct tbl_span *newspan(struct tbl_node *, int,
                                 struct tbl_row *);                                  struct tbl_row *);
   
 static int  static int
 data(struct tbl_node *tbl, struct tbl_span *dp,  getdata(struct tbl_node *tbl, struct tbl_span *dp,
                 int ln, const char *p, int *pos)                  int ln, const char *p, int *pos)
 {  {
         struct tbl_dat  *dat;          struct tbl_dat  *dat;
Line 49  data(struct tbl_node *tbl, struct tbl_span *dp, 
Line 50  data(struct tbl_node *tbl, struct tbl_span *dp, 
                 cp = dp->layout->first;                  cp = dp->layout->first;
   
         /*          /*
          * Skip over spanners and vertical lines to data formats, since           * Skip over spanners, since
          * we want to match data with data layout cells in the header.           * we want to match data with data layout cells in the header.
          */           */
   
         while (cp && (TBL_CELL_VERT == cp->pos ||          while (cp && TBL_CELL_SPAN == cp->pos)
                                 TBL_CELL_DVERT == cp->pos ||  
                                 TBL_CELL_SPAN == cp->pos))  
                 cp = cp->next;                  cp = cp->next;
   
         /*          /*
Line 104  data(struct tbl_node *tbl, struct tbl_span *dp, 
Line 103  data(struct tbl_node *tbl, struct tbl_span *dp, 
   
         if (*pos - sv == 2 && 'T' == p[sv] && '{' == p[sv + 1]) {          if (*pos - sv == 2 && 'T' == p[sv] && '{' == p[sv + 1]) {
                 tbl->part = TBL_PART_CDATA;                  tbl->part = TBL_PART_CDATA;
                 return(0);                  return(1);
         }          }
   
         assert(*pos - sv >= 0);          assert(*pos - sv >= 0);
Line 154  tbl_cdata(struct tbl_node *tbl, int ln, const char *p)
Line 153  tbl_cdata(struct tbl_node *tbl, int ln, const char *p)
                 if (p[pos] == tbl->opts.tab) {                  if (p[pos] == tbl->opts.tab) {
                         tbl->part = TBL_PART_DATA;                          tbl->part = TBL_PART_DATA;
                         pos++;                          pos++;
                         return(data(tbl, tbl->last_span, ln, p, &pos));                          return(getdata(tbl, tbl->last_span, ln, p, &pos));
                 } else if ('\0' == p[pos]) {                  } else if ('\0' == p[pos]) {
                         tbl->part = TBL_PART_DATA;                          tbl->part = TBL_PART_DATA;
                         return(1);                          return(1);
Line 187  newspan(struct tbl_node *tbl, int line, struct tbl_row
Line 186  newspan(struct tbl_node *tbl, int line, struct tbl_row
   
         dp = mandoc_calloc(1, sizeof(struct tbl_span));          dp = mandoc_calloc(1, sizeof(struct tbl_span));
         dp->line = line;          dp->line = line;
         dp->tbl = &tbl->opts;          dp->opts = &tbl->opts;
         dp->layout = rp;          dp->layout = rp;
         dp->head = tbl->first_head;          dp->head = tbl->first_head;
   
Line 269  tbl_data(struct tbl_node *tbl, int ln, const char *p)
Line 268  tbl_data(struct tbl_node *tbl, int ln, const char *p)
         /* This returns 0 when TBL_PART_CDATA is entered. */          /* This returns 0 when TBL_PART_CDATA is entered. */
   
         while ('\0' != p[pos])          while ('\0' != p[pos])
                 if ( ! data(tbl, dp, ln, p, &pos))                  if ( ! getdata(tbl, dp, ln, p, &pos))
                         return(0);                          return(0);
   
         return(1);          return(1);

Legend:
Removed from v.1.24  
changed lines
  Added in v.1.29

CVSweb