tst.cpp 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337
  1. /*=============================================================================
  2. Copyright (c) 2001-2015 Joel de Guzman
  3. Distributed under the Boost Software License, Version 1.0. (See accompanying
  4. file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  5. =============================================================================*/
  6. #include <boost/detail/lightweight_test.hpp>
  7. #include <boost/spirit/home/x3/string/tst.hpp>
  8. #include <boost/spirit/home/x3/string/tst_map.hpp>
  9. #include <boost/spirit/home/x3/support/no_case.hpp>
  10. #include <boost/spirit/home/support/char_encoding/standard.hpp>
  11. #include <boost/spirit/home/support/char_encoding/standard_wide.hpp>
  12. #include <string>
  13. #include <cctype>
  14. #include <iostream>
  15. namespace
  16. {
  17. template <typename TST, typename Char>
  18. void add(TST& tst, Char const* s, int data)
  19. {
  20. Char const* last = s;
  21. while (*last)
  22. last++;
  23. tst.add(s, last, data);
  24. }
  25. template <typename TST, typename Char>
  26. void remove(TST& tst, Char const* s)
  27. {
  28. Char const* last = s;
  29. while (*last)
  30. last++;
  31. tst.remove(s, last);
  32. }
  33. template <typename TST, typename Char, typename CaseCompare>
  34. void docheck(TST const& tst, CaseCompare const& comp, Char const* s, bool expected, int N = 0, int val = -1)
  35. {
  36. Char const* first = s;
  37. Char const* last = s;
  38. while (*last)
  39. last++;
  40. int* r = tst.find(s, last,comp);
  41. BOOST_TEST((r != 0) == expected);
  42. if (r != 0)
  43. BOOST_TEST((s-first) == N);
  44. if (r)
  45. BOOST_TEST(*r == val);
  46. }
  47. struct printer
  48. {
  49. template <typename String, typename Data>
  50. void operator()(String const& s, Data const& data)
  51. {
  52. std::cout << " " << s << ": " << data << std::endl;
  53. }
  54. };
  55. template <typename TST>
  56. void print(TST const& tst)
  57. {
  58. std::cout << '[' << std::endl;
  59. tst.for_each(printer());
  60. std::cout << ']' << std::endl;
  61. }
  62. }
  63. boost::spirit::x3::case_compare<boost::spirit::char_encoding::standard> ncomp;
  64. boost::spirit::x3::case_compare<boost::spirit::char_encoding::standard_wide> wcomp;
  65. boost::spirit::x3::no_case_compare<boost::spirit::char_encoding::standard> nc_ncomp;
  66. boost::spirit::x3::no_case_compare<boost::spirit::char_encoding::standard_wide> nc_wcomp;
  67. template <typename Lookup, typename WideLookup>
  68. void tests()
  69. {
  70. { // basic tests
  71. Lookup lookup;
  72. docheck(lookup, ncomp, "not-yet-there", false);
  73. docheck(lookup, ncomp, "", false);
  74. add(lookup, "apple", 123);
  75. docheck(lookup, ncomp, "apple", true, 5, 123); // full match
  76. docheck(lookup, ncomp, "banana", false); // no-match
  77. docheck(lookup, ncomp, "applexxx", true, 5, 123); // partial match
  78. add(lookup, "applepie", 456);
  79. docheck(lookup, ncomp, "applepie", true, 8, 456); // full match
  80. docheck(lookup, ncomp, "banana", false); // no-match
  81. docheck(lookup, ncomp, "applepiexxx", true, 8, 456); // partial match
  82. docheck(lookup, ncomp, "apple", true, 5, 123); // full match
  83. docheck(lookup, ncomp, "applexxx", true, 5, 123); // partial match
  84. }
  85. { // variation of above
  86. Lookup lookup;
  87. add(lookup, "applepie", 456);
  88. add(lookup, "apple", 123);
  89. docheck(lookup, ncomp, "applepie", true, 8, 456); // full match
  90. docheck(lookup, ncomp, "banana", false); // no-match
  91. docheck(lookup, ncomp, "applepiexxx", true, 8, 456); // partial match
  92. docheck(lookup, ncomp, "apple", true, 5, 123); // full match
  93. docheck(lookup, ncomp, "applexxx", true, 5, 123); // partial match
  94. }
  95. { // variation of above
  96. Lookup lookup;
  97. add(lookup, "applepie", 456);
  98. add(lookup, "apple", 123);
  99. docheck(lookup, ncomp, "applepie", true, 8, 456); // full match
  100. docheck(lookup, ncomp, "banana", false); // no-match
  101. docheck(lookup, ncomp, "applepiexxx", true, 8, 456); // partial match
  102. docheck(lookup, ncomp, "apple", true, 5, 123); // full match
  103. docheck(lookup, ncomp, "applexxx", true, 5, 123); // partial match
  104. }
  105. { // narrow char tests
  106. Lookup lookup;
  107. add(lookup, "pineapple", 1);
  108. add(lookup, "orange", 2);
  109. add(lookup, "banana", 3);
  110. add(lookup, "applepie", 4);
  111. add(lookup, "apple", 5);
  112. docheck(lookup, ncomp, "pineapple", true, 9, 1);
  113. docheck(lookup, ncomp, "orange", true, 6, 2);
  114. docheck(lookup, ncomp, "banana", true, 6, 3);
  115. docheck(lookup, ncomp, "apple", true, 5, 5);
  116. docheck(lookup, ncomp, "pizza", false);
  117. docheck(lookup, ncomp, "steak", false);
  118. docheck(lookup, ncomp, "applepie", true, 8, 4);
  119. docheck(lookup, ncomp, "bananarama", true, 6, 3);
  120. docheck(lookup, ncomp, "applet", true, 5, 5);
  121. docheck(lookup, ncomp, "applepi", true, 5, 5);
  122. docheck(lookup, ncomp, "appl", false);
  123. docheck(lookup, ncomp, "pineapplez", true, 9, 1);
  124. docheck(lookup, ncomp, "orangez", true, 6, 2);
  125. docheck(lookup, ncomp, "bananaz", true, 6, 3);
  126. docheck(lookup, ncomp, "applez", true, 5, 5);
  127. docheck(lookup, ncomp, "pizzaz", false);
  128. docheck(lookup, ncomp, "steakz", false);
  129. docheck(lookup, ncomp, "applepiez", true, 8, 4);
  130. docheck(lookup, ncomp, "bananaramaz", true, 6, 3);
  131. docheck(lookup, ncomp, "appletz", true, 5, 5);
  132. docheck(lookup, ncomp, "applepix", true, 5, 5);
  133. }
  134. { // wide char tests
  135. WideLookup lookup;
  136. add(lookup, L"pineapple", 1);
  137. add(lookup, L"orange", 2);
  138. add(lookup, L"banana", 3);
  139. add(lookup, L"applepie", 4);
  140. add(lookup, L"apple", 5);
  141. docheck(lookup, wcomp, L"pineapple", true, 9, 1);
  142. docheck(lookup, wcomp, L"orange", true, 6, 2);
  143. docheck(lookup, wcomp, L"banana", true, 6, 3);
  144. docheck(lookup, wcomp, L"apple", true, 5, 5);
  145. docheck(lookup, wcomp, L"pizza", false);
  146. docheck(lookup, wcomp, L"steak", false);
  147. docheck(lookup, wcomp, L"applepie", true, 8, 4);
  148. docheck(lookup, wcomp, L"bananarama", true, 6, 3);
  149. docheck(lookup, wcomp, L"applet", true, 5, 5);
  150. docheck(lookup, wcomp, L"applepi", true, 5, 5);
  151. docheck(lookup, wcomp, L"appl", false);
  152. docheck(lookup, wcomp, L"pineapplez", true, 9, 1);
  153. docheck(lookup, wcomp, L"orangez", true, 6, 2);
  154. docheck(lookup, wcomp, L"bananaz", true, 6, 3);
  155. docheck(lookup, wcomp, L"applez", true, 5, 5);
  156. docheck(lookup, wcomp, L"pizzaz", false);
  157. docheck(lookup, wcomp, L"steakz", false);
  158. docheck(lookup, wcomp, L"applepiez", true, 8, 4);
  159. docheck(lookup, wcomp, L"bananaramaz", true, 6, 3);
  160. docheck(lookup, wcomp, L"appletz", true, 5, 5);
  161. docheck(lookup, wcomp, L"applepix", true, 5, 5);
  162. }
  163. { // test remove
  164. Lookup lookup;
  165. add(lookup, "pineapple", 1);
  166. add(lookup, "orange", 2);
  167. add(lookup, "banana", 3);
  168. add(lookup, "applepie", 4);
  169. add(lookup, "apple", 5);
  170. docheck(lookup, ncomp, "pineapple", true, 9, 1);
  171. docheck(lookup, ncomp, "orange", true, 6, 2);
  172. docheck(lookup, ncomp, "banana", true, 6, 3);
  173. docheck(lookup, ncomp, "apple", true, 5, 5);
  174. docheck(lookup, ncomp, "applepie", true, 8, 4);
  175. docheck(lookup, ncomp, "bananarama", true, 6, 3);
  176. docheck(lookup, ncomp, "applet", true, 5, 5);
  177. docheck(lookup, ncomp, "applepi", true, 5, 5);
  178. docheck(lookup, ncomp, "appl", false);
  179. remove(lookup, "banana");
  180. docheck(lookup, ncomp, "pineapple", true, 9, 1);
  181. docheck(lookup, ncomp, "orange", true, 6, 2);
  182. docheck(lookup, ncomp, "banana", false);
  183. docheck(lookup, ncomp, "apple", true, 5, 5);
  184. docheck(lookup, ncomp, "applepie", true, 8, 4);
  185. docheck(lookup, ncomp, "bananarama", false);
  186. docheck(lookup, ncomp, "applet", true, 5, 5);
  187. docheck(lookup, ncomp, "applepi", true, 5, 5);
  188. docheck(lookup, ncomp, "appl", false);
  189. remove(lookup, "apple");
  190. docheck(lookup, ncomp, "pineapple", true, 9, 1);
  191. docheck(lookup, ncomp, "orange", true, 6, 2);
  192. docheck(lookup, ncomp, "apple", false);
  193. docheck(lookup, ncomp, "applepie", true, 8, 4);
  194. docheck(lookup, ncomp, "applet", false);
  195. docheck(lookup, ncomp, "applepi", false);
  196. docheck(lookup, ncomp, "appl", false);
  197. remove(lookup, "orange");
  198. docheck(lookup, ncomp, "pineapple", true, 9, 1);
  199. docheck(lookup, ncomp, "orange", false);
  200. docheck(lookup, ncomp, "applepie", true, 8, 4);
  201. remove(lookup, "pineapple");
  202. docheck(lookup, ncomp, "pineapple", false);
  203. docheck(lookup, ncomp, "orange", false);
  204. docheck(lookup, ncomp, "applepie", true, 8, 4);
  205. remove(lookup, "applepie");
  206. docheck(lookup, ncomp, "applepie", false);
  207. }
  208. { // copy/assign/clear test
  209. Lookup lookupa;
  210. add(lookupa, "pineapple", 1);
  211. add(lookupa, "orange", 2);
  212. add(lookupa, "banana", 3);
  213. add(lookupa, "applepie", 4);
  214. add(lookupa, "apple", 5);
  215. Lookup lookupb(lookupa); // copy ctor
  216. docheck(lookupb, ncomp, "pineapple", true, 9, 1);
  217. docheck(lookupb, ncomp, "orange", true, 6, 2);
  218. docheck(lookupb, ncomp, "banana", true, 6, 3);
  219. docheck(lookupb, ncomp, "apple", true, 5, 5);
  220. docheck(lookupb, ncomp, "pizza", false);
  221. docheck(lookupb, ncomp, "steak", false);
  222. docheck(lookupb, ncomp, "applepie", true, 8, 4);
  223. docheck(lookupb, ncomp, "bananarama", true, 6, 3);
  224. docheck(lookupb, ncomp, "applet", true, 5, 5);
  225. docheck(lookupb, ncomp, "applepi", true, 5, 5);
  226. docheck(lookupb, ncomp, "appl", false);
  227. lookupb.clear(); // clear
  228. docheck(lookupb, ncomp, "pineapple", false);
  229. docheck(lookupb, ncomp, "orange", false);
  230. docheck(lookupb, ncomp, "banana", false);
  231. docheck(lookupb, ncomp, "apple", false);
  232. docheck(lookupb, ncomp, "applepie", false);
  233. docheck(lookupb, ncomp, "bananarama", false);
  234. docheck(lookupb, ncomp, "applet", false);
  235. docheck(lookupb, ncomp, "applepi", false);
  236. docheck(lookupb, ncomp, "appl", false);
  237. lookupb = lookupa; // assign
  238. docheck(lookupb, ncomp, "pineapple", true, 9, 1);
  239. docheck(lookupb, ncomp, "orange", true, 6, 2);
  240. docheck(lookupb, ncomp, "banana", true, 6, 3);
  241. docheck(lookupb, ncomp, "apple", true, 5, 5);
  242. docheck(lookupb, ncomp, "pizza", false);
  243. docheck(lookupb, ncomp, "steak", false);
  244. docheck(lookupb, ncomp, "applepie", true, 8, 4);
  245. docheck(lookupb, ncomp, "bananarama", true, 6, 3);
  246. docheck(lookupb, ncomp, "applet", true, 5, 5);
  247. docheck(lookupb, ncomp, "applepi", true, 5, 5);
  248. docheck(lookupb, ncomp, "appl", false);
  249. }
  250. { // test for_each
  251. Lookup lookup;
  252. add(lookup, "pineapple", 1);
  253. add(lookup, "orange", 2);
  254. add(lookup, "banana", 3);
  255. add(lookup, "applepie", 4);
  256. add(lookup, "apple", 5);
  257. print(lookup);
  258. }
  259. { // case insensitive tests
  260. Lookup lookup;
  261. // NOTE: make sure all entries are in lower-case!!!
  262. add(lookup, "pineapple", 1);
  263. add(lookup, "orange", 2);
  264. add(lookup, "banana", 3);
  265. add(lookup, "applepie", 4);
  266. add(lookup, "apple", 5);
  267. docheck(lookup, nc_ncomp, "pineapple", true, 9, 1);
  268. docheck(lookup, nc_ncomp, "orange", true, 6, 2);
  269. docheck(lookup, nc_ncomp, "banana", true, 6, 3);
  270. docheck(lookup, nc_ncomp, "apple", true, 5, 5);
  271. docheck(lookup, nc_ncomp, "applepie", true, 8, 4);
  272. docheck(lookup, nc_ncomp, "PINEAPPLE", true, 9, 1);
  273. docheck(lookup, nc_ncomp, "ORANGE", true, 6, 2);
  274. docheck(lookup, nc_ncomp, "BANANA", true, 6, 3);
  275. docheck(lookup, nc_ncomp, "APPLE", true, 5, 5);
  276. docheck(lookup, nc_ncomp, "APPLEPIE", true, 8, 4);
  277. docheck(lookup, nc_ncomp, "pineApple", true, 9, 1);
  278. docheck(lookup, nc_ncomp, "orangE", true, 6, 2);
  279. docheck(lookup, nc_ncomp, "Banana", true, 6, 3);
  280. docheck(lookup, nc_ncomp, "aPPLe", true, 5, 5);
  281. docheck(lookup, nc_ncomp, "ApplePie", true, 8, 4);
  282. print(lookup);
  283. }
  284. }
  285. int main()
  286. {
  287. using boost::spirit::x3::tst;
  288. using boost::spirit::x3::tst_map;
  289. tests<tst<char, int>, tst<wchar_t, int> >();
  290. //~ tests<tst_map<char, int>, tst_map<wchar_t, int> >();
  291. return boost::report_errors();
  292. }