[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.91

version 1.82, 2014/07/06 18:37:34 version 1.91, 2015/01/21 20:33:25
Line 1 
Line 1 
 /*      $Id$ */  /*      $Id$ */
 /*  /*
  * Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>   * Copyright (c) 2008-2011, 2014 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2011, 2012, 2013, 2014 Ingo Schwarze <schwarze@openbsd.org>   * Copyright (c) 2011-2015 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 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 169  mandoc_escape(const char **end, const char **start, in
Line 156  mandoc_escape(const char **end, const char **start, in
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
         case 'D':          case 'D':
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
         case 'o':  
                 /* FALLTHROUGH */  
         case 'R':          case 'R':
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
         case 'X':          case 'X':
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
         case 'Z':          case 'Z':
                 if ('\0' == **start)  
                         return(ESCAPE_ERROR);  
                 gly = ESCAPE_IGNORE;                  gly = ESCAPE_IGNORE;
                   /* FALLTHROUGH */
           case 'o':
                   if (**start == '\0')
                           return(ESCAPE_ERROR);
                   if (gly == ESCAPE_ERROR)
                           gly = ESCAPE_OVERSTRIKE;
                 term = **start;                  term = **start;
                 *start = ++*end;                  *start = ++*end;
                 break;                  break;
Line 201  mandoc_escape(const char **end, const char **start, in
Line 190  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 237  mandoc_escape(const char **end, const char **start, in
Line 227  mandoc_escape(const char **end, const char **start, in
   
                 /* See +/- counts as a sign. */                  /* See +/- counts as a sign. */
                 if ('+' == **end || '-' == **end || ASCII_HYPH == **end)                  if ('+' == **end || '-' == **end || ASCII_HYPH == **end)
                         (*end)++;                          *start = ++*end;
   
                 switch (**end) {                  switch (**end) {
                 case '(':                  case '(':
Line 345  mandoc_escape(const char **end, const char **start, in
Line 335  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 434  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 448  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 462  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 482  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.91

CVSweb