string_size.pass.cpp 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. //===----------------------------------------------------------------------===//
  2. //
  3. // The LLVM Compiler Infrastructure
  4. //
  5. // This file is distributed under the University of Illinois Open Source
  6. // License. See LICENSE.TXT for details.
  7. //
  8. //===----------------------------------------------------------------------===//
  9. // <string>
  10. // size_type find(const basic_string& str, size_type pos = 0) const;
  11. #include <string>
  12. #include <cassert>
  13. template <class S>
  14. void
  15. test(const S& s, const S& str, typename S::size_type pos, typename S::size_type x)
  16. {
  17. assert(s.find(str, pos) == x);
  18. if (x != S::npos)
  19. assert(pos <= x && x + str.size() <= s.size());
  20. }
  21. template <class S>
  22. void
  23. test(const S& s, const S& str, typename S::size_type x)
  24. {
  25. assert(s.find(str) == x);
  26. if (x != S::npos)
  27. assert(0 <= x && x + str.size() <= s.size());
  28. }
  29. typedef std::string S;
  30. void test0()
  31. {
  32. test(S(""), S(""), 0, 0);
  33. test(S(""), S("abcde"), 0, S::npos);
  34. test(S(""), S("abcdeabcde"), 0, S::npos);
  35. test(S(""), S("abcdeabcdeabcdeabcde"), 0, S::npos);
  36. test(S(""), S(""), 1, S::npos);
  37. test(S(""), S("abcde"), 1, S::npos);
  38. test(S(""), S("abcdeabcde"), 1, S::npos);
  39. test(S(""), S("abcdeabcdeabcdeabcde"), 1, S::npos);
  40. test(S("abcde"), S(""), 0, 0);
  41. test(S("abcde"), S("abcde"), 0, 0);
  42. test(S("abcde"), S("abcdeabcde"), 0, S::npos);
  43. test(S("abcde"), S("abcdeabcdeabcdeabcde"), 0, S::npos);
  44. test(S("abcde"), S(""), 1, 1);
  45. test(S("abcde"), S("abcde"), 1, S::npos);
  46. test(S("abcde"), S("abcdeabcde"), 1, S::npos);
  47. test(S("abcde"), S("abcdeabcdeabcdeabcde"), 1, S::npos);
  48. test(S("abcde"), S(""), 2, 2);
  49. test(S("abcde"), S("abcde"), 2, S::npos);
  50. test(S("abcde"), S("abcdeabcde"), 2, S::npos);
  51. test(S("abcde"), S("abcdeabcdeabcdeabcde"), 2, S::npos);
  52. test(S("abcde"), S(""), 4, 4);
  53. test(S("abcde"), S("abcde"), 4, S::npos);
  54. test(S("abcde"), S("abcdeabcde"), 4, S::npos);
  55. test(S("abcde"), S("abcdeabcdeabcdeabcde"), 4, S::npos);
  56. test(S("abcde"), S(""), 5, 5);
  57. test(S("abcde"), S("abcde"), 5, S::npos);
  58. test(S("abcde"), S("abcdeabcde"), 5, S::npos);
  59. test(S("abcde"), S("abcdeabcdeabcdeabcde"), 5, S::npos);
  60. test(S("abcde"), S(""), 6, S::npos);
  61. test(S("abcde"), S("abcde"), 6, S::npos);
  62. test(S("abcde"), S("abcdeabcde"), 6, S::npos);
  63. test(S("abcde"), S("abcdeabcdeabcdeabcde"), 6, S::npos);
  64. test(S("abcdeabcde"), S(""), 0, 0);
  65. test(S("abcdeabcde"), S("abcde"), 0, 0);
  66. test(S("abcdeabcde"), S("abcdeabcde"), 0, 0);
  67. test(S("abcdeabcde"), S("abcdeabcdeabcdeabcde"), 0, S::npos);
  68. test(S("abcdeabcde"), S(""), 1, 1);
  69. test(S("abcdeabcde"), S("abcde"), 1, 5);
  70. test(S("abcdeabcde"), S("abcdeabcde"), 1, S::npos);
  71. test(S("abcdeabcde"), S("abcdeabcdeabcdeabcde"), 1, S::npos);
  72. test(S("abcdeabcde"), S(""), 5, 5);
  73. test(S("abcdeabcde"), S("abcde"), 5, 5);
  74. test(S("abcdeabcde"), S("abcdeabcde"), 5, S::npos);
  75. test(S("abcdeabcde"), S("abcdeabcdeabcdeabcde"), 5, S::npos);
  76. test(S("abcdeabcde"), S(""), 9, 9);
  77. test(S("abcdeabcde"), S("abcde"), 9, S::npos);
  78. test(S("abcdeabcde"), S("abcdeabcde"), 9, S::npos);
  79. test(S("abcdeabcde"), S("abcdeabcdeabcdeabcde"), 9, S::npos);
  80. test(S("abcdeabcde"), S(""), 10, 10);
  81. test(S("abcdeabcde"), S("abcde"), 10, S::npos);
  82. test(S("abcdeabcde"), S("abcdeabcde"), 10, S::npos);
  83. test(S("abcdeabcde"), S("abcdeabcdeabcdeabcde"), 10, S::npos);
  84. test(S("abcdeabcde"), S(""), 11, S::npos);
  85. test(S("abcdeabcde"), S("abcde"), 11, S::npos);
  86. test(S("abcdeabcde"), S("abcdeabcde"), 11, S::npos);
  87. test(S("abcdeabcde"), S("abcdeabcdeabcdeabcde"), 11, S::npos);
  88. test(S("abcdeabcdeabcdeabcde"), S(""), 0, 0);
  89. test(S("abcdeabcdeabcdeabcde"), S("abcde"), 0, 0);
  90. test(S("abcdeabcdeabcdeabcde"), S("abcdeabcde"), 0, 0);
  91. test(S("abcdeabcdeabcdeabcde"), S("abcdeabcdeabcdeabcde"), 0, 0);
  92. test(S("abcdeabcdeabcdeabcde"), S(""), 1, 1);
  93. test(S("abcdeabcdeabcdeabcde"), S("abcde"), 1, 5);
  94. test(S("abcdeabcdeabcdeabcde"), S("abcdeabcde"), 1, 5);
  95. test(S("abcdeabcdeabcdeabcde"), S("abcdeabcdeabcdeabcde"), 1, S::npos);
  96. test(S("abcdeabcdeabcdeabcde"), S(""), 10, 10);
  97. test(S("abcdeabcdeabcdeabcde"), S("abcde"), 10, 10);
  98. test(S("abcdeabcdeabcdeabcde"), S("abcdeabcde"), 10, 10);
  99. test(S("abcdeabcdeabcdeabcde"), S("abcdeabcdeabcdeabcde"), 10, S::npos);
  100. test(S("abcdeabcdeabcdeabcde"), S(""), 19, 19);
  101. test(S("abcdeabcdeabcdeabcde"), S("abcde"), 19, S::npos);
  102. test(S("abcdeabcdeabcdeabcde"), S("abcdeabcde"), 19, S::npos);
  103. test(S("abcdeabcdeabcdeabcde"), S("abcdeabcdeabcdeabcde"), 19, S::npos);
  104. test(S("abcdeabcdeabcdeabcde"), S(""), 20, 20);
  105. test(S("abcdeabcdeabcdeabcde"), S("abcde"), 20, S::npos);
  106. test(S("abcdeabcdeabcdeabcde"), S("abcdeabcde"), 20, S::npos);
  107. test(S("abcdeabcdeabcdeabcde"), S("abcdeabcdeabcdeabcde"), 20, S::npos);
  108. test(S("abcdeabcdeabcdeabcde"), S(""), 21, S::npos);
  109. test(S("abcdeabcdeabcdeabcde"), S("abcde"), 21, S::npos);
  110. test(S("abcdeabcdeabcdeabcde"), S("abcdeabcde"), 21, S::npos);
  111. test(S("abcdeabcdeabcdeabcde"), S("abcdeabcdeabcdeabcde"), 21, S::npos);
  112. }
  113. void test1()
  114. {
  115. test(S(""), S(""), 0);
  116. test(S(""), S("abcde"), S::npos);
  117. test(S(""), S("abcdeabcde"), S::npos);
  118. test(S(""), S("abcdeabcdeabcdeabcde"), S::npos);
  119. test(S("abcde"), S(""), 0);
  120. test(S("abcde"), S("abcde"), 0);
  121. test(S("abcde"), S("abcdeabcde"), S::npos);
  122. test(S("abcde"), S("abcdeabcdeabcdeabcde"), S::npos);
  123. test(S("abcdeabcde"), S(""), 0);
  124. test(S("abcdeabcde"), S("abcde"), 0);
  125. test(S("abcdeabcde"), S("abcdeabcde"), 0);
  126. test(S("abcdeabcde"), S("abcdeabcdeabcdeabcde"), S::npos);
  127. test(S("abcdeabcdeabcdeabcde"), S(""), 0);
  128. test(S("abcdeabcdeabcdeabcde"), S("abcde"), 0);
  129. test(S("abcdeabcdeabcdeabcde"), S("abcdeabcde"), 0);
  130. test(S("abcdeabcdeabcdeabcde"), S("abcdeabcdeabcdeabcde"), 0);
  131. }
  132. int main()
  133. {
  134. test0();
  135. test1();
  136. }