strcasecmp.c
上传用户:xxcykj
上传日期:2007-01-04
资源大小:727k
文件大小:4k
源码类别:

Email客户端

开发平台:

Unix_Linux

  1. /*
  2.  * Copyright (c) 1987 Regents of the University of California.
  3.  * All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms are permitted
  6.  * provided that the above copyright notice and this paragraph are
  7.  * duplicated in all such forms and that any documentation,
  8.  * advertising materials, and other materials related to such
  9.  * distribution and use acknowledge that the software was developed
  10.  * by the University of California, Berkeley.  The name of the
  11.  * University may not be used to endorse or promote products derived
  12.  * from this software without specific prior written permission.
  13.  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
  14.  * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
  15.  * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
  16.  */
  17. #if defined(LIBC_SCCS) && !defined(lint)
  18. static char sccsid[] = "@(#)strcasecmp.c 5.6 (Berkeley) 6/27/88";
  19. #endif /* LIBC_SCCS and not lint */
  20. #if defined(QNX)
  21. #include <sys/types.h>
  22. #else
  23. #ifndef(u_char)
  24. typedef unsigned char u_char;
  25. #endif
  26. #endif
  27. /*
  28.  * This array is designed for mapping upper and lower case letter
  29.  * together for a case independent comparison.  The mappings are
  30.  * based upon ascii character sequences.
  31.  */
  32. static u_char charmap[] = {
  33. '00', '01', '02', '03', '04', '05', '06', '07',
  34. '10', '11', '12', '13', '14', '15', '16', '17',
  35. '20', '21', '22', '23', '24', '25', '26', '27',
  36. '30', '31', '32', '33', '34', '35', '36', '37',
  37. '40', '41', '42', '43', '44', '45', '46', '47',
  38. '50', '51', '52', '53', '54', '55', '56', '57',
  39. '60', '61', '62', '63', '64', '65', '66', '67',
  40. '70', '71', '72', '73', '74', '75', '76', '77',
  41. '100', '141', '142', '143', '144', '145', '146', '147',
  42. '150', '151', '152', '153', '154', '155', '156', '157',
  43. '160', '161', '162', '163', '164', '165', '166', '167',
  44. '170', '171', '172', '133', '134', '135', '136', '137',
  45. '140', '141', '142', '143', '144', '145', '146', '147',
  46. '150', '151', '152', '153', '154', '155', '156', '157',
  47. '160', '161', '162', '163', '164', '165', '166', '167',
  48. '170', '171', '172', '173', '174', '175', '176', '177',
  49. '200', '201', '202', '203', '204', '205', '206', '207',
  50. '210', '211', '212', '213', '214', '215', '216', '217',
  51. '220', '221', '222', '223', '224', '225', '226', '227',
  52. '230', '231', '232', '233', '234', '235', '236', '237',
  53. '240', '241', '242', '243', '244', '245', '246', '247',
  54. '250', '251', '252', '253', '254', '255', '256', '257',
  55. '260', '261', '262', '263', '264', '265', '266', '267',
  56. '270', '271', '272', '273', '274', '275', '276', '277',
  57. '300', '341', '342', '343', '344', '345', '346', '347',
  58. '350', '351', '352', '353', '354', '355', '356', '357',
  59. '360', '361', '362', '363', '364', '365', '366', '367',
  60. '370', '371', '372', '333', '334', '335', '336', '337',
  61. '340', '341', '342', '343', '344', '345', '346', '347',
  62. '350', '351', '352', '353', '354', '355', '356', '357',
  63. '360', '361', '362', '363', '364', '365', '366', '367',
  64. '370', '371', '372', '373', '374', '375', '376', '377',
  65. };
  66. strcasecmp(s1, s2)
  67. char *s1, *s2;
  68. {
  69. register u_char *cm = charmap,
  70. *us1 = (u_char *)s1,
  71. *us2 = (u_char *)s2;
  72. while (cm[*us1] == cm[*us2++])
  73. if (*us1++ == '')
  74. return(0);
  75. return(cm[*us1] - cm[*--us2]);
  76. }
  77. strncasecmp(s1, s2, n)
  78. char *s1, *s2;
  79. register int n;
  80. {
  81. register u_char *cm = charmap,
  82. *us1 = (u_char *)s1,
  83. *us2 = (u_char *)s2;
  84. while (--n >= 0 && cm[*us1] == cm[*us2++])
  85. if (*us1++ == '')
  86. return(0);
  87. return(n < 0 ? 0 : cm[*us1] - cm[*--us2]);
  88. }