basic_expr.hpp 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809
  1. ///////////////////////////////////////////////////////////////////////////////
  2. /// \file basic_expr.hpp
  3. /// Contains definition of basic_expr\<\> class template.
  4. //
  5. // Copyright 2008 Eric Niebler. Distributed under the Boost
  6. // Software License, Version 1.0. (See accompanying file
  7. // LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  8. template<typename Tag, typename Arg0>
  9. struct basic_expr<Tag, term<Arg0>, 0>
  10. {
  11. typedef Tag proto_tag;
  12. static const long proto_arity_c = 0;
  13. typedef mpl::long_<0 > proto_arity;
  14. typedef basic_expr proto_base_expr;
  15. typedef term<Arg0> proto_args;
  16. typedef basic_expr proto_grammar;
  17. typedef basic_default_domain proto_domain;
  18. typedef default_generator proto_generator;
  19. typedef proto::tag::proto_expr<Tag, proto_domain> fusion_tag;
  20. typedef basic_expr proto_derived_expr;
  21. typedef void proto_is_expr_;
  22. typedef Arg0 proto_child0; proto_child0 child0;
  23. typedef void proto_child1; typedef void proto_child2; typedef void proto_child3; typedef void proto_child4; typedef void proto_child5; typedef void proto_child6; typedef void proto_child7; typedef void proto_child8; typedef void proto_child9;
  24. BOOST_FORCEINLINE
  25. basic_expr const &proto_base() const
  26. {
  27. return *this;
  28. }
  29. BOOST_FORCEINLINE
  30. basic_expr &proto_base()
  31. {
  32. return *this;
  33. }
  34. template<typename A0>
  35. BOOST_FORCEINLINE
  36. static basic_expr const make(A0 &a0)
  37. {
  38. return detail::make_terminal(a0, static_cast<basic_expr *>(0), static_cast<proto_args *>(0));
  39. }
  40. template<typename A0>
  41. BOOST_FORCEINLINE
  42. static basic_expr const make(A0 const &a0)
  43. {
  44. return detail::make_terminal(a0, static_cast<basic_expr *>(0), static_cast<proto_args *>(0));
  45. }
  46. typedef detail::not_a_valid_type address_of_hack_type_;
  47. };
  48. template<typename Tag , typename Arg0>
  49. struct basic_expr<Tag, list1<Arg0>, 1 >
  50. {
  51. typedef Tag proto_tag;
  52. static const long proto_arity_c = 1;
  53. typedef mpl::long_<1 > proto_arity;
  54. typedef basic_expr proto_base_expr;
  55. typedef list1<Arg0> proto_args;
  56. typedef basic_expr proto_grammar;
  57. typedef basic_default_domain proto_domain;
  58. typedef default_generator proto_generator;
  59. typedef proto::tag::proto_expr<Tag, proto_domain> fusion_tag;
  60. typedef basic_expr proto_derived_expr;
  61. typedef void proto_is_expr_;
  62. typedef Arg0 proto_child0; proto_child0 child0;
  63. typedef void proto_child1; typedef void proto_child2; typedef void proto_child3; typedef void proto_child4; typedef void proto_child5; typedef void proto_child6; typedef void proto_child7; typedef void proto_child8; typedef void proto_child9;
  64. BOOST_FORCEINLINE
  65. basic_expr const &proto_base() const
  66. {
  67. return *this;
  68. }
  69. BOOST_FORCEINLINE
  70. basic_expr &proto_base()
  71. {
  72. return *this;
  73. }
  74. template<typename A0>
  75. BOOST_FORCEINLINE
  76. static basic_expr const make(A0 const &a0)
  77. {
  78. basic_expr that = {a0};
  79. return that;
  80. }
  81. typedef typename detail::address_of_hack<Tag, proto_child0>::type address_of_hack_type_;
  82. BOOST_FORCEINLINE
  83. operator address_of_hack_type_() const
  84. {
  85. return boost::addressof(this->child0);
  86. }
  87. };
  88. template<typename Tag , typename Arg0 , typename Arg1>
  89. struct basic_expr<Tag, list2<Arg0 , Arg1>, 2 >
  90. {
  91. typedef Tag proto_tag;
  92. static const long proto_arity_c = 2;
  93. typedef mpl::long_<2 > proto_arity;
  94. typedef basic_expr proto_base_expr;
  95. typedef list2<Arg0 , Arg1> proto_args;
  96. typedef basic_expr proto_grammar;
  97. typedef basic_default_domain proto_domain;
  98. typedef default_generator proto_generator;
  99. typedef proto::tag::proto_expr<Tag, proto_domain> fusion_tag;
  100. typedef basic_expr proto_derived_expr;
  101. typedef void proto_is_expr_;
  102. typedef Arg0 proto_child0; proto_child0 child0; typedef Arg1 proto_child1; proto_child1 child1;
  103. typedef void proto_child2; typedef void proto_child3; typedef void proto_child4; typedef void proto_child5; typedef void proto_child6; typedef void proto_child7; typedef void proto_child8; typedef void proto_child9;
  104. BOOST_FORCEINLINE
  105. basic_expr const &proto_base() const
  106. {
  107. return *this;
  108. }
  109. BOOST_FORCEINLINE
  110. basic_expr &proto_base()
  111. {
  112. return *this;
  113. }
  114. template<typename A0 , typename A1>
  115. BOOST_FORCEINLINE
  116. static basic_expr const make(A0 const &a0 , A1 const &a1)
  117. {
  118. basic_expr that = {a0 , a1};
  119. return that;
  120. }
  121. typedef detail::not_a_valid_type address_of_hack_type_;
  122. };
  123. template<typename Tag , typename Arg0 , typename Arg1 , typename Arg2>
  124. struct basic_expr<Tag, list3<Arg0 , Arg1 , Arg2>, 3 >
  125. {
  126. typedef Tag proto_tag;
  127. static const long proto_arity_c = 3;
  128. typedef mpl::long_<3 > proto_arity;
  129. typedef basic_expr proto_base_expr;
  130. typedef list3<Arg0 , Arg1 , Arg2> proto_args;
  131. typedef basic_expr proto_grammar;
  132. typedef basic_default_domain proto_domain;
  133. typedef default_generator proto_generator;
  134. typedef proto::tag::proto_expr<Tag, proto_domain> fusion_tag;
  135. typedef basic_expr proto_derived_expr;
  136. typedef void proto_is_expr_;
  137. typedef Arg0 proto_child0; proto_child0 child0; typedef Arg1 proto_child1; proto_child1 child1; typedef Arg2 proto_child2; proto_child2 child2;
  138. typedef void proto_child3; typedef void proto_child4; typedef void proto_child5; typedef void proto_child6; typedef void proto_child7; typedef void proto_child8; typedef void proto_child9;
  139. BOOST_FORCEINLINE
  140. basic_expr const &proto_base() const
  141. {
  142. return *this;
  143. }
  144. BOOST_FORCEINLINE
  145. basic_expr &proto_base()
  146. {
  147. return *this;
  148. }
  149. template<typename A0 , typename A1 , typename A2>
  150. BOOST_FORCEINLINE
  151. static basic_expr const make(A0 const &a0 , A1 const &a1 , A2 const &a2)
  152. {
  153. basic_expr that = {a0 , a1 , a2};
  154. return that;
  155. }
  156. typedef detail::not_a_valid_type address_of_hack_type_;
  157. };
  158. template<typename Tag , typename Arg0 , typename Arg1 , typename Arg2 , typename Arg3>
  159. struct basic_expr<Tag, list4<Arg0 , Arg1 , Arg2 , Arg3>, 4 >
  160. {
  161. typedef Tag proto_tag;
  162. static const long proto_arity_c = 4;
  163. typedef mpl::long_<4 > proto_arity;
  164. typedef basic_expr proto_base_expr;
  165. typedef list4<Arg0 , Arg1 , Arg2 , Arg3> proto_args;
  166. typedef basic_expr proto_grammar;
  167. typedef basic_default_domain proto_domain;
  168. typedef default_generator proto_generator;
  169. typedef proto::tag::proto_expr<Tag, proto_domain> fusion_tag;
  170. typedef basic_expr proto_derived_expr;
  171. typedef void proto_is_expr_;
  172. typedef Arg0 proto_child0; proto_child0 child0; typedef Arg1 proto_child1; proto_child1 child1; typedef Arg2 proto_child2; proto_child2 child2; typedef Arg3 proto_child3; proto_child3 child3;
  173. typedef void proto_child4; typedef void proto_child5; typedef void proto_child6; typedef void proto_child7; typedef void proto_child8; typedef void proto_child9;
  174. BOOST_FORCEINLINE
  175. basic_expr const &proto_base() const
  176. {
  177. return *this;
  178. }
  179. BOOST_FORCEINLINE
  180. basic_expr &proto_base()
  181. {
  182. return *this;
  183. }
  184. template<typename A0 , typename A1 , typename A2 , typename A3>
  185. BOOST_FORCEINLINE
  186. static basic_expr const make(A0 const &a0 , A1 const &a1 , A2 const &a2 , A3 const &a3)
  187. {
  188. basic_expr that = {a0 , a1 , a2 , a3};
  189. return that;
  190. }
  191. typedef detail::not_a_valid_type address_of_hack_type_;
  192. };
  193. template<typename Tag , typename Arg0 , typename Arg1 , typename Arg2 , typename Arg3 , typename Arg4>
  194. struct basic_expr<Tag, list5<Arg0 , Arg1 , Arg2 , Arg3 , Arg4>, 5 >
  195. {
  196. typedef Tag proto_tag;
  197. static const long proto_arity_c = 5;
  198. typedef mpl::long_<5 > proto_arity;
  199. typedef basic_expr proto_base_expr;
  200. typedef list5<Arg0 , Arg1 , Arg2 , Arg3 , Arg4> proto_args;
  201. typedef basic_expr proto_grammar;
  202. typedef basic_default_domain proto_domain;
  203. typedef default_generator proto_generator;
  204. typedef proto::tag::proto_expr<Tag, proto_domain> fusion_tag;
  205. typedef basic_expr proto_derived_expr;
  206. typedef void proto_is_expr_;
  207. typedef Arg0 proto_child0; proto_child0 child0; typedef Arg1 proto_child1; proto_child1 child1; typedef Arg2 proto_child2; proto_child2 child2; typedef Arg3 proto_child3; proto_child3 child3; typedef Arg4 proto_child4; proto_child4 child4;
  208. typedef void proto_child5; typedef void proto_child6; typedef void proto_child7; typedef void proto_child8; typedef void proto_child9;
  209. BOOST_FORCEINLINE
  210. basic_expr const &proto_base() const
  211. {
  212. return *this;
  213. }
  214. BOOST_FORCEINLINE
  215. basic_expr &proto_base()
  216. {
  217. return *this;
  218. }
  219. template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4>
  220. BOOST_FORCEINLINE
  221. static basic_expr const make(A0 const &a0 , A1 const &a1 , A2 const &a2 , A3 const &a3 , A4 const &a4)
  222. {
  223. basic_expr that = {a0 , a1 , a2 , a3 , a4};
  224. return that;
  225. }
  226. typedef detail::not_a_valid_type address_of_hack_type_;
  227. };
  228. template<typename Tag , typename Arg0 , typename Arg1 , typename Arg2 , typename Arg3 , typename Arg4 , typename Arg5>
  229. struct basic_expr<Tag, list6<Arg0 , Arg1 , Arg2 , Arg3 , Arg4 , Arg5>, 6 >
  230. {
  231. typedef Tag proto_tag;
  232. static const long proto_arity_c = 6;
  233. typedef mpl::long_<6 > proto_arity;
  234. typedef basic_expr proto_base_expr;
  235. typedef list6<Arg0 , Arg1 , Arg2 , Arg3 , Arg4 , Arg5> proto_args;
  236. typedef basic_expr proto_grammar;
  237. typedef basic_default_domain proto_domain;
  238. typedef default_generator proto_generator;
  239. typedef proto::tag::proto_expr<Tag, proto_domain> fusion_tag;
  240. typedef basic_expr proto_derived_expr;
  241. typedef void proto_is_expr_;
  242. typedef Arg0 proto_child0; proto_child0 child0; typedef Arg1 proto_child1; proto_child1 child1; typedef Arg2 proto_child2; proto_child2 child2; typedef Arg3 proto_child3; proto_child3 child3; typedef Arg4 proto_child4; proto_child4 child4; typedef Arg5 proto_child5; proto_child5 child5;
  243. typedef void proto_child6; typedef void proto_child7; typedef void proto_child8; typedef void proto_child9;
  244. BOOST_FORCEINLINE
  245. basic_expr const &proto_base() const
  246. {
  247. return *this;
  248. }
  249. BOOST_FORCEINLINE
  250. basic_expr &proto_base()
  251. {
  252. return *this;
  253. }
  254. template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5>
  255. BOOST_FORCEINLINE
  256. static basic_expr const make(A0 const &a0 , A1 const &a1 , A2 const &a2 , A3 const &a3 , A4 const &a4 , A5 const &a5)
  257. {
  258. basic_expr that = {a0 , a1 , a2 , a3 , a4 , a5};
  259. return that;
  260. }
  261. typedef detail::not_a_valid_type address_of_hack_type_;
  262. };
  263. template<typename Tag , typename Arg0 , typename Arg1 , typename Arg2 , typename Arg3 , typename Arg4 , typename Arg5 , typename Arg6>
  264. struct basic_expr<Tag, list7<Arg0 , Arg1 , Arg2 , Arg3 , Arg4 , Arg5 , Arg6>, 7 >
  265. {
  266. typedef Tag proto_tag;
  267. static const long proto_arity_c = 7;
  268. typedef mpl::long_<7 > proto_arity;
  269. typedef basic_expr proto_base_expr;
  270. typedef list7<Arg0 , Arg1 , Arg2 , Arg3 , Arg4 , Arg5 , Arg6> proto_args;
  271. typedef basic_expr proto_grammar;
  272. typedef basic_default_domain proto_domain;
  273. typedef default_generator proto_generator;
  274. typedef proto::tag::proto_expr<Tag, proto_domain> fusion_tag;
  275. typedef basic_expr proto_derived_expr;
  276. typedef void proto_is_expr_;
  277. typedef Arg0 proto_child0; proto_child0 child0; typedef Arg1 proto_child1; proto_child1 child1; typedef Arg2 proto_child2; proto_child2 child2; typedef Arg3 proto_child3; proto_child3 child3; typedef Arg4 proto_child4; proto_child4 child4; typedef Arg5 proto_child5; proto_child5 child5; typedef Arg6 proto_child6; proto_child6 child6;
  278. typedef void proto_child7; typedef void proto_child8; typedef void proto_child9;
  279. BOOST_FORCEINLINE
  280. basic_expr const &proto_base() const
  281. {
  282. return *this;
  283. }
  284. BOOST_FORCEINLINE
  285. basic_expr &proto_base()
  286. {
  287. return *this;
  288. }
  289. template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6>
  290. BOOST_FORCEINLINE
  291. static basic_expr const make(A0 const &a0 , A1 const &a1 , A2 const &a2 , A3 const &a3 , A4 const &a4 , A5 const &a5 , A6 const &a6)
  292. {
  293. basic_expr that = {a0 , a1 , a2 , a3 , a4 , a5 , a6};
  294. return that;
  295. }
  296. typedef detail::not_a_valid_type address_of_hack_type_;
  297. };
  298. template<typename Tag , typename Arg0 , typename Arg1 , typename Arg2 , typename Arg3 , typename Arg4 , typename Arg5 , typename Arg6 , typename Arg7>
  299. struct basic_expr<Tag, list8<Arg0 , Arg1 , Arg2 , Arg3 , Arg4 , Arg5 , Arg6 , Arg7>, 8 >
  300. {
  301. typedef Tag proto_tag;
  302. static const long proto_arity_c = 8;
  303. typedef mpl::long_<8 > proto_arity;
  304. typedef basic_expr proto_base_expr;
  305. typedef list8<Arg0 , Arg1 , Arg2 , Arg3 , Arg4 , Arg5 , Arg6 , Arg7> proto_args;
  306. typedef basic_expr proto_grammar;
  307. typedef basic_default_domain proto_domain;
  308. typedef default_generator proto_generator;
  309. typedef proto::tag::proto_expr<Tag, proto_domain> fusion_tag;
  310. typedef basic_expr proto_derived_expr;
  311. typedef void proto_is_expr_;
  312. typedef Arg0 proto_child0; proto_child0 child0; typedef Arg1 proto_child1; proto_child1 child1; typedef Arg2 proto_child2; proto_child2 child2; typedef Arg3 proto_child3; proto_child3 child3; typedef Arg4 proto_child4; proto_child4 child4; typedef Arg5 proto_child5; proto_child5 child5; typedef Arg6 proto_child6; proto_child6 child6; typedef Arg7 proto_child7; proto_child7 child7;
  313. typedef void proto_child8; typedef void proto_child9;
  314. BOOST_FORCEINLINE
  315. basic_expr const &proto_base() const
  316. {
  317. return *this;
  318. }
  319. BOOST_FORCEINLINE
  320. basic_expr &proto_base()
  321. {
  322. return *this;
  323. }
  324. template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7>
  325. BOOST_FORCEINLINE
  326. static basic_expr const make(A0 const &a0 , A1 const &a1 , A2 const &a2 , A3 const &a3 , A4 const &a4 , A5 const &a5 , A6 const &a6 , A7 const &a7)
  327. {
  328. basic_expr that = {a0 , a1 , a2 , a3 , a4 , a5 , a6 , a7};
  329. return that;
  330. }
  331. typedef detail::not_a_valid_type address_of_hack_type_;
  332. };
  333. template<typename Tag , typename Arg0 , typename Arg1 , typename Arg2 , typename Arg3 , typename Arg4 , typename Arg5 , typename Arg6 , typename Arg7 , typename Arg8>
  334. struct basic_expr<Tag, list9<Arg0 , Arg1 , Arg2 , Arg3 , Arg4 , Arg5 , Arg6 , Arg7 , Arg8>, 9 >
  335. {
  336. typedef Tag proto_tag;
  337. static const long proto_arity_c = 9;
  338. typedef mpl::long_<9 > proto_arity;
  339. typedef basic_expr proto_base_expr;
  340. typedef list9<Arg0 , Arg1 , Arg2 , Arg3 , Arg4 , Arg5 , Arg6 , Arg7 , Arg8> proto_args;
  341. typedef basic_expr proto_grammar;
  342. typedef basic_default_domain proto_domain;
  343. typedef default_generator proto_generator;
  344. typedef proto::tag::proto_expr<Tag, proto_domain> fusion_tag;
  345. typedef basic_expr proto_derived_expr;
  346. typedef void proto_is_expr_;
  347. typedef Arg0 proto_child0; proto_child0 child0; typedef Arg1 proto_child1; proto_child1 child1; typedef Arg2 proto_child2; proto_child2 child2; typedef Arg3 proto_child3; proto_child3 child3; typedef Arg4 proto_child4; proto_child4 child4; typedef Arg5 proto_child5; proto_child5 child5; typedef Arg6 proto_child6; proto_child6 child6; typedef Arg7 proto_child7; proto_child7 child7; typedef Arg8 proto_child8; proto_child8 child8;
  348. typedef void proto_child9;
  349. BOOST_FORCEINLINE
  350. basic_expr const &proto_base() const
  351. {
  352. return *this;
  353. }
  354. BOOST_FORCEINLINE
  355. basic_expr &proto_base()
  356. {
  357. return *this;
  358. }
  359. template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8>
  360. BOOST_FORCEINLINE
  361. static basic_expr const make(A0 const &a0 , A1 const &a1 , A2 const &a2 , A3 const &a3 , A4 const &a4 , A5 const &a5 , A6 const &a6 , A7 const &a7 , A8 const &a8)
  362. {
  363. basic_expr that = {a0 , a1 , a2 , a3 , a4 , a5 , a6 , a7 , a8};
  364. return that;
  365. }
  366. typedef detail::not_a_valid_type address_of_hack_type_;
  367. };
  368. template<typename Tag , typename Arg0 , typename Arg1 , typename Arg2 , typename Arg3 , typename Arg4 , typename Arg5 , typename Arg6 , typename Arg7 , typename Arg8 , typename Arg9>
  369. struct basic_expr<Tag, list10<Arg0 , Arg1 , Arg2 , Arg3 , Arg4 , Arg5 , Arg6 , Arg7 , Arg8 , Arg9>, 10 >
  370. {
  371. typedef Tag proto_tag;
  372. static const long proto_arity_c = 10;
  373. typedef mpl::long_<10 > proto_arity;
  374. typedef basic_expr proto_base_expr;
  375. typedef list10<Arg0 , Arg1 , Arg2 , Arg3 , Arg4 , Arg5 , Arg6 , Arg7 , Arg8 , Arg9> proto_args;
  376. typedef basic_expr proto_grammar;
  377. typedef basic_default_domain proto_domain;
  378. typedef default_generator proto_generator;
  379. typedef proto::tag::proto_expr<Tag, proto_domain> fusion_tag;
  380. typedef basic_expr proto_derived_expr;
  381. typedef void proto_is_expr_;
  382. typedef Arg0 proto_child0; proto_child0 child0; typedef Arg1 proto_child1; proto_child1 child1; typedef Arg2 proto_child2; proto_child2 child2; typedef Arg3 proto_child3; proto_child3 child3; typedef Arg4 proto_child4; proto_child4 child4; typedef Arg5 proto_child5; proto_child5 child5; typedef Arg6 proto_child6; proto_child6 child6; typedef Arg7 proto_child7; proto_child7 child7; typedef Arg8 proto_child8; proto_child8 child8; typedef Arg9 proto_child9; proto_child9 child9;
  383. BOOST_FORCEINLINE
  384. basic_expr const &proto_base() const
  385. {
  386. return *this;
  387. }
  388. BOOST_FORCEINLINE
  389. basic_expr &proto_base()
  390. {
  391. return *this;
  392. }
  393. template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8 , typename A9>
  394. BOOST_FORCEINLINE
  395. static basic_expr const make(A0 const &a0 , A1 const &a1 , A2 const &a2 , A3 const &a3 , A4 const &a4 , A5 const &a5 , A6 const &a6 , A7 const &a7 , A8 const &a8 , A9 const &a9)
  396. {
  397. basic_expr that = {a0 , a1 , a2 , a3 , a4 , a5 , a6 , a7 , a8 , a9};
  398. return that;
  399. }
  400. typedef detail::not_a_valid_type address_of_hack_type_;
  401. };