Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

169 lines
3.2 KiB

  1. /*++
  2. Copyright (C) 1999-2001 Microsoft Corporation
  3. Module Name:
  4. STRUTILS.H
  5. Abstract:
  6. String utilities
  7. History:
  8. --*/
  9. #ifndef __WBEM_STRING_UTILS__H_
  10. #define __WBEM_STRING_UTILS__H_
  11. #pragma optimize("gt", on)
  12. /*
  13. inline int wbem_towlower(wint_t c)
  14. {
  15. if(c >= 0 && c <= 127)
  16. {
  17. if(c >= 'A' && c <= 'Z')
  18. return c + ('a' - 'A');
  19. else
  20. return c;
  21. }
  22. else return towlower(c);
  23. }
  24. */
  25. #define wbem_towlower(C) \
  26. (((C) >= 0 && (C) <= 127)? \
  27. (((C) >= 'A' && (C) <= 'Z')? \
  28. ((C) + ('a' - 'A')): \
  29. (C) \
  30. ): \
  31. towlower(C) \
  32. )
  33. inline wchar_t wbem_towupper(wchar_t c)
  34. {
  35. if(c >= 0 && c <= 127)
  36. {
  37. if(c >= 'a' && c <= 'z')
  38. return c + ('A' - 'a');
  39. else
  40. return c;
  41. }
  42. else return towupper(c);
  43. }
  44. inline int wbem_tolower(int c)
  45. {
  46. if(c >= 0 && c <= 127)
  47. {
  48. if(c >= 'A' && c <= 'Z')
  49. return c + ('a' - 'A');
  50. else
  51. return c;
  52. }
  53. else return tolower(c);
  54. }
  55. inline int wbem_toupper(int c)
  56. {
  57. if(c >= 0 && c <= 127)
  58. {
  59. if(c >= 'a' && c <= 'z')
  60. return c + ('A' - 'a');
  61. else
  62. return c;
  63. }
  64. else return toupper(c);
  65. }
  66. inline int wbem_wcsicmp( const wchar_t* wsz1, const wchar_t* wsz2)
  67. {
  68. while(*wsz1 || *wsz2)
  69. {
  70. int diff = wbem_towlower(*wsz1) - wbem_towlower(*wsz2);
  71. if(diff) return diff;
  72. wsz1++; wsz2++;
  73. }
  74. return 0;
  75. }
  76. inline int wbem_unaligned_wcsicmp( UNALIGNED const wchar_t* wsz1, UNALIGNED const wchar_t* wsz2)
  77. {
  78. while(*wsz1 || *wsz2)
  79. {
  80. int diff = wbem_towlower(*wsz1) - wbem_towlower(*wsz2);
  81. if(diff) return diff;
  82. wsz1++; wsz2++;
  83. }
  84. return 0;
  85. }
  86. // just like wcsicmp, but first 0 of unicode chracters have been omitted
  87. inline int wbem_ncsicmp(const char* wsz1, const char* wsz2)
  88. {
  89. while(*wsz1 || *wsz2)
  90. {
  91. int diff = wbem_towlower((unsigned char)*wsz1) -
  92. wbem_towlower((unsigned char)*wsz2);
  93. if(diff) return diff;
  94. wsz1++; wsz2++;
  95. }
  96. return 0;
  97. }
  98. inline int wbem_wcsnicmp( const wchar_t* wsz1, const wchar_t* wsz2, size_t n )
  99. {
  100. while(n-- && (*wsz1 || *wsz2))
  101. {
  102. int diff = wbem_towlower(*wsz1) - wbem_towlower(*wsz2);
  103. if(diff) return diff;
  104. wsz1++; wsz2++;
  105. }
  106. return 0;
  107. }
  108. inline int wbem_unaligned_wcsnicmp( UNALIGNED const wchar_t* wsz1, UNALIGNED const wchar_t* wsz2, size_t n )
  109. {
  110. while(n-- && (*wsz1 || *wsz2))
  111. {
  112. int diff = wbem_towlower(*wsz1) - wbem_towlower(*wsz2);
  113. if(diff) return diff;
  114. wsz1++; wsz2++;
  115. }
  116. return 0;
  117. }
  118. inline int wbem_stricmp(const char* sz1, const char* sz2)
  119. {
  120. while(*sz1 || *sz2)
  121. {
  122. int diff = wbem_tolower(*sz1) - wbem_tolower(*sz2);
  123. if(diff) return diff;
  124. sz1++; sz2++;
  125. }
  126. return 0;
  127. }
  128. inline int wbem_strnicmp(const char* sz1, const char* sz2, size_t n)
  129. {
  130. while(n-- && (*sz1 || *sz2))
  131. {
  132. int diff = wbem_tolower(*sz1) - wbem_tolower(*sz2);
  133. if(diff) return diff;
  134. sz1++; sz2++;
  135. }
  136. return 0;
  137. }
  138. #pragma optimize("", on)
  139. #endif