stricmp.c 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. /*
  2. * Copyright (C) 2004 by egnite Software GmbH. All rights reserved.
  3. *
  4. * Redistribution and use in source and binary forms, with or without
  5. * modification, are permitted provided that the following conditions
  6. * are met:
  7. *
  8. * 1. Redistributions of source code must retain the above copyright
  9. * notice, this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright
  11. * notice, this list of conditions and the following disclaimer in the
  12. * documentation and/or other materials provided with the distribution.
  13. * 3. Neither the name of the copyright holders nor the names of
  14. * contributors may be used to endorse or promote products derived
  15. * from this software without specific prior written permission.
  16. *
  17. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  18. * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  19. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  20. * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
  21. * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
  22. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
  23. * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
  24. * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
  25. * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  26. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
  27. * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  28. * SUCH DAMAGE.
  29. *
  30. * For additional information see http://www.ethernut.de/
  31. *
  32. *-
  33. * Copyright (c) 1987, 1993
  34. * The Regents of the University of California. All rights reserved.
  35. *
  36. * Redistribution and use in source and binary forms, with or without
  37. * modification, are permitted provided that the following conditions
  38. * are met:
  39. * 1. Redistributions of source code must retain the above copyright
  40. * notice, this list of conditions and the following disclaimer.
  41. * 2. Redistributions in binary form must reproduce the above copyright
  42. * notice, this list of conditions and the following disclaimer in the
  43. * documentation and/or other materials provided with the distribution.
  44. * 3. Neither the name of the University nor the names of its contributors
  45. * may be used to endorse or promote products derived from this software
  46. * without specific prior written permission.
  47. *
  48. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  49. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  50. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  51. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  52. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  53. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  54. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  55. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  56. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  57. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  58. * SUCH DAMAGE.
  59. */
  60. /*
  61. * $Log$
  62. * Revision 1.3 2008/08/11 06:59:39 haraldkipp
  63. * BSD types replaced by stdint types (feature request #1282721).
  64. *
  65. * Revision 1.2 2006/10/08 16:48:08 haraldkipp
  66. * Documentation fixed
  67. *
  68. * Revision 1.1 2004/09/08 10:24:00 haraldkipp
  69. * Generic C string library added
  70. *
  71. */
  72. #include <compiler.h>
  73. #include <string.h>
  74. /*!
  75. * \addtogroup xgCrtString
  76. */
  77. /*@{*/
  78. typedef unsigned char uint8_t;
  79. /*
  80. * This array is designed for mapping upper and lower case letter
  81. * together for a case independent comparison. The mappings are
  82. * based upon ascii character sequences.
  83. */
  84. static const uint8_t charmap[] = {
  85. '\000', '\001', '\002', '\003', '\004', '\005', '\006', '\007',
  86. '\010', '\011', '\012', '\013', '\014', '\015', '\016', '\017',
  87. '\020', '\021', '\022', '\023', '\024', '\025', '\026', '\027',
  88. '\030', '\031', '\032', '\033', '\034', '\035', '\036', '\037',
  89. '\040', '\041', '\042', '\043', '\044', '\045', '\046', '\047',
  90. '\050', '\051', '\052', '\053', '\054', '\055', '\056', '\057',
  91. '\060', '\061', '\062', '\063', '\064', '\065', '\066', '\067',
  92. '\070', '\071', '\072', '\073', '\074', '\075', '\076', '\077',
  93. '\100', '\141', '\142', '\143', '\144', '\145', '\146', '\147',
  94. '\150', '\151', '\152', '\153', '\154', '\155', '\156', '\157',
  95. '\160', '\161', '\162', '\163', '\164', '\165', '\166', '\167',
  96. '\170', '\171', '\172', '\133', '\134', '\135', '\136', '\137',
  97. '\140', '\141', '\142', '\143', '\144', '\145', '\146', '\147',
  98. '\150', '\151', '\152', '\153', '\154', '\155', '\156', '\157',
  99. '\160', '\161', '\162', '\163', '\164', '\165', '\166', '\167',
  100. '\170', '\171', '\172', '\173', '\174', '\175', '\176', '\177',
  101. '\200', '\201', '\202', '\203', '\204', '\205', '\206', '\207',
  102. '\210', '\211', '\212', '\213', '\214', '\215', '\216', '\217',
  103. '\220', '\221', '\222', '\223', '\224', '\225', '\226', '\227',
  104. '\230', '\231', '\232', '\233', '\234', '\235', '\236', '\237',
  105. '\240', '\241', '\242', '\243', '\244', '\245', '\246', '\247',
  106. '\250', '\251', '\252', '\253', '\254', '\255', '\256', '\257',
  107. '\260', '\261', '\262', '\263', '\264', '\265', '\266', '\267',
  108. '\270', '\271', '\272', '\273', '\274', '\275', '\276', '\277',
  109. '\300', '\301', '\302', '\303', '\304', '\305', '\306', '\307',
  110. '\310', '\311', '\312', '\313', '\314', '\315', '\316', '\317',
  111. '\320', '\321', '\322', '\323', '\324', '\325', '\326', '\327',
  112. '\330', '\331', '\332', '\333', '\334', '\335', '\336', '\337',
  113. '\340', '\341', '\342', '\343', '\344', '\345', '\346', '\347',
  114. '\350', '\351', '\352', '\353', '\354', '\355', '\356', '\357',
  115. '\360', '\361', '\362', '\363', '\364', '\365', '\366', '\367',
  116. '\370', '\371', '\372', '\373', '\374', '\375', '\376', '\377',
  117. };
  118. /*!
  119. * \brief Compare two strings, ignoring case.
  120. *
  121. * The strings are compared lexicographically. The comparison is done
  122. * using unsigned characters,
  123. *
  124. * \param s1 Pointer to the first string.
  125. * \param s2 Pointer to the second string.
  126. *
  127. * \return An integer greater than, equal to, or less than 0, according
  128. * to whether the first string is greater than, equal to, or less
  129. * than the second string after translation of each corresponding
  130. * character to lower-case.
  131. */
  132. int stricmp(const char *s1, const char *s2)
  133. {
  134. const uint8_t *cm = charmap;
  135. const uint8_t *us1 = (const uint8_t *) s1;
  136. const uint8_t *us2 = (const uint8_t *) s2;
  137. while (cm[*us1] == cm[*us2++]) {
  138. if (*us1++ == '\0') {
  139. return 0;
  140. }
  141. }
  142. return cm[*us1] - cm[*--us2];
  143. }
  144. /*!
  145. * \brief Compare two strings up to a given number of characters and ignoring case.
  146. *
  147. * The strings are compared lexicographically. The comparison is done
  148. * using unsigned characters,
  149. *
  150. * \param s1 Pointer to the first string.
  151. * \param s2 Pointer to the second string.
  152. * \param n Number of bytes to compare.
  153. *
  154. * \return An integer greater than, equal to, or less than 0, according
  155. * to whether the first string is greater than, equal to, or less
  156. * than the second string after translation of each corresponding
  157. * character to lower-case.
  158. */
  159. int strnicmp(const char *s1, const char *s2, size_t n)
  160. {
  161. if (n != 0) {
  162. const uint8_t *cm = charmap;
  163. const uint8_t *us1 = (const uint8_t *) s1;
  164. const uint8_t *us2 = (const uint8_t *) s2;
  165. do {
  166. if (cm[*us1] != cm[*us2++]) {
  167. return cm[*us1] - cm[*--us2];
  168. }
  169. if (*us1++ == '\0') {
  170. break;
  171. }
  172. } while (--n);
  173. }
  174. return 0;
  175. }
  176. /*@}*/