c-strcase.h 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. /* Case-insensitive string comparison functions in C locale.
  2. Copyright (C) 1995-1996, 2001, 2003, 2005, 2009-2023 Free Software
  3. Foundation, Inc.
  4. This file is free software: you can redistribute it and/or modify
  5. it under the terms of the GNU Lesser General Public License as
  6. published by the Free Software Foundation; either version 2.1 of the
  7. License, or (at your option) any later version.
  8. This file is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. GNU Lesser General Public License for more details.
  12. You should have received a copy of the GNU Lesser General Public License
  13. along with this program. If not, see <https://www.gnu.org/licenses/>. */
  14. #ifndef C_STRCASE_H
  15. #define C_STRCASE_H
  16. #include <stddef.h>
  17. /* The functions defined in this file assume the "C" locale and a character
  18. set without diacritics (ASCII-US or EBCDIC-US or something like that).
  19. Even if the "C" locale on a particular system is an extension of the ASCII
  20. character set (like on BeOS, where it is UTF-8, or on AmigaOS, where it
  21. is ISO-8859-1), the functions in this file recognize only the ASCII
  22. characters. More precisely, one of the string arguments must be an ASCII
  23. string; the other one can also contain non-ASCII characters (but then
  24. the comparison result will be nonzero). */
  25. #ifdef __cplusplus
  26. extern "C" {
  27. #endif
  28. /* Compare strings S1 and S2, ignoring case, returning less than, equal to or
  29. greater than zero if S1 is lexicographically less than, equal to or greater
  30. than S2. */
  31. extern int c_strcasecmp (const char *s1, const char *s2) _GL_ATTRIBUTE_PURE;
  32. /* Compare no more than N characters of strings S1 and S2, ignoring case,
  33. returning less than, equal to or greater than zero if S1 is
  34. lexicographically less than, equal to or greater than S2. */
  35. extern int c_strncasecmp (const char *s1, const char *s2, size_t n)
  36. _GL_ATTRIBUTE_PURE;
  37. #ifdef __cplusplus
  38. }
  39. #endif
  40. #endif /* C_STRCASE_H */