mem_fn_template.hpp 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020
  1. //
  2. // bind/mem_fn_template.hpp
  3. //
  4. // Do not include this header directly
  5. //
  6. // Copyright (c) 2001 Peter Dimov and Multi Media Ltd.
  7. //
  8. // Distributed under the Boost Software License, Version 1.0. (See
  9. // accompanying file LICENSE_1_0.txt or copy at
  10. // http://www.boost.org/LICENSE_1_0.txt)
  11. //
  12. // See http://www.boost.org/libs/bind/mem_fn.html for documentation.
  13. //
  14. #if !defined(BOOST_NO_FUNCTION_TEMPLATE_ORDERING)
  15. # define BOOST_MEM_FN_ENABLE_CONST_OVERLOADS
  16. #endif
  17. // mf0
  18. template<class R, class T BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(mf0)
  19. {
  20. public:
  21. typedef R result_type;
  22. typedef T * argument_type;
  23. private:
  24. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) ())
  25. F f_;
  26. template<class U> R call(U & u, T const *) const
  27. {
  28. BOOST_MEM_FN_RETURN (u.*f_)();
  29. }
  30. template<class U> R call(U & u, void const *) const
  31. {
  32. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)();
  33. }
  34. public:
  35. explicit BOOST_MEM_FN_NAME(mf0)(F f): f_(f) {}
  36. R operator()(T * p) const
  37. {
  38. BOOST_MEM_FN_RETURN (p->*f_)();
  39. }
  40. template<class U> R operator()(U & u) const
  41. {
  42. BOOST_MEM_FN_RETURN call(u, &u);
  43. }
  44. #ifdef BOOST_MEM_FN_ENABLE_CONST_OVERLOADS
  45. template<class U> R operator()(U const & u) const
  46. {
  47. BOOST_MEM_FN_RETURN call(u, &u);
  48. }
  49. #endif
  50. R operator()(T & t) const
  51. {
  52. BOOST_MEM_FN_RETURN (t.*f_)();
  53. }
  54. bool operator==(BOOST_MEM_FN_NAME(mf0) const & rhs) const
  55. {
  56. return f_ == rhs.f_;
  57. }
  58. bool operator!=(BOOST_MEM_FN_NAME(mf0) const & rhs) const
  59. {
  60. return f_ != rhs.f_;
  61. }
  62. };
  63. // cmf0
  64. template<class R, class T BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(cmf0)
  65. {
  66. public:
  67. typedef R result_type;
  68. typedef T const * argument_type;
  69. private:
  70. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) () const)
  71. F f_;
  72. template<class U> R call(U & u, T const *) const
  73. {
  74. BOOST_MEM_FN_RETURN (u.*f_)();
  75. }
  76. template<class U> R call(U & u, void const *) const
  77. {
  78. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)();
  79. }
  80. public:
  81. explicit BOOST_MEM_FN_NAME(cmf0)(F f): f_(f) {}
  82. template<class U> R operator()(U const & u) const
  83. {
  84. BOOST_MEM_FN_RETURN call(u, &u);
  85. }
  86. R operator()(T const & t) const
  87. {
  88. BOOST_MEM_FN_RETURN (t.*f_)();
  89. }
  90. bool operator==(BOOST_MEM_FN_NAME(cmf0) const & rhs) const
  91. {
  92. return f_ == rhs.f_;
  93. }
  94. bool operator!=(BOOST_MEM_FN_NAME(cmf0) const & rhs) const
  95. {
  96. return f_ != rhs.f_;
  97. }
  98. };
  99. // mf1
  100. template<class R, class T, class A1 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(mf1)
  101. {
  102. public:
  103. typedef R result_type;
  104. typedef T * first_argument_type;
  105. typedef A1 second_argument_type;
  106. private:
  107. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1))
  108. F f_;
  109. template<class U, class B1> R call(U & u, T const *, B1 & b1) const
  110. {
  111. BOOST_MEM_FN_RETURN (u.*f_)(b1);
  112. }
  113. template<class U, class B1> R call(U & u, void const *, B1 & b1) const
  114. {
  115. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1);
  116. }
  117. public:
  118. explicit BOOST_MEM_FN_NAME(mf1)(F f): f_(f) {}
  119. R operator()(T * p, A1 a1) const
  120. {
  121. BOOST_MEM_FN_RETURN (p->*f_)(a1);
  122. }
  123. template<class U> R operator()(U & u, A1 a1) const
  124. {
  125. BOOST_MEM_FN_RETURN call(u, &u, a1);
  126. }
  127. #ifdef BOOST_MEM_FN_ENABLE_CONST_OVERLOADS
  128. template<class U> R operator()(U const & u, A1 a1) const
  129. {
  130. BOOST_MEM_FN_RETURN call(u, &u, a1);
  131. }
  132. #endif
  133. R operator()(T & t, A1 a1) const
  134. {
  135. BOOST_MEM_FN_RETURN (t.*f_)(a1);
  136. }
  137. bool operator==(BOOST_MEM_FN_NAME(mf1) const & rhs) const
  138. {
  139. return f_ == rhs.f_;
  140. }
  141. bool operator!=(BOOST_MEM_FN_NAME(mf1) const & rhs) const
  142. {
  143. return f_ != rhs.f_;
  144. }
  145. };
  146. // cmf1
  147. template<class R, class T, class A1 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(cmf1)
  148. {
  149. public:
  150. typedef R result_type;
  151. typedef T const * first_argument_type;
  152. typedef A1 second_argument_type;
  153. private:
  154. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1) const)
  155. F f_;
  156. template<class U, class B1> R call(U & u, T const *, B1 & b1) const
  157. {
  158. BOOST_MEM_FN_RETURN (u.*f_)(b1);
  159. }
  160. template<class U, class B1> R call(U & u, void const *, B1 & b1) const
  161. {
  162. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1);
  163. }
  164. public:
  165. explicit BOOST_MEM_FN_NAME(cmf1)(F f): f_(f) {}
  166. template<class U> R operator()(U const & u, A1 a1) const
  167. {
  168. BOOST_MEM_FN_RETURN call(u, &u, a1);
  169. }
  170. R operator()(T const & t, A1 a1) const
  171. {
  172. BOOST_MEM_FN_RETURN (t.*f_)(a1);
  173. }
  174. bool operator==(BOOST_MEM_FN_NAME(cmf1) const & rhs) const
  175. {
  176. return f_ == rhs.f_;
  177. }
  178. bool operator!=(BOOST_MEM_FN_NAME(cmf1) const & rhs) const
  179. {
  180. return f_ != rhs.f_;
  181. }
  182. };
  183. // mf2
  184. template<class R, class T, class A1, class A2 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(mf2)
  185. {
  186. public:
  187. typedef R result_type;
  188. private:
  189. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1, A2))
  190. F f_;
  191. template<class U, class B1, class B2> R call(U & u, T const *, B1 & b1, B2 & b2) const
  192. {
  193. BOOST_MEM_FN_RETURN (u.*f_)(b1, b2);
  194. }
  195. template<class U, class B1, class B2> R call(U & u, void const *, B1 & b1, B2 & b2) const
  196. {
  197. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1, b2);
  198. }
  199. public:
  200. explicit BOOST_MEM_FN_NAME(mf2)(F f): f_(f) {}
  201. R operator()(T * p, A1 a1, A2 a2) const
  202. {
  203. BOOST_MEM_FN_RETURN (p->*f_)(a1, a2);
  204. }
  205. template<class U> R operator()(U & u, A1 a1, A2 a2) const
  206. {
  207. BOOST_MEM_FN_RETURN call(u, &u, a1, a2);
  208. }
  209. #ifdef BOOST_MEM_FN_ENABLE_CONST_OVERLOADS
  210. template<class U> R operator()(U const & u, A1 a1, A2 a2) const
  211. {
  212. BOOST_MEM_FN_RETURN call(u, &u, a1, a2);
  213. }
  214. #endif
  215. R operator()(T & t, A1 a1, A2 a2) const
  216. {
  217. BOOST_MEM_FN_RETURN (t.*f_)(a1, a2);
  218. }
  219. bool operator==(BOOST_MEM_FN_NAME(mf2) const & rhs) const
  220. {
  221. return f_ == rhs.f_;
  222. }
  223. bool operator!=(BOOST_MEM_FN_NAME(mf2) const & rhs) const
  224. {
  225. return f_ != rhs.f_;
  226. }
  227. };
  228. // cmf2
  229. template<class R, class T, class A1, class A2 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(cmf2)
  230. {
  231. public:
  232. typedef R result_type;
  233. private:
  234. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1, A2) const)
  235. F f_;
  236. template<class U, class B1, class B2> R call(U & u, T const *, B1 & b1, B2 & b2) const
  237. {
  238. BOOST_MEM_FN_RETURN (u.*f_)(b1, b2);
  239. }
  240. template<class U, class B1, class B2> R call(U & u, void const *, B1 & b1, B2 & b2) const
  241. {
  242. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1, b2);
  243. }
  244. public:
  245. explicit BOOST_MEM_FN_NAME(cmf2)(F f): f_(f) {}
  246. template<class U> R operator()(U const & u, A1 a1, A2 a2) const
  247. {
  248. BOOST_MEM_FN_RETURN call(u, &u, a1, a2);
  249. }
  250. R operator()(T const & t, A1 a1, A2 a2) const
  251. {
  252. BOOST_MEM_FN_RETURN (t.*f_)(a1, a2);
  253. }
  254. bool operator==(BOOST_MEM_FN_NAME(cmf2) const & rhs) const
  255. {
  256. return f_ == rhs.f_;
  257. }
  258. bool operator!=(BOOST_MEM_FN_NAME(cmf2) const & rhs) const
  259. {
  260. return f_ != rhs.f_;
  261. }
  262. };
  263. // mf3
  264. template<class R, class T, class A1, class A2, class A3 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(mf3)
  265. {
  266. public:
  267. typedef R result_type;
  268. private:
  269. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1, A2, A3))
  270. F f_;
  271. template<class U, class B1, class B2, class B3> R call(U & u, T const *, B1 & b1, B2 & b2, B3 & b3) const
  272. {
  273. BOOST_MEM_FN_RETURN (u.*f_)(b1, b2, b3);
  274. }
  275. template<class U, class B1, class B2, class B3> R call(U & u, void const *, B1 & b1, B2 & b2, B3 & b3) const
  276. {
  277. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1, b2, b3);
  278. }
  279. public:
  280. explicit BOOST_MEM_FN_NAME(mf3)(F f): f_(f) {}
  281. R operator()(T * p, A1 a1, A2 a2, A3 a3) const
  282. {
  283. BOOST_MEM_FN_RETURN (p->*f_)(a1, a2, a3);
  284. }
  285. template<class U> R operator()(U & u, A1 a1, A2 a2, A3 a3) const
  286. {
  287. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3);
  288. }
  289. #ifdef BOOST_MEM_FN_ENABLE_CONST_OVERLOADS
  290. template<class U> R operator()(U const & u, A1 a1, A2 a2, A3 a3) const
  291. {
  292. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3);
  293. }
  294. #endif
  295. R operator()(T & t, A1 a1, A2 a2, A3 a3) const
  296. {
  297. BOOST_MEM_FN_RETURN (t.*f_)(a1, a2, a3);
  298. }
  299. bool operator==(BOOST_MEM_FN_NAME(mf3) const & rhs) const
  300. {
  301. return f_ == rhs.f_;
  302. }
  303. bool operator!=(BOOST_MEM_FN_NAME(mf3) const & rhs) const
  304. {
  305. return f_ != rhs.f_;
  306. }
  307. };
  308. // cmf3
  309. template<class R, class T, class A1, class A2, class A3 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(cmf3)
  310. {
  311. public:
  312. typedef R result_type;
  313. private:
  314. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1, A2, A3) const)
  315. F f_;
  316. template<class U, class B1, class B2, class B3> R call(U & u, T const *, B1 & b1, B2 & b2, B3 & b3) const
  317. {
  318. BOOST_MEM_FN_RETURN (u.*f_)(b1, b2, b3);
  319. }
  320. template<class U, class B1, class B2, class B3> R call(U & u, void const *, B1 & b1, B2 & b2, B3 & b3) const
  321. {
  322. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1, b2, b3);
  323. }
  324. public:
  325. explicit BOOST_MEM_FN_NAME(cmf3)(F f): f_(f) {}
  326. template<class U> R operator()(U const & u, A1 a1, A2 a2, A3 a3) const
  327. {
  328. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3);
  329. }
  330. R operator()(T const & t, A1 a1, A2 a2, A3 a3) const
  331. {
  332. BOOST_MEM_FN_RETURN (t.*f_)(a1, a2, a3);
  333. }
  334. bool operator==(BOOST_MEM_FN_NAME(cmf3) const & rhs) const
  335. {
  336. return f_ == rhs.f_;
  337. }
  338. bool operator!=(BOOST_MEM_FN_NAME(cmf3) const & rhs) const
  339. {
  340. return f_ != rhs.f_;
  341. }
  342. };
  343. // mf4
  344. template<class R, class T, class A1, class A2, class A3, class A4 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(mf4)
  345. {
  346. public:
  347. typedef R result_type;
  348. private:
  349. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1, A2, A3, A4))
  350. F f_;
  351. template<class U, class B1, class B2, class B3, class B4> R call(U & u, T const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4) const
  352. {
  353. BOOST_MEM_FN_RETURN (u.*f_)(b1, b2, b3, b4);
  354. }
  355. template<class U, class B1, class B2, class B3, class B4> R call(U & u, void const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4) const
  356. {
  357. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1, b2, b3, b4);
  358. }
  359. public:
  360. explicit BOOST_MEM_FN_NAME(mf4)(F f): f_(f) {}
  361. R operator()(T * p, A1 a1, A2 a2, A3 a3, A4 a4) const
  362. {
  363. BOOST_MEM_FN_RETURN (p->*f_)(a1, a2, a3, a4);
  364. }
  365. template<class U> R operator()(U & u, A1 a1, A2 a2, A3 a3, A4 a4) const
  366. {
  367. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4);
  368. }
  369. #ifdef BOOST_MEM_FN_ENABLE_CONST_OVERLOADS
  370. template<class U> R operator()(U const & u, A1 a1, A2 a2, A3 a3, A4 a4) const
  371. {
  372. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4);
  373. }
  374. #endif
  375. R operator()(T & t, A1 a1, A2 a2, A3 a3, A4 a4) const
  376. {
  377. BOOST_MEM_FN_RETURN (t.*f_)(a1, a2, a3, a4);
  378. }
  379. bool operator==(BOOST_MEM_FN_NAME(mf4) const & rhs) const
  380. {
  381. return f_ == rhs.f_;
  382. }
  383. bool operator!=(BOOST_MEM_FN_NAME(mf4) const & rhs) const
  384. {
  385. return f_ != rhs.f_;
  386. }
  387. };
  388. // cmf4
  389. template<class R, class T, class A1, class A2, class A3, class A4 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(cmf4)
  390. {
  391. public:
  392. typedef R result_type;
  393. private:
  394. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1, A2, A3, A4) const)
  395. F f_;
  396. template<class U, class B1, class B2, class B3, class B4> R call(U & u, T const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4) const
  397. {
  398. BOOST_MEM_FN_RETURN (u.*f_)(b1, b2, b3, b4);
  399. }
  400. template<class U, class B1, class B2, class B3, class B4> R call(U & u, void const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4) const
  401. {
  402. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1, b2, b3, b4);
  403. }
  404. public:
  405. explicit BOOST_MEM_FN_NAME(cmf4)(F f): f_(f) {}
  406. template<class U> R operator()(U const & u, A1 a1, A2 a2, A3 a3, A4 a4) const
  407. {
  408. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4);
  409. }
  410. R operator()(T const & t, A1 a1, A2 a2, A3 a3, A4 a4) const
  411. {
  412. BOOST_MEM_FN_RETURN (t.*f_)(a1, a2, a3, a4);
  413. }
  414. bool operator==(BOOST_MEM_FN_NAME(cmf4) const & rhs) const
  415. {
  416. return f_ == rhs.f_;
  417. }
  418. bool operator!=(BOOST_MEM_FN_NAME(cmf4) const & rhs) const
  419. {
  420. return f_ != rhs.f_;
  421. }
  422. };
  423. // mf5
  424. template<class R, class T, class A1, class A2, class A3, class A4, class A5 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(mf5)
  425. {
  426. public:
  427. typedef R result_type;
  428. private:
  429. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1, A2, A3, A4, A5))
  430. F f_;
  431. template<class U, class B1, class B2, class B3, class B4, class B5> R call(U & u, T const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5) const
  432. {
  433. BOOST_MEM_FN_RETURN (u.*f_)(b1, b2, b3, b4, b5);
  434. }
  435. template<class U, class B1, class B2, class B3, class B4, class B5> R call(U & u, void const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5) const
  436. {
  437. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1, b2, b3, b4, b5);
  438. }
  439. public:
  440. explicit BOOST_MEM_FN_NAME(mf5)(F f): f_(f) {}
  441. R operator()(T * p, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5) const
  442. {
  443. BOOST_MEM_FN_RETURN (p->*f_)(a1, a2, a3, a4, a5);
  444. }
  445. template<class U> R operator()(U & u, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5) const
  446. {
  447. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4, a5);
  448. }
  449. #ifdef BOOST_MEM_FN_ENABLE_CONST_OVERLOADS
  450. template<class U> R operator()(U const & u, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5) const
  451. {
  452. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4, a5);
  453. }
  454. #endif
  455. R operator()(T & t, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5) const
  456. {
  457. BOOST_MEM_FN_RETURN (t.*f_)(a1, a2, a3, a4, a5);
  458. }
  459. bool operator==(BOOST_MEM_FN_NAME(mf5) const & rhs) const
  460. {
  461. return f_ == rhs.f_;
  462. }
  463. bool operator!=(BOOST_MEM_FN_NAME(mf5) const & rhs) const
  464. {
  465. return f_ != rhs.f_;
  466. }
  467. };
  468. // cmf5
  469. template<class R, class T, class A1, class A2, class A3, class A4, class A5 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(cmf5)
  470. {
  471. public:
  472. typedef R result_type;
  473. private:
  474. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1, A2, A3, A4, A5) const)
  475. F f_;
  476. template<class U, class B1, class B2, class B3, class B4, class B5> R call(U & u, T const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5) const
  477. {
  478. BOOST_MEM_FN_RETURN (u.*f_)(b1, b2, b3, b4, b5);
  479. }
  480. template<class U, class B1, class B2, class B3, class B4, class B5> R call(U & u, void const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5) const
  481. {
  482. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1, b2, b3, b4, b5);
  483. }
  484. public:
  485. explicit BOOST_MEM_FN_NAME(cmf5)(F f): f_(f) {}
  486. template<class U> R operator()(U const & u, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5) const
  487. {
  488. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4, a5);
  489. }
  490. R operator()(T const & t, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5) const
  491. {
  492. BOOST_MEM_FN_RETURN (t.*f_)(a1, a2, a3, a4, a5);
  493. }
  494. bool operator==(BOOST_MEM_FN_NAME(cmf5) const & rhs) const
  495. {
  496. return f_ == rhs.f_;
  497. }
  498. bool operator!=(BOOST_MEM_FN_NAME(cmf5) const & rhs) const
  499. {
  500. return f_ != rhs.f_;
  501. }
  502. };
  503. // mf6
  504. template<class R, class T, class A1, class A2, class A3, class A4, class A5, class A6 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(mf6)
  505. {
  506. public:
  507. typedef R result_type;
  508. private:
  509. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1, A2, A3, A4, A5, A6))
  510. F f_;
  511. template<class U, class B1, class B2, class B3, class B4, class B5, class B6> R call(U & u, T const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5, B6 & b6) const
  512. {
  513. BOOST_MEM_FN_RETURN (u.*f_)(b1, b2, b3, b4, b5, b6);
  514. }
  515. template<class U, class B1, class B2, class B3, class B4, class B5, class B6> R call(U & u, void const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5, B6 & b6) const
  516. {
  517. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1, b2, b3, b4, b5, b6);
  518. }
  519. public:
  520. explicit BOOST_MEM_FN_NAME(mf6)(F f): f_(f) {}
  521. R operator()(T * p, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6) const
  522. {
  523. BOOST_MEM_FN_RETURN (p->*f_)(a1, a2, a3, a4, a5, a6);
  524. }
  525. template<class U> R operator()(U & u, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6) const
  526. {
  527. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4, a5, a6);
  528. }
  529. #ifdef BOOST_MEM_FN_ENABLE_CONST_OVERLOADS
  530. template<class U> R operator()(U const & u, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6) const
  531. {
  532. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4, a5, a6);
  533. }
  534. #endif
  535. R operator()(T & t, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6) const
  536. {
  537. BOOST_MEM_FN_RETURN (t.*f_)(a1, a2, a3, a4, a5, a6);
  538. }
  539. bool operator==(BOOST_MEM_FN_NAME(mf6) const & rhs) const
  540. {
  541. return f_ == rhs.f_;
  542. }
  543. bool operator!=(BOOST_MEM_FN_NAME(mf6) const & rhs) const
  544. {
  545. return f_ != rhs.f_;
  546. }
  547. };
  548. // cmf6
  549. template<class R, class T, class A1, class A2, class A3, class A4, class A5, class A6 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(cmf6)
  550. {
  551. public:
  552. typedef R result_type;
  553. private:
  554. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1, A2, A3, A4, A5, A6) const)
  555. F f_;
  556. template<class U, class B1, class B2, class B3, class B4, class B5, class B6> R call(U & u, T const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5, B6 & b6) const
  557. {
  558. BOOST_MEM_FN_RETURN (u.*f_)(b1, b2, b3, b4, b5, b6);
  559. }
  560. template<class U, class B1, class B2, class B3, class B4, class B5, class B6> R call(U & u, void const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5, B6 & b6) const
  561. {
  562. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1, b2, b3, b4, b5, b6);
  563. }
  564. public:
  565. explicit BOOST_MEM_FN_NAME(cmf6)(F f): f_(f) {}
  566. template<class U> R operator()(U const & u, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6) const
  567. {
  568. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4, a5, a6);
  569. }
  570. R operator()(T const & t, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6) const
  571. {
  572. BOOST_MEM_FN_RETURN (t.*f_)(a1, a2, a3, a4, a5, a6);
  573. }
  574. bool operator==(BOOST_MEM_FN_NAME(cmf6) const & rhs) const
  575. {
  576. return f_ == rhs.f_;
  577. }
  578. bool operator!=(BOOST_MEM_FN_NAME(cmf6) const & rhs) const
  579. {
  580. return f_ != rhs.f_;
  581. }
  582. };
  583. // mf7
  584. template<class R, class T, class A1, class A2, class A3, class A4, class A5, class A6, class A7 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(mf7)
  585. {
  586. public:
  587. typedef R result_type;
  588. private:
  589. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1, A2, A3, A4, A5, A6, A7))
  590. F f_;
  591. template<class U, class B1, class B2, class B3, class B4, class B5, class B6, class B7> R call(U & u, T const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5, B6 & b6, B7 & b7) const
  592. {
  593. BOOST_MEM_FN_RETURN (u.*f_)(b1, b2, b3, b4, b5, b6, b7);
  594. }
  595. template<class U, class B1, class B2, class B3, class B4, class B5, class B6, class B7> R call(U & u, void const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5, B6 & b6, B7 & b7) const
  596. {
  597. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1, b2, b3, b4, b5, b6, b7);
  598. }
  599. public:
  600. explicit BOOST_MEM_FN_NAME(mf7)(F f): f_(f) {}
  601. R operator()(T * p, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7) const
  602. {
  603. BOOST_MEM_FN_RETURN (p->*f_)(a1, a2, a3, a4, a5, a6, a7);
  604. }
  605. template<class U> R operator()(U & u, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7) const
  606. {
  607. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4, a5, a6, a7);
  608. }
  609. #ifdef BOOST_MEM_FN_ENABLE_CONST_OVERLOADS
  610. template<class U> R operator()(U const & u, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7) const
  611. {
  612. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4, a5, a6, a7);
  613. }
  614. #endif
  615. R operator()(T & t, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7) const
  616. {
  617. BOOST_MEM_FN_RETURN (t.*f_)(a1, a2, a3, a4, a5, a6, a7);
  618. }
  619. bool operator==(BOOST_MEM_FN_NAME(mf7) const & rhs) const
  620. {
  621. return f_ == rhs.f_;
  622. }
  623. bool operator!=(BOOST_MEM_FN_NAME(mf7) const & rhs) const
  624. {
  625. return f_ != rhs.f_;
  626. }
  627. };
  628. // cmf7
  629. template<class R, class T, class A1, class A2, class A3, class A4, class A5, class A6, class A7 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(cmf7)
  630. {
  631. public:
  632. typedef R result_type;
  633. private:
  634. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1, A2, A3, A4, A5, A6, A7) const)
  635. F f_;
  636. template<class U, class B1, class B2, class B3, class B4, class B5, class B6, class B7> R call(U & u, T const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5, B6 & b6, B7 & b7) const
  637. {
  638. BOOST_MEM_FN_RETURN (u.*f_)(b1, b2, b3, b4, b5, b6, b7);
  639. }
  640. template<class U, class B1, class B2, class B3, class B4, class B5, class B6, class B7> R call(U & u, void const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5, B6 & b6, B7 & b7) const
  641. {
  642. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1, b2, b3, b4, b5, b6, b7);
  643. }
  644. public:
  645. explicit BOOST_MEM_FN_NAME(cmf7)(F f): f_(f) {}
  646. template<class U> R operator()(U const & u, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7) const
  647. {
  648. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4, a5, a6, a7);
  649. }
  650. R operator()(T const & t, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7) const
  651. {
  652. BOOST_MEM_FN_RETURN (t.*f_)(a1, a2, a3, a4, a5, a6, a7);
  653. }
  654. bool operator==(BOOST_MEM_FN_NAME(cmf7) const & rhs) const
  655. {
  656. return f_ == rhs.f_;
  657. }
  658. bool operator!=(BOOST_MEM_FN_NAME(cmf7) const & rhs) const
  659. {
  660. return f_ != rhs.f_;
  661. }
  662. };
  663. // mf8
  664. template<class R, class T, class A1, class A2, class A3, class A4, class A5, class A6, class A7, class A8 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(mf8)
  665. {
  666. public:
  667. typedef R result_type;
  668. private:
  669. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1, A2, A3, A4, A5, A6, A7, A8))
  670. F f_;
  671. template<class U, class B1, class B2, class B3, class B4, class B5, class B6, class B7, class B8> R call(U & u, T const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5, B6 & b6, B7 & b7, B8 & b8) const
  672. {
  673. BOOST_MEM_FN_RETURN (u.*f_)(b1, b2, b3, b4, b5, b6, b7, b8);
  674. }
  675. template<class U, class B1, class B2, class B3, class B4, class B5, class B6, class B7, class B8> R call(U & u, void const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5, B6 & b6, B7 & b7, B8 & b8) const
  676. {
  677. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1, b2, b3, b4, b5, b6, b7, b8);
  678. }
  679. public:
  680. explicit BOOST_MEM_FN_NAME(mf8)(F f): f_(f) {}
  681. R operator()(T * p, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8) const
  682. {
  683. BOOST_MEM_FN_RETURN (p->*f_)(a1, a2, a3, a4, a5, a6, a7, a8);
  684. }
  685. template<class U> R operator()(U & u, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8) const
  686. {
  687. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4, a5, a6, a7, a8);
  688. }
  689. #ifdef BOOST_MEM_FN_ENABLE_CONST_OVERLOADS
  690. template<class U> R operator()(U const & u, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8) const
  691. {
  692. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4, a5, a6, a7, a8);
  693. }
  694. #endif
  695. R operator()(T & t, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8) const
  696. {
  697. BOOST_MEM_FN_RETURN (t.*f_)(a1, a2, a3, a4, a5, a6, a7, a8);
  698. }
  699. bool operator==(BOOST_MEM_FN_NAME(mf8) const & rhs) const
  700. {
  701. return f_ == rhs.f_;
  702. }
  703. bool operator!=(BOOST_MEM_FN_NAME(mf8) const & rhs) const
  704. {
  705. return f_ != rhs.f_;
  706. }
  707. };
  708. // cmf8
  709. template<class R, class T, class A1, class A2, class A3, class A4, class A5, class A6, class A7, class A8 BOOST_MEM_FN_CLASS_F> class BOOST_MEM_FN_NAME(cmf8)
  710. {
  711. public:
  712. typedef R result_type;
  713. private:
  714. BOOST_MEM_FN_TYPEDEF(R (BOOST_MEM_FN_CC T::*F) (A1, A2, A3, A4, A5, A6, A7, A8) const)
  715. F f_;
  716. template<class U, class B1, class B2, class B3, class B4, class B5, class B6, class B7, class B8> R call(U & u, T const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5, B6 & b6, B7 & b7, B8 & b8) const
  717. {
  718. BOOST_MEM_FN_RETURN (u.*f_)(b1, b2, b3, b4, b5, b6, b7, b8);
  719. }
  720. template<class U, class B1, class B2, class B3, class B4, class B5, class B6, class B7, class B8> R call(U & u, void const *, B1 & b1, B2 & b2, B3 & b3, B4 & b4, B5 & b5, B6 & b6, B7 & b7, B8 & b8) const
  721. {
  722. BOOST_MEM_FN_RETURN (get_pointer(u)->*f_)(b1, b2, b3, b4, b5, b6, b7, b8);
  723. }
  724. public:
  725. explicit BOOST_MEM_FN_NAME(cmf8)(F f): f_(f) {}
  726. R operator()(T const * p, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8) const
  727. {
  728. BOOST_MEM_FN_RETURN (p->*f_)(a1, a2, a3, a4, a5, a6, a7, a8);
  729. }
  730. template<class U> R operator()(U const & u, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8) const
  731. {
  732. BOOST_MEM_FN_RETURN call(u, &u, a1, a2, a3, a4, a5, a6, a7, a8);
  733. }
  734. R operator()(T const & t, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8) const
  735. {
  736. BOOST_MEM_FN_RETURN (t.*f_)(a1, a2, a3, a4, a5, a6, a7, a8);
  737. }
  738. bool operator==(BOOST_MEM_FN_NAME(cmf8) const & rhs) const
  739. {
  740. return f_ == rhs.f_;
  741. }
  742. bool operator!=(BOOST_MEM_FN_NAME(cmf8) const & rhs) const
  743. {
  744. return f_ != rhs.f_;
  745. }
  746. };
  747. #undef BOOST_MEM_FN_ENABLE_CONST_OVERLOADS