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

Diff for /mandoc/roff.c between version 1.117 and 1.120

version 1.117, 2011/01/01 16:18:39 version 1.120, 2011/01/03 23:24:16
Line 1 
Line 1 
 /*      $Id$ */  /*      $Id$ */
 /*  /*
  * Copyright (c) 2010 Kristaps Dzonsons <kristaps@bsd.lv>   * Copyright (c) 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2010 Ingo Schwarze <schwarze@openbsd.org>   * Copyright (c) 2010, 2011 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 86  struct roff {
Line 86  struct roff {
         struct regset   *regs; /* read/writable registers */          struct regset   *regs; /* read/writable registers */
         struct roffstr  *first_string; /* user-defined strings & macros */          struct roffstr  *first_string; /* user-defined strings & macros */
         const char      *current_string; /* value of last called user macro */          const char      *current_string; /* value of last called user macro */
         struct tbl      *first_tbl; /* first table parsed */          struct tbl_node *first_tbl; /* first table parsed */
         struct tbl      *last_tbl; /* last table parsed */          struct tbl_node *last_tbl; /* last table parsed */
         struct tbl      *tbl; /* current table being parsed */          struct tbl_node *tbl; /* current table being parsed */
 };  };
   
 struct  roffnode {  struct  roffnode {
Line 301  roffnode_push(struct roff *r, enum rofft tok, const ch
Line 301  roffnode_push(struct roff *r, enum rofft tok, const ch
 static void  static void
 roff_free1(struct roff *r)  roff_free1(struct roff *r)
 {  {
         struct tbl      *t;          struct tbl_node *t;
   
         while (r->first_tbl) {          while (r->first_tbl) {
                 t = r->first_tbl;                  t = r->first_tbl;
Line 1152  roff_T_(ROFF_ARGS)
Line 1152  roff_T_(ROFF_ARGS)
 static enum rofferr  static enum rofferr
 roff_TS(ROFF_ARGS)  roff_TS(ROFF_ARGS)
 {  {
         struct tbl      *t;          struct tbl_node *t;
   
         if (r->tbl) {          if (r->tbl) {
                 (*r->msg)(MANDOCERR_SCOPEBROKEN, r->data, ln, ppos, NULL);                  (*r->msg)(MANDOCERR_SCOPEBROKEN, r->data, ln, ppos, NULL);
Line 1201  roff_userdef(ROFF_ARGS)
Line 1201  roff_userdef(ROFF_ARGS)
 {  {
         const char       *arg[9];          const char       *arg[9];
         char             *cp, *n1, *n2;          char             *cp, *n1, *n2;
         int               i, quoted, pairs;          int               i;
   
         /*          /*
          * Collect pointers to macro argument strings           * Collect pointers to macro argument strings
          * and null-terminate them.           * and null-terminate them.
          */           */
         cp = *bufp + pos;          cp = *bufp + pos;
         for (i = 0; i < 9; i++) {          for (i = 0; i < 9; i++)
                 /* Quoting can only start with a new word. */                  arg[i] = '\0' == *cp ? "" :
                 if ('"' == *cp) {                      mandoc_getarg(&cp, r->msg, r->data, ln, &pos);
                         quoted = 1;  
                         cp++;  
                 } else  
                         quoted = 0;  
                 arg[i] = cp;  
                 for (pairs = 0; '\0' != *cp; cp++) {  
                         /* Unquoted arguments end at blanks. */  
                         if (0 == quoted) {  
                                 if (' ' == *cp)  
                                         break;  
                                 continue;  
                         }  
                         /* After pairs of quotes, move left. */  
                         if (pairs)  
                                 cp[-pairs] = cp[0];  
                         /* Pairs of quotes do not end words, ... */  
                         if ('"' == cp[0] && '"' == cp[1]) {  
                                 pairs++;  
                                 cp++;  
                                 continue;  
                         }  
                         /* ... but solitary quotes do. */  
                         if ('"' != *cp)  
                                 continue;  
                         if (pairs)  
                                 cp[-pairs] = '\0';  
                         *cp = ' ';  
                         break;  
                 }  
                 /* Last argument; the remaining ones are empty strings. */  
                 if ('\0' == *cp)  
                         continue;  
                 /* Null-terminate argument and move to the next one. */  
                 *cp++ = '\0';  
                 while (' ' == *cp)  
                         cp++;  
         }  
   
         /*          /*
          * Expand macro arguments.           * Expand macro arguments.

Legend:
Removed from v.1.117  
changed lines
  Added in v.1.120

CVSweb