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

Diff for /mandoc/tbl.c between version 1.33 and 1.40

version 1.33, 2015/01/26 00:57:22 version 1.40, 2015/10/06 18:32:20
Line 32 
Line 32 
   
   
 enum rofferr  enum rofferr
 tbl_read(struct tbl_node *tbl, int ln, const char *p, int offs)  tbl_read(struct tbl_node *tbl, int ln, const char *p, int pos)
 {  {
         const char      *cp;          const char      *cp;
         int              active;          int              active;
Line 46  tbl_read(struct tbl_node *tbl, int ln, const char *p, 
Line 46  tbl_read(struct tbl_node *tbl, int ln, const char *p, 
         if (tbl->part == TBL_PART_OPTS) {          if (tbl->part == TBL_PART_OPTS) {
                 tbl->part = TBL_PART_LAYOUT;                  tbl->part = TBL_PART_LAYOUT;
                 active = 1;                  active = 1;
                 for (cp = p; *cp != '\0'; cp++) {                  for (cp = p + pos; *cp != '\0'; cp++) {
                         switch (*cp) {                          switch (*cp) {
                         case '(':                          case '(':
                                 active = 0;                                  active = 0;
Line 64  tbl_read(struct tbl_node *tbl, int ln, const char *p, 
Line 64  tbl_read(struct tbl_node *tbl, int ln, const char *p, 
                         break;                          break;
                 }                  }
                 if (*cp == ';') {                  if (*cp == ';') {
                         tbl_option(tbl, ln, p);                          tbl_option(tbl, ln, p, &pos);
                         if (*(p = cp + 1) == '\0')                          if (p[pos] == '\0')
                                 return(ROFF_IGN);                                  return ROFF_IGN;
                 }                  }
         }          }
   
Line 74  tbl_read(struct tbl_node *tbl, int ln, const char *p, 
Line 74  tbl_read(struct tbl_node *tbl, int ln, const char *p, 
   
         switch (tbl->part) {          switch (tbl->part) {
         case TBL_PART_LAYOUT:          case TBL_PART_LAYOUT:
                 tbl_layout(tbl, ln, p);                  tbl_layout(tbl, ln, p, pos);
                 return(ROFF_IGN);                  return ROFF_IGN;
         case TBL_PART_CDATA:          case TBL_PART_CDATA:
                 return(tbl_cdata(tbl, ln, p) ? ROFF_TBL : ROFF_IGN);                  return tbl_cdata(tbl, ln, p, pos) ? ROFF_TBL : ROFF_IGN;
         default:          default:
                 break;                  break;
         }          }
   
         tbl_data(tbl, ln, p);          tbl_data(tbl, ln, p, pos);
         return(ROFF_TBL);          return ROFF_TBL;
 }  }
   
 struct tbl_node *  struct tbl_node *
Line 91  tbl_alloc(int pos, int line, struct mparse *parse)
Line 91  tbl_alloc(int pos, int line, struct mparse *parse)
 {  {
         struct tbl_node *tbl;          struct tbl_node *tbl;
   
         tbl = mandoc_calloc(1, sizeof(struct tbl_node));          tbl = mandoc_calloc(1, sizeof(*tbl));
         tbl->line = line;          tbl->line = line;
         tbl->pos = pos;          tbl->pos = pos;
         tbl->parse = parse;          tbl->parse = parse;
         tbl->part = TBL_PART_OPTS;          tbl->part = TBL_PART_OPTS;
         tbl->opts.tab = '\t';          tbl->opts.tab = '\t';
         tbl->opts.decimal = '.';          tbl->opts.decimal = '.';
         return(tbl);          return tbl;
 }  }
   
 void  void
Line 108  tbl_free(struct tbl_node *tbl)
Line 108  tbl_free(struct tbl_node *tbl)
         struct tbl_cell *cp;          struct tbl_cell *cp;
         struct tbl_span *sp;          struct tbl_span *sp;
         struct tbl_dat  *dp;          struct tbl_dat  *dp;
         struct tbl_head *hp;  
   
         while (NULL != (rp = tbl->first_row)) {          while ((rp = tbl->first_row) != NULL) {
                 tbl->first_row = rp->next;                  tbl->first_row = rp->next;
                 while (rp->first) {                  while (rp->first != NULL) {
                         cp = rp->first;                          cp = rp->first;
                         rp->first = cp->next;                          rp->first = cp->next;
                         free(cp);                          free(cp);
Line 120  tbl_free(struct tbl_node *tbl)
Line 119  tbl_free(struct tbl_node *tbl)
                 free(rp);                  free(rp);
         }          }
   
         while (NULL != (sp = tbl->first_span)) {          while ((sp = tbl->first_span) != NULL) {
                 tbl->first_span = sp->next;                  tbl->first_span = sp->next;
                 while (sp->first) {                  while (sp->first != NULL) {
                         dp = sp->first;                          dp = sp->first;
                         sp->first = dp->next;                          sp->first = dp->next;
                         if (dp->string)                          free(dp->string);
                                 free(dp->string);  
                         free(dp);                          free(dp);
                 }                  }
                 free(sp);                  free(sp);
         }          }
   
         while (NULL != (hp = tbl->first_head)) {  
                 tbl->first_head = hp->next;  
                 free(hp);  
         }  
   
         free(tbl);          free(tbl);
 }  }
   
 void  void
 tbl_restart(int line, int pos, struct tbl_node *tbl)  tbl_restart(int line, int pos, struct tbl_node *tbl)
 {  {
         if (TBL_PART_CDATA == tbl->part)          if (tbl->part == TBL_PART_CDATA)
                 mandoc_msg(MANDOCERR_TBLBLOCK, tbl->parse,                  mandoc_msg(MANDOCERR_TBLDATA_BLK, tbl->parse,
                     tbl->line, tbl->pos, NULL);                      line, pos, "T&");
   
         tbl->part = TBL_PART_LAYOUT;          tbl->part = TBL_PART_LAYOUT;
         tbl->line = line;          tbl->line = line;
         tbl->pos = pos;          tbl->pos = pos;
   
         if (NULL == tbl->first_span || NULL == tbl->first_span->first)  
                 mandoc_msg(MANDOCERR_TBLNODATA, tbl->parse,  
                     tbl->line, tbl->pos, NULL);  
 }  }
   
 const struct tbl_span *  const struct tbl_span *
Line 166  tbl_span(struct tbl_node *tbl)
Line 155  tbl_span(struct tbl_node *tbl)
                                  : tbl->first_span;                                   : tbl->first_span;
         if (span)          if (span)
                 tbl->current_span = span;                  tbl->current_span = span;
         return(span);          return span;
 }  }
   
 void  int
 tbl_end(struct tbl_node **tblp)  tbl_end(struct tbl_node **tblp)
 {  {
         struct tbl_node *tbl;          struct tbl_node *tbl;
           struct tbl_span *sp;
   
         tbl = *tblp;          tbl = *tblp;
         *tblp = NULL;          *tblp = NULL;
   
         if (NULL == tbl->first_span || NULL == tbl->first_span->first)          if (tbl->part == TBL_PART_CDATA)
                 mandoc_msg(MANDOCERR_TBLNODATA, tbl->parse,                  mandoc_msg(MANDOCERR_TBLDATA_BLK, tbl->parse,
                     tbl->line, tbl->pos, NULL);                      tbl->line, tbl->pos, "TE");
   
         if (tbl->last_span)          sp = tbl->first_span;
                 tbl->last_span->flags |= TBL_SPAN_LAST;          while (sp != NULL && sp->first == NULL)
                   sp = sp->next;
         if (TBL_PART_CDATA == tbl->part)          if (sp == NULL) {
                 mandoc_msg(MANDOCERR_TBLBLOCK, tbl->parse,                  mandoc_msg(MANDOCERR_TBLDATA_NONE, tbl->parse,
                     tbl->line, tbl->pos, NULL);                      tbl->line, tbl->pos, NULL);
                   return 0;
           }
           return 1;
 }  }

Legend:
Removed from v.1.33  
changed lines
  Added in v.1.40

CVSweb