]> granicus.if.org Git - yasm/commitdiff
Check for case-insensitive string comparisons. Use strcasecmp and strncasecmp
authorPeter Johnson <peter@tortall.net>
Sun, 16 Sep 2001 09:13:00 +0000 (09:13 -0000)
committerPeter Johnson <peter@tortall.net>
Sun, 16 Sep 2001 09:13:00 +0000 (09:13 -0000)
in the source: if stricmp or strcmpi is available, they're mapped to
strcasecmp.

svn path=/trunk/yasm/; revision=159

configure.ac
configure.in
libyasm/strcasecmp.c [new file with mode: 0644]
libyasm/util.h
src/Makefile.am
src/strcasecmp.c [new file with mode: 0644]
src/util.h
util.h

index 8e4e11e58c9cc7e3b7887a21c5fed9ee1003a4e4..8af8f6c0830482fc4dbbae764393e5db8ff69234 100644 (file)
@@ -31,7 +31,7 @@ AC_C_CONST
 AC_TYPE_SIZE_T
 
 AC_FUNC_VPRINTF
-AC_CHECK_FUNCS(memcpy toascii abort)
+AC_CHECK_FUNCS(memcpy toascii abort strcasecmp stricmp strcmpi)
 AC_REPLACE_FUNCS(strdup strtoul)
 
 AC_CHECK_HEADERS(limits.h sys/queue.h sys/cdefs.h)
index 8e4e11e58c9cc7e3b7887a21c5fed9ee1003a4e4..8af8f6c0830482fc4dbbae764393e5db8ff69234 100644 (file)
@@ -31,7 +31,7 @@ AC_C_CONST
 AC_TYPE_SIZE_T
 
 AC_FUNC_VPRINTF
-AC_CHECK_FUNCS(memcpy toascii abort)
+AC_CHECK_FUNCS(memcpy toascii abort strcasecmp stricmp strcmpi)
 AC_REPLACE_FUNCS(strdup strtoul)
 
 AC_CHECK_HEADERS(limits.h sys/queue.h sys/cdefs.h)
diff --git a/libyasm/strcasecmp.c b/libyasm/strcasecmp.c
new file mode 100644 (file)
index 0000000..1975b43
--- /dev/null
@@ -0,0 +1,82 @@
+/* $Id: strcasecmp.c,v 1.1 2001/09/16 09:13:00 peter Exp $
+ * strcasecmp() implementation for systems that don't have it or stricmp()
+ * or strcmpi().
+ *
+ * Copyright (c) 1987, 1993
+ *     The Regents of the University of California.  All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. Neither the name of the University nor the names of its contributors
+ *    may be used to endorse or promote products derived from this software
+ *    without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include "util.h"
+
+#ifdef USE_OUR_OWN_STRCASECMP
+
+#if defined(LIBC_SCCS) && !defined(lint)
+static char sccsid[] = "@(#)strcasecmp.c       8.1 (Berkeley) 6/4/93";
+#endif /* LIBC_SCCS and not lint */
+
+#ifdef STDC_HEADERS
+# include <string.h>
+# include <ctype.h>
+#endif
+
+RCSID("$Id: strcasecmp.c,v 1.1 2001/09/16 09:13:00 peter Exp $");
+
+int
+strcasecmp(const char *s1, const char *s2)
+{
+       const unsigned char
+                       *us1 = (const unsigned char *)s1,
+                       *us2 = (const unsigned char *)s2;
+
+       while (tolower(*us1) == tolower(*us2++))
+               if (*us1++ == '\0')
+                       return (0);
+       return (tolower(*us1) - tolower(*--us2));
+}
+
+int
+strncasecmp(const char *s1, const char *s2, size_t n)
+{
+       const unsigned char
+                       *us1 = (const unsigned char *)s1,
+                       *us2 = (const unsigned char *)s2;
+
+       if (n != 0) {
+               do {
+                       if (tolower(*us1) != tolower(*us2++))
+                               return (tolower(*us1) - tolower(*--us2));
+                       if (*us1++ == '\0')
+                               break;
+               } while (--n != 0);
+       }
+       return (0);
+}
+#endif
index 2d91d1b3dfe5492b82ce211963a2c28ef00ea960..d6741dac14bec93f38a0b7ea489cbf34c1cd616e 100644 (file)
@@ -1,4 +1,4 @@
-/* $Id: util.h,v 1.6 2001/08/19 07:32:39 peter Exp $
+/* $Id: util.h,v 1.7 2001/09/16 09:13:00 peter Exp $
  * Defines prototypes for replacement functions if needed.
  *
  *  Copyright (C) 2001  Peter Johnson
@@ -30,6 +30,18 @@ char *strdup(const char *str);
 unsigned long strtoul(const char *nptr, char **endptr, int base);
 #endif
 
+#ifndef HAVE_STRCASECMP
+# ifdef HAVE_STRICMP
+#  define strcasecmp(x, y)     stricmp(x, y)
+#  define strncasecmp(x, y)    strnicmp(x, y)
+# elif HAVE_STRCMPI
+#  define strcasecmp(x, y)     strcmpi(x, y)
+#  define strcasecmp(x, y)     strncmpi(x, y)
+# else
+#  define USE_OUR_OWN_STRCASECMP
+# endif
+#endif
+
 #ifndef HAVE_TOASCII
 # define toascii(c) ((c) & 0x7F)
 #endif
index fbb3381683f8ccd7dc6095e6a29077e847072072..d648ac7fad8777a5e619817492ede3d73836b0de 100644 (file)
@@ -20,7 +20,8 @@ yasm_SOURCES = \
        objfmt.h                \
        preproc.h               \
        parser.c                \
-       parser.h
+       parser.h                \
+       strcasecmp.c
 
 yasm_LDADD = \
        parsers/nasm/libparser.a        \
diff --git a/src/strcasecmp.c b/src/strcasecmp.c
new file mode 100644 (file)
index 0000000..1975b43
--- /dev/null
@@ -0,0 +1,82 @@
+/* $Id: strcasecmp.c,v 1.1 2001/09/16 09:13:00 peter Exp $
+ * strcasecmp() implementation for systems that don't have it or stricmp()
+ * or strcmpi().
+ *
+ * Copyright (c) 1987, 1993
+ *     The Regents of the University of California.  All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. Neither the name of the University nor the names of its contributors
+ *    may be used to endorse or promote products derived from this software
+ *    without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include "util.h"
+
+#ifdef USE_OUR_OWN_STRCASECMP
+
+#if defined(LIBC_SCCS) && !defined(lint)
+static char sccsid[] = "@(#)strcasecmp.c       8.1 (Berkeley) 6/4/93";
+#endif /* LIBC_SCCS and not lint */
+
+#ifdef STDC_HEADERS
+# include <string.h>
+# include <ctype.h>
+#endif
+
+RCSID("$Id: strcasecmp.c,v 1.1 2001/09/16 09:13:00 peter Exp $");
+
+int
+strcasecmp(const char *s1, const char *s2)
+{
+       const unsigned char
+                       *us1 = (const unsigned char *)s1,
+                       *us2 = (const unsigned char *)s2;
+
+       while (tolower(*us1) == tolower(*us2++))
+               if (*us1++ == '\0')
+                       return (0);
+       return (tolower(*us1) - tolower(*--us2));
+}
+
+int
+strncasecmp(const char *s1, const char *s2, size_t n)
+{
+       const unsigned char
+                       *us1 = (const unsigned char *)s1,
+                       *us2 = (const unsigned char *)s2;
+
+       if (n != 0) {
+               do {
+                       if (tolower(*us1) != tolower(*us2++))
+                               return (tolower(*us1) - tolower(*--us2));
+                       if (*us1++ == '\0')
+                               break;
+               } while (--n != 0);
+       }
+       return (0);
+}
+#endif
index 2d91d1b3dfe5492b82ce211963a2c28ef00ea960..d6741dac14bec93f38a0b7ea489cbf34c1cd616e 100644 (file)
@@ -1,4 +1,4 @@
-/* $Id: util.h,v 1.6 2001/08/19 07:32:39 peter Exp $
+/* $Id: util.h,v 1.7 2001/09/16 09:13:00 peter Exp $
  * Defines prototypes for replacement functions if needed.
  *
  *  Copyright (C) 2001  Peter Johnson
@@ -30,6 +30,18 @@ char *strdup(const char *str);
 unsigned long strtoul(const char *nptr, char **endptr, int base);
 #endif
 
+#ifndef HAVE_STRCASECMP
+# ifdef HAVE_STRICMP
+#  define strcasecmp(x, y)     stricmp(x, y)
+#  define strncasecmp(x, y)    strnicmp(x, y)
+# elif HAVE_STRCMPI
+#  define strcasecmp(x, y)     strcmpi(x, y)
+#  define strcasecmp(x, y)     strncmpi(x, y)
+# else
+#  define USE_OUR_OWN_STRCASECMP
+# endif
+#endif
+
 #ifndef HAVE_TOASCII
 # define toascii(c) ((c) & 0x7F)
 #endif
diff --git a/util.h b/util.h
index 2d91d1b3dfe5492b82ce211963a2c28ef00ea960..d6741dac14bec93f38a0b7ea489cbf34c1cd616e 100644 (file)
--- a/util.h
+++ b/util.h
@@ -1,4 +1,4 @@
-/* $Id: util.h,v 1.6 2001/08/19 07:32:39 peter Exp $
+/* $Id: util.h,v 1.7 2001/09/16 09:13:00 peter Exp $
  * Defines prototypes for replacement functions if needed.
  *
  *  Copyright (C) 2001  Peter Johnson
@@ -30,6 +30,18 @@ char *strdup(const char *str);
 unsigned long strtoul(const char *nptr, char **endptr, int base);
 #endif
 
+#ifndef HAVE_STRCASECMP
+# ifdef HAVE_STRICMP
+#  define strcasecmp(x, y)     stricmp(x, y)
+#  define strncasecmp(x, y)    strnicmp(x, y)
+# elif HAVE_STRCMPI
+#  define strcasecmp(x, y)     strcmpi(x, y)
+#  define strcasecmp(x, y)     strncmpi(x, y)
+# else
+#  define USE_OUR_OWN_STRCASECMP
+# endif
+#endif
+
 #ifndef HAVE_TOASCII
 # define toascii(c) ((c) & 0x7F)
 #endif