ctype.c 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. /* vi: set sw=4 ts=4: */
  2. /*
  3. * Test application for functions defined in ctype.h
  4. * Copyright (C) 2000-2006 by Erik Andersen <andersen@uclibc.org>
  5. *
  6. * Licensed under the LGPL v2.1, see the file COPYING.LIB in this tarball.
  7. */
  8. #include <stdio.h>
  9. #include <stdlib.h>
  10. #include <stdarg.h>
  11. #include <ctype.h>
  12. #include "../testsuite.h"
  13. int main( int argc, char **argv)
  14. {
  15. int i, c;
  16. init_testsuite("Testing functions defined in ctype.h\n");
  17. /* isalnum() */
  18. {
  19. int buffer[]={ '1', '4', 'a', 'z', 'A', 'Z', '5', -1};
  20. for(i=0; buffer[i]!=-1; i++) {
  21. c = buffer[i];
  22. TEST( isalnum(c)!=0);
  23. }
  24. }
  25. {
  26. int buffer[]={ 2, 128, 254, '\n', -1};
  27. for(i=0; buffer[i]!=-1; i++) {
  28. c = buffer[i];
  29. TEST( isalnum(c)==0);
  30. }
  31. }
  32. /* isalpha() */
  33. {
  34. int buffer[]={ 'a', 'z', 'A', 'Z', -1};
  35. for(i=0; buffer[i]!=-1; i++) {
  36. c = buffer[i];
  37. TEST( isalpha(c)!=0);
  38. }
  39. }
  40. {
  41. int buffer[]={ 2, 63, 128, 254, '\n', -1};
  42. for(i=0; buffer[i]!=-1; i++) {
  43. c = buffer[i];
  44. TEST( isalpha(c)==0);
  45. }
  46. }
  47. #ifdef __UCLIBC_SUSV4_LEGACY__
  48. /* isascii() */
  49. {
  50. int buffer[]={ 'a', 'z', 'A', 'Z', '\n', -1};
  51. for(i=0; buffer[i]!=-1; i++) {
  52. c = buffer[i];
  53. TEST( isascii(c)!=0);
  54. }
  55. }
  56. {
  57. int buffer[]={ 128, 254, -1};
  58. for(i=0; buffer[i]!=-1; i++) {
  59. c = buffer[i];
  60. TEST( isascii(c)==0);
  61. }
  62. }
  63. #endif
  64. /* iscntrl() */
  65. {
  66. int buffer[]={ 0x7F, 6, '\t', '\n', 0x7F, -1};
  67. for(i=0; buffer[i]!=-1; i++) {
  68. c = buffer[i];
  69. TEST( iscntrl(c)!=0);
  70. }
  71. }
  72. {
  73. int buffer[]={ 63, 128, 254, -1};
  74. for(i=0; buffer[i]!=-1; i++) {
  75. c = buffer[i];
  76. TEST( iscntrl(c)==0);
  77. }
  78. }
  79. /* isdigit() */
  80. {
  81. int buffer[]={ '1', '5', '7', '9', -1};
  82. for(i=0; buffer[i]!=-1; i++) {
  83. c = buffer[i];
  84. TEST( isdigit(c)!=0);
  85. }
  86. }
  87. {
  88. int buffer[]={ 2, 'a', 'z', 'A', 'Z', 63, 128, 254, '\n', -1};
  89. for(i=0; buffer[i]!=-1; i++) {
  90. c = buffer[i];
  91. TEST( isdigit(c)==0);
  92. }
  93. }
  94. /* isgraph() */
  95. {
  96. int buffer[]={ ')', '~', '9', -1};
  97. for(i=0; buffer[i]!=-1; i++) {
  98. c = buffer[i];
  99. TEST( isgraph(c)!=0);
  100. }
  101. }
  102. {
  103. int buffer[]={ 9, ' ', '\t', '\n', 200, 0x7F, -1};
  104. for(i=0; buffer[i]!=-1; i++) {
  105. c = buffer[i];
  106. TEST( isgraph(c)==0);
  107. }
  108. }
  109. /* islower() */
  110. {
  111. int buffer[]={ 'a', 'g', 'z', -1};
  112. for(i=0; buffer[i]!=-1; i++) {
  113. c = buffer[i];
  114. TEST( islower(c)!=0);
  115. }
  116. }
  117. {
  118. int buffer[]={ 9, 'A', 'Z', 128, 254, ' ', '\t', '\n', 0x7F, -1};
  119. for(i=0; buffer[i]!=-1; i++) {
  120. c = buffer[i];
  121. TEST( islower(c)==0);
  122. }
  123. }
  124. /* isprint() */
  125. {
  126. int buffer[]={ ' ', ')', '~', '9', -1};
  127. for(i=0; buffer[i]!=-1; i++) {
  128. c = buffer[i];
  129. TEST( isprint(c)!=0);
  130. }
  131. }
  132. {
  133. int buffer[]={ '\b', '\t', '\n', 9, 128, 254, 200, 0x7F, -1};
  134. for(i=0; buffer[i]!=-1; i++) {
  135. c = buffer[i];
  136. TEST( isprint(c)==0);
  137. }
  138. }
  139. /* ispunct() */
  140. {
  141. int buffer[]={ '.', '#', '@', ';', -1};
  142. for(i=0; buffer[i]!=-1; i++) {
  143. c = buffer[i];
  144. TEST( ispunct(c)!=0);
  145. }
  146. }
  147. {
  148. int buffer[]={ 2, 'a', 'Z', '1', 128, 254, '\n', -1};
  149. for(i=0; buffer[i]!=-1; i++) {
  150. c = buffer[i];
  151. TEST( ispunct(c)==0);
  152. }
  153. }
  154. /* isspace() */
  155. {
  156. int buffer[]={ ' ', '\t', '\r', '\v', '\n', -1};
  157. for(i=0; buffer[i]!=-1; i++) {
  158. c = buffer[i];
  159. TEST( isspace(c)!=0);
  160. }
  161. }
  162. {
  163. int buffer[]={ 2, 'a', 'Z', '1', 128, 254, -1};
  164. for(i=0; buffer[i]!=-1; i++) {
  165. c = buffer[i];
  166. TEST( isspace(c)==0);
  167. }
  168. }
  169. /* isupper() */
  170. {
  171. int buffer[]={ 'A', 'G', 'Z', -1};
  172. for(i=0; buffer[i]!=-1; i++) {
  173. c = buffer[i];
  174. TEST( isupper(c)!=0);
  175. }
  176. }
  177. {
  178. int buffer[]={ 2, 'a', 'z', '1', 128, 254, -1};
  179. for(i=0; buffer[i]!=-1; i++) {
  180. c = buffer[i];
  181. TEST( isupper(c)==0);
  182. }
  183. }
  184. /* isxdigit() */
  185. {
  186. int buffer[]={ 'f', 'A', '1', '8', -1};
  187. for(i=0; buffer[i]!=-1; i++) {
  188. c = buffer[i];
  189. TEST( isxdigit(c)!=0);
  190. }
  191. }
  192. {
  193. int buffer[]={ 2, 'g', 'G', 'x', '\n', -1};
  194. for(i=0; buffer[i]!=-1; i++) {
  195. c = buffer[i];
  196. TEST( isxdigit(c)==0);
  197. }
  198. }
  199. /* tolower() */
  200. c='A';
  201. TEST_NUMERIC( tolower(c), 'a');
  202. c='a';
  203. TEST_NUMERIC( tolower(c), 'a');
  204. c='#';
  205. TEST_NUMERIC( tolower(c), c);
  206. /* toupper() */
  207. c='a';
  208. TEST_NUMERIC( toupper(c), 'A');
  209. c='A';
  210. TEST_NUMERIC( toupper(c), 'A');
  211. c='#';
  212. TEST_NUMERIC( toupper(c), c);
  213. exit(0);
  214. }