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

Diff for /mandoc/mandoc.c between version 1.82 and 1.89

version 1.82, 2014/07/06 18:37:34 version 1.89, 2014/12/15 17:30:30
Line 15 
Line 15 
  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF   * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.   * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  */   */
 #ifdef HAVE_CONFIG_H  
 #include "config.h"  #include "config.h"
 #endif  
   
 #include <sys/types.h>  #include <sys/types.h>
   
Line 81  mandoc_escape(const char **end, const char **start, in
Line 79  mandoc_escape(const char **end, const char **start, in
                 break;                  break;
         case '[':          case '[':
                 gly = ESCAPE_SPECIAL;                  gly = ESCAPE_SPECIAL;
                 /*  
                  * Unicode escapes are defined in groff as \[uXXXX] to  
                  * \[u10FFFF], where the contained value must be a valid  
                  * Unicode codepoint.  Here, however, only check whether  
                  * it's not a zero-width escape.  
                  */  
                 if ('u' == (*start)[0] && ']' != (*start)[1])  
                         gly = ESCAPE_UNICODE;  
                 term = ']';                  term = ']';
                 break;                  break;
         case 'C':          case 'C':
                 if ('\'' != **start)                  if ('\'' != **start)
                         return(ESCAPE_ERROR);                          return(ESCAPE_ERROR);
                 *start = ++*end;                  *start = ++*end;
                 if ('u' == (*start)[0] && '\'' != (*start)[1])                  gly = ESCAPE_SPECIAL;
                         gly = ESCAPE_UNICODE;  
                 else  
                         gly = ESCAPE_SPECIAL;  
                 term = '\'';                  term = '\'';
                 break;                  break;
   
Line 201  mandoc_escape(const char **end, const char **start, in
Line 188  mandoc_escape(const char **end, const char **start, in
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
         case 'x':          case 'x':
                 if (strchr(" %&()*+-./0123456789:<=>", **start)) {                  if (strchr(" %&()*+-./0123456789:<=>", **start)) {
                         ++*end;                          if ('\0' != **start)
                                   ++*end;
                         return(ESCAPE_ERROR);                          return(ESCAPE_ERROR);
                 }                  }
                 gly = ESCAPE_IGNORE;                  gly = ESCAPE_IGNORE;
Line 345  mandoc_escape(const char **end, const char **start, in
Line 333  mandoc_escape(const char **end, const char **start, in
         case ESCAPE_SPECIAL:          case ESCAPE_SPECIAL:
                 if (1 == *sz && 'c' == **start)                  if (1 == *sz && 'c' == **start)
                         gly = ESCAPE_NOSPACE;                          gly = ESCAPE_NOSPACE;
                   /*
                    * Unicode escapes are defined in groff as \[u0000]
                    * to \[u10FFFF], where the contained value must be
                    * a valid Unicode codepoint.  Here, however, only
                    * check the length and range.
                    */
                   if (**start != 'u' || *sz < 5 || *sz > 7)
                           break;
                   if (*sz == 7 && ((*start)[1] != '1' || (*start)[2] != '0'))
                           break;
                   if (*sz == 6 && (*start)[1] == '0')
                           break;
                   if ((int)strspn(*start + 1, "0123456789ABCDEFabcdef")
                       + 1 == *sz)
                           gly = ESCAPE_UNICODE;
                 break;                  break;
         default:          default:
                 break;                  break;
Line 429  mandoc_getarg(struct mparse *parse, char **cpp, int ln
Line 432  mandoc_getarg(struct mparse *parse, char **cpp, int ln
   
         /* Quoted argument without a closing quote. */          /* Quoted argument without a closing quote. */
         if (1 == quoted)          if (1 == quoted)
                 mandoc_msg(MANDOCERR_BADQUOTE, parse, ln, *pos, NULL);                  mandoc_msg(MANDOCERR_ARG_QUOTE, parse, ln, *pos, NULL);
   
         /* NUL-terminate this argument and move to the next one. */          /* NUL-terminate this argument and move to the next one. */
         if (pairs)          if (pairs)
Line 443  mandoc_getarg(struct mparse *parse, char **cpp, int ln
Line 446  mandoc_getarg(struct mparse *parse, char **cpp, int ln
         *cpp = cp;          *cpp = cp;
   
         if ('\0' == *cp && (white || ' ' == cp[-1]))          if ('\0' == *cp && (white || ' ' == cp[-1]))
                 mandoc_msg(MANDOCERR_EOLNSPACE, parse, ln, *pos, NULL);                  mandoc_msg(MANDOCERR_SPACE_EOL, parse, ln, *pos, NULL);
   
         return(start);          return(start);
 }  }
Line 457  a2time(time_t *t, const char *fmt, const char *p)
Line 460  a2time(time_t *t, const char *fmt, const char *p)
         memset(&tm, 0, sizeof(struct tm));          memset(&tm, 0, sizeof(struct tm));
   
         pp = NULL;          pp = NULL;
 #ifdef  HAVE_STRPTIME  #if HAVE_STRPTIME
         pp = strptime(p, fmt, &tm);          pp = strptime(p, fmt, &tm);
 #endif  #endif
         if (NULL != pp && '\0' == *pp) {          if (NULL != pp && '\0' == *pp) {
Line 477  time2a(time_t t)
Line 480  time2a(time_t t)
         int              isz;          int              isz;
   
         tm = localtime(&t);          tm = localtime(&t);
           if (tm == NULL)
                   return(NULL);
   
         /*          /*
          * Reserve space:           * Reserve space:

Legend:
Removed from v.1.82  
changed lines
  Added in v.1.89

CVSweb