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

Diff for /mandoc/roff.c between version 1.295 and 1.296

version 1.295, 2017/04/29 12:45:42 version 1.296, 2017/05/04 17:48:29
Line 77  struct roffreq {
Line 77  struct roffreq {
   
 struct  roff {  struct  roff {
         struct mparse   *parse; /* parse point */          struct mparse   *parse; /* parse point */
           struct roff_man *man; /* mdoc or man parser */
         struct roffnode *last; /* leaf of stack */          struct roffnode *last; /* leaf of stack */
         int             *rstack; /* stack of inverted `ie' values */          int             *rstack; /* stack of inverted `ie' values */
         struct ohash    *reqtab; /* request lookup table */          struct ohash    *reqtab; /* request lookup table */
Line 146  static void   roffnode_push(struct roff *, enum roff_t
Line 147  static void   roffnode_push(struct roff *, enum roff_t
 static  enum rofferr     roff_block(ROFF_ARGS);  static  enum rofferr     roff_block(ROFF_ARGS);
 static  enum rofferr     roff_block_text(ROFF_ARGS);  static  enum rofferr     roff_block_text(ROFF_ARGS);
 static  enum rofferr     roff_block_sub(ROFF_ARGS);  static  enum rofferr     roff_block_sub(ROFF_ARGS);
 static  enum rofferr     roff_brp(ROFF_ARGS);  static  enum rofferr     roff_br(ROFF_ARGS);
 static  enum rofferr     roff_cblock(ROFF_ARGS);  static  enum rofferr     roff_cblock(ROFF_ARGS);
 static  enum rofferr     roff_cc(ROFF_ARGS);  static  enum rofferr     roff_cc(ROFF_ARGS);
 static  void             roff_ccond(struct roff *, int, int);  static  void             roff_ccond(struct roff *, int, int);
Line 209  static enum rofferr  roff_userdef(ROFF_ARGS);
Line 210  static enum rofferr  roff_userdef(ROFF_ARGS);
 #define ROFFNUM_WHITE   (1 << 1)  /* Skip whitespace in roff_evalnum(). */  #define ROFFNUM_WHITE   (1 << 1)  /* Skip whitespace in roff_evalnum(). */
   
 const char *__roff_name[MAN_MAX + 1] = {  const char *__roff_name[MAN_MAX + 1] = {
           "br",           NULL,
         "ab",           "ad",           "af",           "aln",          "ab",           "ad",           "af",           "aln",
         "als",          "am",           "am1",          "ami",          "als",          "am",           "am1",          "ami",
         "ami1",         "as",           "as1",          "asciify",          "ami1",         "as",           "as1",          "asciify",
Line 298  const char *__roff_name[MAN_MAX + 1] = {
Line 300  const char *__roff_name[MAN_MAX + 1] = {
         "Fr",           "Ud",           "Lb",           "Lp",          "Fr",           "Ud",           "Lb",           "Lp",
         "Lk",           "Mt",           "Brq",          "Bro",          "Lk",           "Mt",           "Brq",          "Bro",
         "Brc",          "%C",           "Es",           "En",          "Brc",          "%C",           "Es",           "En",
         "Dx",           "%Q",           "br",           "sp",          "Dx",           "%Q",           "sp",
         "%U",           "Ta",           "ll",           NULL,          "%U",           "Ta",           "ll",           NULL,
         "TH",           "SH",           "SS",           "TP",          "TH",           "SH",           "SS",           "TP",
         "LP",           "PP",           "P",            "IP",          "LP",           "PP",           "P",            "IP",
         "HP",           "SM",           "SB",           "BI",          "HP",           "SM",           "SB",           "BI",
         "IB",           "BR",           "RB",           "R",          "IB",           "BR",           "RB",           "R",
         "B",            "I",            "IR",           "RI",          "B",            "I",            "IR",           "RI",
         "br",           "sp",           "nf",           "fi",          "sp",           "nf",           "fi",
         "RE",           "RS",           "DT",           "UC",          "RE",           "RS",           "DT",           "UC",
         "PD",           "AT",           "in",           "ft",          "PD",           "AT",           "in",           "ft",
         "OP",           "EX",           "EE",           "UR",          "OP",           "EX",           "EE",           "UR",
Line 314  const char *__roff_name[MAN_MAX + 1] = {
Line 316  const char *__roff_name[MAN_MAX + 1] = {
 const   char *const *roff_name = __roff_name;  const   char *const *roff_name = __roff_name;
   
 static  struct roffmac   roffs[TOKEN_NONE] = {  static  struct roffmac   roffs[TOKEN_NONE] = {
           { roff_br, NULL, NULL, 0 },  /* br */
           { NULL, NULL, NULL, 0 },  /* ROFF_MAX */
         { roff_unsupp, NULL, NULL, 0 },  /* ab */          { roff_unsupp, NULL, NULL, 0 },  /* ab */
         { roff_line_ignore, NULL, NULL, 0 },  /* ad */          { roff_line_ignore, NULL, NULL, 0 },  /* ad */
         { roff_line_ignore, NULL, NULL, 0 },  /* af */          { roff_line_ignore, NULL, NULL, 0 },  /* af */
Line 337  static struct roffmac  roffs[TOKEN_NONE] = {
Line 341  static struct roffmac  roffs[TOKEN_NONE] = {
         { roff_unsupp, NULL, NULL, 0 },  /* break */          { roff_unsupp, NULL, NULL, 0 },  /* break */
         { roff_line_ignore, NULL, NULL, 0 },  /* breakchar */          { roff_line_ignore, NULL, NULL, 0 },  /* breakchar */
         { roff_line_ignore, NULL, NULL, 0 },  /* brnl */          { roff_line_ignore, NULL, NULL, 0 },  /* brnl */
         { roff_brp, NULL, NULL, 0 },  /* brp */          { roff_br, NULL, NULL, 0 },  /* brp */
         { roff_line_ignore, NULL, NULL, 0 },  /* brpnl */          { roff_line_ignore, NULL, NULL, 0 },  /* brpnl */
         { roff_unsupp, NULL, NULL, 0 },  /* c2 */          { roff_unsupp, NULL, NULL, 0 },  /* c2 */
         { roff_cc, NULL, NULL, 0 },  /* cc */          { roff_cc, NULL, NULL, 0 },  /* cc */
Line 610  roffhash_alloc(enum roff_tok mintok, enum roff_tok max
Line 614  roffhash_alloc(enum roff_tok mintok, enum roff_tok max
         mandoc_ohash_init(htab, 8, offsetof(struct roffreq, name));          mandoc_ohash_init(htab, 8, offsetof(struct roffreq, name));
   
         for (tok = mintok; tok < maxtok; tok++) {          for (tok = mintok; tok < maxtok; tok++) {
                   if (roff_name[tok] == NULL)
                           continue;
                 sz = strlen(roff_name[tok]);                  sz = strlen(roff_name[tok]);
                 req = mandoc_malloc(sizeof(*req) + sz + 1);                  req = mandoc_malloc(sizeof(*req) + sz + 1);
                 req->tok = tok;                  req->tok = tok;
Line 824  roff_man_alloc(struct roff *roff, struct mparse *parse
Line 830  roff_man_alloc(struct roff *roff, struct mparse *parse
         man->defos = defos;          man->defos = defos;
         man->quick = quick;          man->quick = quick;
         roff_man_alloc1(man);          roff_man_alloc1(man);
           roff->man = man;
         return man;          return man;
 }  }
   
Line 1473  roff_parseln(struct roff *r, int ln, struct buf *buf, 
Line 1480  roff_parseln(struct roff *r, int ln, struct buf *buf, 
   
         /* Execute a roff request or a user defined macro. */          /* Execute a roff request or a user defined macro. */
   
         return (*roffs[t].proc)(r, t, buf, ln, ppos, pos, offs);          return (*roffs[t].proc)(r, t, buf, ln, spos, pos, offs);
 }  }
   
 void  void
Line 2633  roff_T_(ROFF_ARGS)
Line 2640  roff_T_(ROFF_ARGS)
                 mandoc_msg(MANDOCERR_BLK_NOTOPEN, r->parse,                  mandoc_msg(MANDOCERR_BLK_NOTOPEN, r->parse,
                     ln, ppos, "T&");                      ln, ppos, "T&");
         else          else
                 tbl_restart(ppos, ln, r->tbl);                  tbl_restart(ln, ppos, r->tbl);
   
         return ROFF_IGN;          return ROFF_IGN;
 }  }
Line 2760  roff_TS(ROFF_ARGS)
Line 2767  roff_TS(ROFF_ARGS)
 }  }
   
 static enum rofferr  static enum rofferr
 roff_brp(ROFF_ARGS)  roff_br(ROFF_ARGS)
 {  {
           roff_elem_alloc(r->man, ln, ppos, ROFF_br);
         buf->buf[pos - 1] = '\0';          if (buf->buf[pos] != '\0')
         return ROFF_CONT;                  mandoc_vmsg(MANDOCERR_ARG_SKIP, r->parse, ln, pos,
                       "%s %s", roff_name[tok], buf->buf + pos);
           r->man->last->flags |= NODE_LINE | NODE_VALID | NODE_ENDED;
           r->man->next = ROFF_NEXT_SIBLING;
           return ROFF_IGN;
 }  }
   
 static enum rofferr  static enum rofferr

Legend:
Removed from v.1.295  
changed lines
  Added in v.1.296

CVSweb