strcasecmp.c 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. /* $OpenBSD: strcasecmp.c,v 1.6 2005/08/08 08:05:37 espie Exp $ */
  2. /*
  3. * Copyright (c) 1987, 1993
  4. * The Regents of the University of California. All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without
  7. * modification, are permitted provided that the following conditions
  8. * are met:
  9. * 1. Redistributions of source code must retain the above copyright
  10. * notice, this list of conditions and the following disclaimer.
  11. * 2. Redistributions in binary form must reproduce the above copyright
  12. * notice, this list of conditions and the following disclaimer in the
  13. * documentation and/or other materials provided with the distribution.
  14. * 3. Neither the name of the University nor the names of its contributors
  15. * may be used to endorse or promote products derived from this software
  16. * without specific prior written permission.
  17. *
  18. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  19. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  20. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  21. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  22. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  23. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  24. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  25. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  26. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  27. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  28. * SUCH DAMAGE.
  29. */
  30. #include <string.h>
  31. typedef unsigned char u_char;
  32. /*
  33. * This array is designed for mapping upper and lower case letter
  34. * together for a case independent comparison. The mappings are
  35. * based upon ascii character sequences.
  36. */
  37. static const u_char charmap[] = {
  38. '\000', '\001', '\002', '\003', '\004', '\005', '\006', '\007',
  39. '\010', '\011', '\012', '\013', '\014', '\015', '\016', '\017',
  40. '\020', '\021', '\022', '\023', '\024', '\025', '\026', '\027',
  41. '\030', '\031', '\032', '\033', '\034', '\035', '\036', '\037',
  42. '\040', '\041', '\042', '\043', '\044', '\045', '\046', '\047',
  43. '\050', '\051', '\052', '\053', '\054', '\055', '\056', '\057',
  44. '\060', '\061', '\062', '\063', '\064', '\065', '\066', '\067',
  45. '\070', '\071', '\072', '\073', '\074', '\075', '\076', '\077',
  46. '\100', '\141', '\142', '\143', '\144', '\145', '\146', '\147',
  47. '\150', '\151', '\152', '\153', '\154', '\155', '\156', '\157',
  48. '\160', '\161', '\162', '\163', '\164', '\165', '\166', '\167',
  49. '\170', '\171', '\172', '\133', '\134', '\135', '\136', '\137',
  50. '\140', '\141', '\142', '\143', '\144', '\145', '\146', '\147',
  51. '\150', '\151', '\152', '\153', '\154', '\155', '\156', '\157',
  52. '\160', '\161', '\162', '\163', '\164', '\165', '\166', '\167',
  53. '\170', '\171', '\172', '\173', '\174', '\175', '\176', '\177',
  54. '\200', '\201', '\202', '\203', '\204', '\205', '\206', '\207',
  55. '\210', '\211', '\212', '\213', '\214', '\215', '\216', '\217',
  56. '\220', '\221', '\222', '\223', '\224', '\225', '\226', '\227',
  57. '\230', '\231', '\232', '\233', '\234', '\235', '\236', '\237',
  58. '\240', '\241', '\242', '\243', '\244', '\245', '\246', '\247',
  59. '\250', '\251', '\252', '\253', '\254', '\255', '\256', '\257',
  60. '\260', '\261', '\262', '\263', '\264', '\265', '\266', '\267',
  61. '\270', '\271', '\272', '\273', '\274', '\275', '\276', '\277',
  62. '\300', '\301', '\302', '\303', '\304', '\305', '\306', '\307',
  63. '\310', '\311', '\312', '\313', '\314', '\315', '\316', '\317',
  64. '\320', '\321', '\322', '\323', '\324', '\325', '\326', '\327',
  65. '\330', '\331', '\332', '\333', '\334', '\335', '\336', '\337',
  66. '\340', '\341', '\342', '\343', '\344', '\345', '\346', '\347',
  67. '\350', '\351', '\352', '\353', '\354', '\355', '\356', '\357',
  68. '\360', '\361', '\362', '\363', '\364', '\365', '\366', '\367',
  69. '\370', '\371', '\372', '\373', '\374', '\375', '\376', '\377',
  70. };
  71. int
  72. strcasecmp(const char *s1, const char *s2)
  73. {
  74. const u_char *cm = charmap;
  75. const u_char *us1 = (const u_char *)s1;
  76. const u_char *us2 = (const u_char *)s2;
  77. while (cm[*us1] == cm[*us2++])
  78. if (*us1++ == '\0')
  79. return (0);
  80. return (cm[*us1] - cm[*--us2]);
  81. }
  82. int
  83. strncasecmp(const char *s1, const char *s2, size_t n)
  84. {
  85. if (n != 0) {
  86. const u_char *cm = charmap;
  87. const u_char *us1 = (const u_char *)s1;
  88. const u_char *us2 = (const u_char *)s2;
  89. do {
  90. if (cm[*us1] != cm[*us2++])
  91. return (cm[*us1] - cm[*--us2]);
  92. if (*us1++ == '\0')
  93. break;
  94. } while (--n != 0);
  95. }
  96. return (0);
  97. }