* io/Versions (__dup2, __pipe): Added to GLIBC_2.0 for
[kopensolaris-gnu/glibc.git] / posix / fnmatch.c
index 2d6f6af..dc389ef 100644 (file)
@@ -136,7 +136,7 @@ fnmatch (pattern, string, flags)
      int flags;
 {
   register const char *p = pattern, *n = string;
      int flags;
 {
   register const char *p = pattern, *n = string;
-  register char c;
+  register unsigned char c;
 
 /* Note that this evaluates C many times.  */
 # ifdef _LIBC
 
 /* Note that this evaluates C many times.  */
 # ifdef _LIBC
@@ -170,7 +170,7 @@ fnmatch (pattern, string, flags)
                return FNM_NOMATCH;
              c = FOLD (c);
            }
                return FNM_NOMATCH;
              c = FOLD (c);
            }
-         if (FOLD (*n) != c)
+         if (FOLD ((unsigned char) *n) != c)
            return FNM_NOMATCH;
          break;
 
            return FNM_NOMATCH;
          break;
 
@@ -202,10 +202,10 @@ fnmatch (pattern, string, flags)
            return 0;
 
          {
            return 0;
 
          {
-           char c1 = (!(flags & FNM_NOESCAPE) && c == '\\') ? *p : c;
+           unsigned char c1 = (!(flags & FNM_NOESCAPE) && c == '\\') ? *p : c;
            c1 = FOLD (c1);
            for (--p; *n != '\0'; ++n)
            c1 = FOLD (c1);
            for (--p; *n != '\0'; ++n)
-             if ((c == '[' || FOLD (*n) == c1) &&
+             if ((c == '[' || FOLD ((unsigned char) *n) == c1) &&
                  fnmatch (p, n, flags & ~FNM_PERIOD) == 0)
                return 0;
            return FNM_NOMATCH;
                  fnmatch (p, n, flags & ~FNM_PERIOD) == 0)
                return 0;
            return FNM_NOMATCH;
@@ -239,13 +239,14 @@ fnmatch (pattern, string, flags)
            c = *p++;
            for (;;)
              {
            c = *p++;
            for (;;)
              {
-               int fn = FOLD (*n);
+               unsigned char fn = FOLD ((unsigned char) *n);
 
                if (!(flags & FNM_NOESCAPE) && c == '\\')
                  {
                    if (*p == '\0')
                      return FNM_NOMATCH;
 
                if (!(flags & FNM_NOESCAPE) && c == '\\')
                  {
                    if (*p == '\0')
                      return FNM_NOMATCH;
-                   c = FOLD (*p++);
+                   c = FOLD ((unsigned char) *p);
+                   ++p;
 
                    if (c == fn)
                      goto matched;
 
                    if (c == fn)
                      goto matched;
@@ -282,21 +283,21 @@ fnmatch (pattern, string, flags)
                      /* Invalid character class name.  */
                      return FNM_NOMATCH;
 
                      /* Invalid character class name.  */
                      return FNM_NOMATCH;
 
-                   if (__iswctype (__btowc (*n), wt))
+                   if (__iswctype (__btowc ((unsigned char) *n), wt))
                      goto matched;
 # else
                      goto matched;
 # else
-                   if ((STREQ (str, "alnum") && ISALNUM (*n))
-                       || (STREQ (str, "alpha") && ISALPHA (*n))
-                       || (STREQ (str, "blank") && ISBLANK (*n))
-                       || (STREQ (str, "cntrl") && ISCNTRL (*n))
-                       || (STREQ (str, "digit") && ISDIGIT (*n))
-                       || (STREQ (str, "graph") && ISGRAPH (*n))
-                       || (STREQ (str, "lower") && ISLOWER (*n))
-                       || (STREQ (str, "print") && ISPRINT (*n))
-                       || (STREQ (str, "punct") && ISPUNCT (*n))
-                       || (STREQ (str, "space") && ISSPACE (*n))
-                       || (STREQ (str, "upper") && ISUPPER (*n))
-                       || (STREQ (str, "xdigit") && ISXDIGIT (*n)))
+                   if ((STREQ (str, "alnum") && ISALNUM ((unsigned char) *n))
+                       || (STREQ (str, "alpha") && ISALPHA ((unsigned char) *n))
+                       || (STREQ (str, "blank") && ISBLANK ((unsigned char) *n))
+                       || (STREQ (str, "cntrl") && ISCNTRL ((unsigned char) *n))
+                       || (STREQ (str, "digit") && ISDIGIT ((unsigned char) *n))
+                       || (STREQ (str, "graph") && ISGRAPH ((unsigned char) *n))
+                       || (STREQ (str, "lower") && ISLOWER ((unsigned char) *n))
+                       || (STREQ (str, "print") && ISPRINT ((unsigned char) *n))
+                       || (STREQ (str, "punct") && ISPUNCT ((unsigned char) *n))
+                       || (STREQ (str, "space") && ISSPACE ((unsigned char) *n))
+                       || (STREQ (str, "upper") && ISUPPER ((unsigned char) *n))
+                       || (STREQ (str, "xdigit") && ISXDIGIT ((unsigned char) *n)))
                      goto matched;
 # endif
                  }
                      goto matched;
 # endif
                  }
@@ -312,7 +313,7 @@ fnmatch (pattern, string, flags)
                if (c == '-' && *p != ']')
                  {
                    /* It is a range.  */
                if (c == '-' && *p != ']')
                  {
                    /* It is a range.  */
-                   char cend = *p++;
+                   unsigned char cend = *p++;
                    if (!(flags & FNM_NOESCAPE) && cend == '\\')
                      cend = *p++;
                    if (cend == '\0')
                    if (!(flags & FNM_NOESCAPE) && cend == '\\')
                      cend = *p++;
                    if (cend == '\0')
@@ -363,7 +364,7 @@ fnmatch (pattern, string, flags)
          break;
 
        default:
          break;
 
        default:
-         if (c != FOLD (*n))
+         if (c != FOLD ((unsigned char) *n))
            return FNM_NOMATCH;
        }
 
            return FNM_NOMATCH;
        }