test_key_extractors.cpp 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602
  1. /* Boost.MultiIndex test for key extractors.
  2. *
  3. * Copyright 2003-2019 Joaquin M Lopez Munoz.
  4. * Distributed under the Boost Software License, Version 1.0.
  5. * (See accompanying file LICENSE_1_0.txt or copy at
  6. * http://www.boost.org/LICENSE_1_0.txt)
  7. *
  8. * See http://www.boost.org/libs/multi_index for library home page.
  9. */
  10. #include "test_key_extractors.hpp"
  11. #include <boost/config.hpp> /* keep it first to prevent nasty warns in MSVC */
  12. #include <boost/detail/lightweight_test.hpp>
  13. #include "pre_multi_index.hpp"
  14. #include <boost/multi_index/key_extractors.hpp>
  15. #include <boost/ref.hpp>
  16. #include <boost/scoped_ptr.hpp>
  17. #include <list>
  18. using namespace boost::multi_index;
  19. using namespace boost::tuples;
  20. struct test_class
  21. {
  22. int int_member;
  23. const int int_cmember;
  24. bool bool_mem_fun_const()const{return true;}
  25. bool bool_mem_fun(){return false;}
  26. bool bool_mem_fun_volatile()volatile{return false;}
  27. bool bool_mem_fun_cv()const volatile{return true;}
  28. #if !defined(BOOST_NO_CXX11_REF_QUALIFIERS)
  29. bool bool_mem_fun_cref()const&{return true;}
  30. bool bool_mem_fun_ref()&{return false;}
  31. bool bool_mem_fun_vref()volatile&{return false;}
  32. bool bool_mem_fun_cvref()const volatile&{return true;}
  33. #endif
  34. static bool bool_global_fun(test_class){return true;}
  35. static bool bool_global_fun_const_ref(const test_class&){return false;}
  36. static bool bool_global_fun_ref(test_class&){return true;}
  37. test_class(int i=0):int_member(i),int_cmember(i){}
  38. test_class(int i,int j):int_member(i),int_cmember(j){}
  39. test_class& operator=(const test_class& x)
  40. {
  41. int_member=x.int_member;
  42. return *this;
  43. }
  44. bool operator<(const test_class& x)const
  45. {
  46. if(int_member<x.int_member)return true;
  47. if(x.int_member<int_member)return false;
  48. return int_cmember<x.int_cmember;
  49. }
  50. bool operator==(const test_class& x)const
  51. {
  52. return int_member==x.int_member&&int_cmember==x.int_cmember;
  53. }
  54. };
  55. struct test_derived_class:test_class
  56. {
  57. test_derived_class(int i=0):test_class(i){}
  58. test_derived_class(int i,int j):test_class(i,j){}
  59. };
  60. typedef identity<test_class> idn;
  61. typedef identity<const test_class> cidn;
  62. typedef BOOST_MULTI_INDEX_MEMBER(test_class,int,int_member) key_m;
  63. typedef BOOST_MULTI_INDEX_MEMBER(test_class,const int,int_member) ckey_m;
  64. typedef BOOST_MULTI_INDEX_MEMBER(test_class,const int,int_cmember) key_cm;
  65. typedef BOOST_MULTI_INDEX_MEM_FUN(test_class,bool,bool_mem_fun) key_mf;
  66. typedef BOOST_MULTI_INDEX_CONST_MEM_FUN(
  67. test_class,bool,bool_mem_fun_const) key_cmf;
  68. typedef volatile_mem_fun<
  69. test_class,bool,&test_class::bool_mem_fun_volatile> key_vmf;
  70. typedef cv_mem_fun<test_class,bool,&test_class::bool_mem_fun_cv> key_cvmf;
  71. #if !defined(BOOST_NO_CXX11_REF_QUALIFIERS)
  72. typedef cref_mem_fun<
  73. test_class,bool,&test_class::bool_mem_fun_cref> key_crmf;
  74. typedef ref_mem_fun<test_class,bool,&test_class::bool_mem_fun_ref> key_rmf;
  75. typedef vref_mem_fun<
  76. test_class,bool,&test_class::bool_mem_fun_vref> key_vrmf;
  77. typedef cvref_mem_fun<
  78. test_class,bool,&test_class::bool_mem_fun_cvref> key_cvrmf;
  79. #endif
  80. typedef global_fun<test_class,bool,&test_class::bool_global_fun> key_gf;
  81. typedef global_fun<
  82. const test_class&,bool,
  83. &test_class::bool_global_fun_const_ref
  84. > key_gcrf;
  85. typedef global_fun<
  86. test_class&,bool,
  87. &test_class::bool_global_fun_ref
  88. > key_grf;
  89. typedef composite_key<
  90. test_class,
  91. idn,
  92. key_m,
  93. key_cm,
  94. key_cmf
  95. > compkey;
  96. typedef composite_key<
  97. test_class,
  98. cidn,
  99. ckey_m
  100. > ccompkey;
  101. typedef composite_key<
  102. boost::reference_wrapper<test_class>,
  103. key_mf
  104. > ccompw_key;
  105. #if !defined(BOOST_NO_SFINAE)
  106. /* testcases for problems with non-copyable classes reported at
  107. * http://lists.boost.org/Archives/boost/2006/04/103065.php
  108. */
  109. struct test_nc_class
  110. {
  111. int int_member;
  112. const int int_cmember;
  113. bool bool_mem_fun_const()const{return true;}
  114. bool bool_mem_fun(){return false;}
  115. static bool bool_global_fun_const_ref(const test_nc_class&){return false;}
  116. static bool bool_global_fun_ref(test_nc_class&){return true;}
  117. test_nc_class(int i=0):int_member(i),int_cmember(i){}
  118. test_nc_class(int i,int j):int_member(i),int_cmember(j){}
  119. bool operator==(const test_nc_class& x)const
  120. {
  121. return int_member==x.int_member&&int_cmember==x.int_cmember;
  122. }
  123. private:
  124. test_nc_class(const test_nc_class&);
  125. test_nc_class& operator=(const test_nc_class&);
  126. };
  127. struct test_nc_derived_class:test_nc_class
  128. {
  129. test_nc_derived_class(int i=0):test_nc_class(i){}
  130. test_nc_derived_class(int i,int j):test_nc_class(i,j){}
  131. };
  132. typedef identity<test_nc_class> nc_idn;
  133. typedef identity<const test_nc_class> nc_cidn;
  134. typedef BOOST_MULTI_INDEX_MEMBER(test_nc_class,int,int_member) nc_key_m;
  135. typedef BOOST_MULTI_INDEX_MEMBER(
  136. test_nc_class,const int,int_member) nc_ckey_m;
  137. typedef BOOST_MULTI_INDEX_CONST_MEM_FUN(
  138. test_nc_class,bool,bool_mem_fun_const) nc_key_cmf;
  139. typedef BOOST_MULTI_INDEX_MEM_FUN(
  140. test_nc_class,bool,bool_mem_fun) nc_key_mf;
  141. typedef global_fun<
  142. const test_nc_class&,bool,
  143. &test_nc_class::bool_global_fun_const_ref
  144. > nc_key_gcrf;
  145. typedef global_fun<
  146. test_nc_class&,bool,
  147. &test_nc_class::bool_global_fun_ref
  148. > nc_key_grf;
  149. typedef composite_key<
  150. test_nc_class,
  151. nc_idn,
  152. nc_key_m,
  153. nc_ckey_m,
  154. nc_key_cmf
  155. > nc_compkey;
  156. #endif
  157. void test_key_extractors()
  158. {
  159. idn id;
  160. cidn cid;
  161. key_m k_m;
  162. ckey_m ck_m;
  163. key_cm k_cm;
  164. key_cmf k_cmf;
  165. key_mf k_mf;
  166. key_vmf k_vmf;
  167. key_cvmf k_cvmf;
  168. #if !defined(BOOST_NO_CXX11_REF_QUALIFIERS)
  169. key_crmf k_crmf;
  170. key_rmf k_rmf;
  171. key_vrmf k_vrmf;
  172. key_cvrmf k_cvrmf;
  173. #endif
  174. key_gf k_gf;
  175. key_gcrf k_gcrf;
  176. key_grf k_grf;
  177. compkey cmpk;
  178. ccompkey ccmpk;
  179. ccompw_key ccmpk_w;
  180. test_derived_class td(-1,0);
  181. const test_derived_class& ctdr=td;
  182. test_class& tr=td;
  183. const test_class& ctr=tr;
  184. test_derived_class* tdp=&td;
  185. const test_derived_class* ctdp=&ctdr;
  186. test_class* tp=&tr;
  187. const test_class* ctp=&tr;
  188. test_class** tpp=&tp;
  189. const test_class** ctpp=&ctp;
  190. boost::scoped_ptr<test_class*> tap(new test_class*(tp));
  191. boost::scoped_ptr<const test_class*> ctap(new const test_class*(ctp));
  192. boost::reference_wrapper<test_class> tw(tr);
  193. boost::reference_wrapper<const test_class> ctw(tr);
  194. id(tr).int_member=0;
  195. BOOST_TEST(id(tr).int_member==0);
  196. BOOST_TEST(cid(tr).int_member==0);
  197. BOOST_TEST(k_m(tr)==0);
  198. BOOST_TEST(ck_m(tr)==0);
  199. BOOST_TEST(cmpk(tr)==make_tuple(test_class(0,0),0,0,true));
  200. BOOST_TEST(ccmpk(tr)==make_tuple(test_class(0,0),0));
  201. BOOST_TEST(id(ctr).int_member==0);
  202. BOOST_TEST(cid(ctr).int_member==0);
  203. BOOST_TEST(k_m(ctr)==0);
  204. BOOST_TEST(ck_m(ctr)==0);
  205. BOOST_TEST(cmpk(ctr)==make_tuple(test_class(0,0),0,0,true));
  206. BOOST_TEST(ccmpk(ctr)==make_tuple(test_class(0,0),0));
  207. #if !defined(BOOST_NO_SFINAE)
  208. BOOST_TEST(id(td).int_member==0);
  209. BOOST_TEST(cid(td).int_member==0);
  210. BOOST_TEST(k_m(td)==0);
  211. BOOST_TEST(ck_m(td)==0);
  212. BOOST_TEST(cmpk(td)==make_tuple(test_class(0,0),0,0,true));
  213. BOOST_TEST(ccmpk(td)==make_tuple(test_class(0,0),0));
  214. BOOST_TEST(id(ctdr).int_member==0);
  215. BOOST_TEST(cid(ctdr).int_member==0);
  216. BOOST_TEST(k_m(ctdr)==0);
  217. BOOST_TEST(ck_m(ctdr)==0);
  218. BOOST_TEST(cmpk(ctdr)==make_tuple(test_class(0,0),0,0,true));
  219. BOOST_TEST(ccmpk(ctdr)==make_tuple(test_class(0,0),0));
  220. #endif
  221. k_m(tr)=1;
  222. BOOST_TEST(id(tp).int_member==1);
  223. BOOST_TEST(cid(tp).int_member==1);
  224. BOOST_TEST(k_m(tp)==1);
  225. BOOST_TEST(ck_m(tp)==1);
  226. BOOST_TEST(cmpk(tp)==make_tuple(test_class(1,0),1,0,true));
  227. BOOST_TEST(ccmpk(tp)==make_tuple(test_class(1,0),1));
  228. BOOST_TEST(cid(ctp).int_member==1);
  229. BOOST_TEST(ck_m(ctp)==1);
  230. BOOST_TEST(cmpk(ctp)==make_tuple(test_class(1,0),1,0,true));
  231. BOOST_TEST(ccmpk(ctp)==make_tuple(test_class(1,0),1));
  232. #if !defined(BOOST_NO_SFINAE)
  233. BOOST_TEST(id(tdp).int_member==1);
  234. BOOST_TEST(cid(tdp).int_member==1);
  235. BOOST_TEST(k_m(tdp)==1);
  236. BOOST_TEST(ck_m(tdp)==1);
  237. BOOST_TEST(cmpk(tdp)==make_tuple(test_class(1,0),1,0,true));
  238. BOOST_TEST(ccmpk(tdp)==make_tuple(test_class(1,0),1));
  239. BOOST_TEST(cid(ctdp).int_member==1);
  240. BOOST_TEST(ck_m(ctdp)==1);
  241. BOOST_TEST(cmpk(ctdp)==make_tuple(test_class(1,0),1,0,true));
  242. BOOST_TEST(ccmpk(ctdp)==make_tuple(test_class(1,0),1));
  243. #endif
  244. k_m(tp)=2;
  245. BOOST_TEST(id(tpp).int_member==2);
  246. BOOST_TEST(cid(tpp).int_member==2);
  247. BOOST_TEST(k_m(tpp)==2);
  248. BOOST_TEST(ck_m(tpp)==2);
  249. BOOST_TEST(cmpk(tpp)==make_tuple(test_class(2,0),2,0,true));
  250. BOOST_TEST(ccmpk(tpp)==make_tuple(test_class(2,0),2));
  251. BOOST_TEST(cid(ctpp).int_member==2);
  252. BOOST_TEST(ck_m(ctpp)==2);
  253. BOOST_TEST(cmpk(ctpp)==make_tuple(test_class(2,0),2,0,true));
  254. BOOST_TEST(ccmpk(ctpp)==make_tuple(test_class(2,0),2));
  255. k_m(tpp)=3;
  256. BOOST_TEST(id(tap).int_member==3);
  257. BOOST_TEST(cid(tap).int_member==3);
  258. BOOST_TEST(k_m(tap)==3);
  259. BOOST_TEST(ck_m(tap)==3);
  260. BOOST_TEST(cmpk(tap)==make_tuple(test_class(3,0),3,0,true));
  261. BOOST_TEST(ccmpk(tap)==make_tuple(test_class(3,0),3));
  262. BOOST_TEST(cid(ctap).int_member==3);
  263. BOOST_TEST(ck_m(ctap)==3);
  264. BOOST_TEST(cmpk(ctap)==make_tuple(test_class(3,0),3,0,true));
  265. BOOST_TEST(ccmpk(ctap)==make_tuple(test_class(3,0),3));
  266. k_m(tap)=4;
  267. BOOST_TEST(id(tw).int_member==4);
  268. BOOST_TEST(cid(tw).int_member==4);
  269. BOOST_TEST(k_m(tw)==4);
  270. BOOST_TEST(ck_m(tw)==4);
  271. BOOST_TEST(cmpk(tw)==make_tuple(test_class(4,0),4,0,true));
  272. BOOST_TEST(ccmpk(tw)==make_tuple(test_class(4,0),4));
  273. k_m(tw)=5;
  274. BOOST_TEST(id(ctw).int_member==5);
  275. BOOST_TEST(cid(ctw).int_member==5);
  276. BOOST_TEST(k_m(ctw)==5);
  277. BOOST_TEST(ck_m(ctw)==5);
  278. BOOST_TEST(cmpk(ctw)==make_tuple(test_class(5,0),5,0,true));
  279. BOOST_TEST(ccmpk(ctw)==make_tuple(test_class(5,0),5));
  280. BOOST_TEST(k_cm(tr)==0);
  281. BOOST_TEST(k_cm(ctr)==0);
  282. #if !defined(BOOST_NO_SFINAE)
  283. BOOST_TEST(k_cm(td)==0);
  284. BOOST_TEST(k_cm(ctdr)==0);
  285. #endif
  286. BOOST_TEST(k_cm(tp)==0);
  287. BOOST_TEST(k_cm(ctp)==0);
  288. #if !defined(BOOST_NO_SFINAE)
  289. BOOST_TEST(k_cm(tdp)==0);
  290. BOOST_TEST(k_cm(ctdp)==0);
  291. #endif
  292. BOOST_TEST(k_cm(tpp)==0);
  293. BOOST_TEST(k_cm(ctpp)==0);
  294. BOOST_TEST(k_cm(tap)==0);
  295. BOOST_TEST(k_cm(ctap)==0);
  296. BOOST_TEST(k_cm(tw)==0);
  297. BOOST_TEST(k_cm(ctw)==0);
  298. BOOST_TEST(k_cmf(tr));
  299. BOOST_TEST(k_cmf(ctr));
  300. BOOST_TEST(k_cvmf(tr));
  301. BOOST_TEST(k_cvmf(ctr));
  302. #if !defined(BOOST_NO_CXX11_REF_QUALIFIERS)
  303. BOOST_TEST(k_crmf(tr));
  304. BOOST_TEST(k_crmf(ctr));
  305. BOOST_TEST(k_cvrmf(tr));
  306. BOOST_TEST(k_cvrmf(ctr));
  307. #endif
  308. #if !defined(BOOST_NO_SFINAE)
  309. BOOST_TEST(k_cmf(td));
  310. BOOST_TEST(k_cmf(ctdr));
  311. BOOST_TEST(k_cvmf(td));
  312. BOOST_TEST(k_cvmf(ctdr));
  313. #if !defined(BOOST_NO_CXX11_REF_QUALIFIERS)
  314. BOOST_TEST(k_crmf(td));
  315. BOOST_TEST(k_crmf(ctdr));
  316. BOOST_TEST(k_cvrmf(td));
  317. BOOST_TEST(k_cvrmf(ctdr));
  318. #endif
  319. #endif
  320. BOOST_TEST(k_cmf(tp));
  321. BOOST_TEST(k_cmf(ctp));
  322. BOOST_TEST(k_cvmf(tp));
  323. BOOST_TEST(k_cvmf(ctp));
  324. #if !defined(BOOST_NO_CXX11_REF_QUALIFIERS)
  325. BOOST_TEST(k_crmf(tp));
  326. BOOST_TEST(k_crmf(ctp));
  327. BOOST_TEST(k_cvrmf(tp));
  328. BOOST_TEST(k_cvrmf(ctp));
  329. #endif
  330. #if !defined(BOOST_NO_SFINAE)
  331. BOOST_TEST(k_cmf(tdp));
  332. BOOST_TEST(k_cmf(ctdp));
  333. BOOST_TEST(k_cvmf(tdp));
  334. BOOST_TEST(k_cvmf(ctdp));
  335. #if !defined(BOOST_NO_CXX11_REF_QUALIFIERS)
  336. BOOST_TEST(k_crmf(tdp));
  337. BOOST_TEST(k_crmf(ctdp));
  338. BOOST_TEST(k_cvrmf(tdp));
  339. BOOST_TEST(k_cvrmf(ctdp));
  340. #endif
  341. #endif
  342. BOOST_TEST(k_cmf(tpp));
  343. BOOST_TEST(k_cmf(ctpp));
  344. BOOST_TEST(k_cmf(tap));
  345. BOOST_TEST(k_cmf(ctap));
  346. BOOST_TEST(k_cvmf(tpp));
  347. BOOST_TEST(k_cvmf(ctpp));
  348. BOOST_TEST(k_cvmf(tap));
  349. BOOST_TEST(k_cvmf(ctap));
  350. #if !defined(BOOST_NO_CXX11_REF_QUALIFIERS)
  351. BOOST_TEST(k_crmf(tpp));
  352. BOOST_TEST(k_crmf(ctpp));
  353. BOOST_TEST(k_crmf(tap));
  354. BOOST_TEST(k_crmf(ctap));
  355. BOOST_TEST(k_cvrmf(tpp));
  356. BOOST_TEST(k_cvrmf(ctpp));
  357. BOOST_TEST(k_cvrmf(tap));
  358. BOOST_TEST(k_cvrmf(ctap));
  359. #endif
  360. BOOST_TEST(k_cmf(tw));
  361. BOOST_TEST(k_cmf(ctw));
  362. BOOST_TEST(k_cvmf(tw));
  363. BOOST_TEST(k_cvmf(ctw));
  364. #if !defined(BOOST_NO_CXX11_REF_QUALIFIERS)
  365. BOOST_TEST(k_crmf(tw));
  366. BOOST_TEST(k_crmf(ctw));
  367. BOOST_TEST(k_cvrmf(tw));
  368. BOOST_TEST(k_cvrmf(ctw));
  369. #endif
  370. BOOST_TEST(!k_mf(tr));
  371. BOOST_TEST(!k_vmf(tr));
  372. #if !defined(BOOST_NO_CXX11_REF_QUALIFIERS)
  373. BOOST_TEST(!k_rmf(tr));
  374. BOOST_TEST(!k_vrmf(tr));
  375. #endif
  376. #if !defined(BOOST_NO_SFINAE)
  377. BOOST_TEST(!k_mf(td));
  378. BOOST_TEST(!k_vmf(td));
  379. #if !defined(BOOST_NO_CXX11_REF_QUALIFIERS)
  380. BOOST_TEST(!k_rmf(td));
  381. BOOST_TEST(!k_vrmf(td));
  382. #endif
  383. #endif
  384. BOOST_TEST(!k_mf(tp));
  385. BOOST_TEST(!k_vmf(tp));
  386. #if !defined(BOOST_NO_CXX11_REF_QUALIFIERS)
  387. BOOST_TEST(!k_rmf(tp));
  388. BOOST_TEST(!k_vrmf(tp));
  389. #endif
  390. #if !defined(BOOST_NO_SFINAE)
  391. BOOST_TEST(!k_mf(tdp));
  392. BOOST_TEST(!k_vmf(tdp));
  393. #if !defined(BOOST_NO_CXX11_REF_QUALIFIERS)
  394. BOOST_TEST(!k_rmf(tdp));
  395. BOOST_TEST(!k_vrmf(tdp));
  396. #endif
  397. #endif
  398. BOOST_TEST(!k_mf(tpp));
  399. BOOST_TEST(!k_mf(tap));
  400. BOOST_TEST(!k_mf(tw));
  401. BOOST_TEST(!k_vmf(tpp));
  402. BOOST_TEST(!k_vmf(tap));
  403. BOOST_TEST(!k_vmf(tw));
  404. #if !defined(BOOST_NO_CXX11_REF_QUALIFIERS)
  405. BOOST_TEST(!k_rmf(tpp));
  406. BOOST_TEST(!k_rmf(tap));
  407. BOOST_TEST(!k_rmf(tw));
  408. BOOST_TEST(!k_vrmf(tpp));
  409. BOOST_TEST(!k_vrmf(tap));
  410. BOOST_TEST(!k_vrmf(tw));
  411. #endif
  412. BOOST_TEST(k_gf(tr));
  413. BOOST_TEST(k_gf(ctr));
  414. #if !defined(BOOST_NO_SFINAE)
  415. BOOST_TEST(k_gf(td));
  416. BOOST_TEST(k_gf(ctdr));
  417. #endif
  418. BOOST_TEST(k_gf(tp));
  419. BOOST_TEST(k_gf(ctp));
  420. #if !defined(BOOST_NO_SFINAE)
  421. BOOST_TEST(k_gf(tdp));
  422. BOOST_TEST(k_gf(ctdp));
  423. #endif
  424. BOOST_TEST(k_gf(tpp));
  425. BOOST_TEST(k_gf(ctpp));
  426. BOOST_TEST(k_gf(tap));
  427. BOOST_TEST(k_gf(ctap));
  428. BOOST_TEST(k_gf(tw));
  429. BOOST_TEST(k_gf(ctw));
  430. BOOST_TEST(!k_gcrf(tr));
  431. BOOST_TEST(!k_gcrf(ctr));
  432. #if !defined(BOOST_NO_SFINAE)
  433. BOOST_TEST(!k_gcrf(td));
  434. BOOST_TEST(!k_gcrf(ctdr));
  435. #endif
  436. BOOST_TEST(!k_gcrf(tp));
  437. BOOST_TEST(!k_gcrf(ctp));
  438. #if !defined(BOOST_NO_SFINAE)
  439. BOOST_TEST(!k_gcrf(tdp));
  440. BOOST_TEST(!k_gcrf(ctdp));
  441. #endif
  442. BOOST_TEST(!k_gcrf(tpp));
  443. BOOST_TEST(!k_gcrf(ctpp));
  444. BOOST_TEST(!k_gcrf(tap));
  445. BOOST_TEST(!k_gcrf(ctap));
  446. BOOST_TEST(!k_gcrf(tw));
  447. BOOST_TEST(!k_gcrf(ctw));
  448. BOOST_TEST(k_grf(tr));
  449. #if !defined(BOOST_NO_SFINAE)
  450. BOOST_TEST(k_grf(td));
  451. #endif
  452. BOOST_TEST(k_grf(tp));
  453. #if !defined(BOOST_NO_SFINAE)
  454. BOOST_TEST(k_grf(tdp));
  455. #endif
  456. BOOST_TEST(k_grf(tpp));
  457. BOOST_TEST(k_grf(tap));
  458. BOOST_TEST(k_grf(tw));
  459. BOOST_TEST(ccmpk_w(tw)==make_tuple(false));
  460. #if !defined(BOOST_NO_SFINAE)
  461. /* testcases for problems with non-copyable classes reported at
  462. * http://lists.boost.org/Archives/boost/2006/04/103065.php
  463. */
  464. nc_idn nc_id;
  465. nc_cidn nc_cid;
  466. nc_key_m nc_k_m;
  467. nc_ckey_m nc_ck_m;
  468. nc_key_cmf nc_k_cmf;
  469. nc_key_mf nc_k_mf;
  470. nc_key_gcrf nc_k_gcrf;
  471. nc_key_grf nc_k_grf;
  472. nc_compkey nc_cmpk;
  473. test_nc_derived_class nc_td(-1,0);
  474. nc_id(nc_td).int_member=0;
  475. BOOST_TEST(nc_id(nc_td).int_member==0);
  476. BOOST_TEST(nc_cid(nc_td).int_member==0);
  477. nc_k_m(&nc_td)=1;
  478. BOOST_TEST(nc_k_m(&nc_td)==1);
  479. BOOST_TEST(nc_ck_m(&nc_td)==1);
  480. BOOST_TEST(nc_k_cmf(nc_td));
  481. BOOST_TEST(!nc_k_mf(nc_td));
  482. BOOST_TEST(!nc_k_gcrf(nc_td));
  483. BOOST_TEST(nc_k_grf(nc_td));
  484. test_nc_class nc_t(1,0);
  485. BOOST_TEST(nc_cmpk(nc_td)==make_tuple(boost::cref(nc_t),1,1,true));
  486. #endif
  487. std::list<test_class> tl;
  488. for(int i=0;i<20;++i)tl.push_back(test_class(i));
  489. int j=0;
  490. for(std::list<test_class>::iterator it=tl.begin();it!=tl.end();++it){
  491. BOOST_TEST(k_m(it)==j);
  492. BOOST_TEST(k_cm(it)==j);
  493. BOOST_TEST(k_cmf(it));
  494. BOOST_TEST(!k_mf(it));
  495. BOOST_TEST(k_gf(it));
  496. BOOST_TEST(!k_gcrf(it));
  497. BOOST_TEST(k_grf(it));
  498. BOOST_TEST(cmpk(it)==make_tuple(test_class(j),j,j,true));
  499. BOOST_TEST(ccmpk(it)==make_tuple(test_class(j),j));
  500. ++j;
  501. }
  502. }