add_varargs.cpp 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. /*
  2. Copyright Barrett Adair 2016-2017
  3. Distributed under the Boost Software License, Version 1.0.
  4. (See accompanying file LICENSE.md or copy at http ://boost.org/LICENSE_1_0.txt)
  5. */
  6. #include <type_traits>
  7. #include <functional>
  8. #include <tuple>
  9. #include <boost/callable_traits/add_varargs.hpp>
  10. #include "test.hpp"
  11. struct foo {};
  12. int main() {
  13. {
  14. using f = void(foo::*)();
  15. using l = void(foo::*)() LREF;
  16. using r = void(foo::*)() RREF ;
  17. using c = void(foo::*)() const;
  18. using cl = void(foo::*)() const LREF;
  19. using cr = void(foo::*)() const RREF;
  20. using v = void(foo::*)() volatile;
  21. using vl = void(foo::*)() volatile LREF;
  22. using vr = void(foo::*)() volatile RREF;
  23. using cv = void(foo::*)() const volatile;
  24. using cvl = void(foo::*)() const volatile LREF;
  25. using cvr = void(foo::*)() const volatile RREF;
  26. using va_f = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(...);
  27. using va_l = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(...) LREF;
  28. using va_r = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(...) RREF ;
  29. using va_c = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(...) const;
  30. using va_cl = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(...) const LREF;
  31. using va_cr = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(...) const RREF;
  32. using va_v = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(...) volatile;
  33. using va_vl = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(...) volatile LREF;
  34. using va_vr = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(...) volatile RREF;
  35. using va_cv = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(...) const volatile;
  36. using va_cvl = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(...) const volatile LREF;
  37. using va_cvr = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(...) const volatile RREF;
  38. CT_ASSERT(std::is_same<va_f, TRAIT(add_varargs, f)>{});
  39. CT_ASSERT(std::is_same<va_l, TRAIT(add_varargs, l)>{});
  40. CT_ASSERT(std::is_same<va_r, TRAIT(add_varargs, r)>{});
  41. CT_ASSERT(std::is_same<va_c, TRAIT(add_varargs, c)>{});
  42. CT_ASSERT(std::is_same<va_cl, TRAIT(add_varargs, cl)>{});
  43. CT_ASSERT(std::is_same<va_cr, TRAIT(add_varargs, cr)>{});
  44. CT_ASSERT(std::is_same<va_v, TRAIT(add_varargs, v)>{});
  45. CT_ASSERT(std::is_same<va_vl, TRAIT(add_varargs, vl)>{});
  46. CT_ASSERT(std::is_same<va_vr, TRAIT(add_varargs, vr)>{});
  47. CT_ASSERT(std::is_same<va_cv, TRAIT(add_varargs, cv)>{});
  48. CT_ASSERT(std::is_same<va_cvl, TRAIT(add_varargs, cvl)>{});
  49. CT_ASSERT(std::is_same<va_cvr, TRAIT(add_varargs, cvr)>{});
  50. CT_ASSERT(std::is_same<va_f, TRAIT(add_varargs, va_f)>{});
  51. CT_ASSERT(std::is_same<va_l, TRAIT(add_varargs, va_l)>{});
  52. CT_ASSERT(std::is_same<va_r, TRAIT(add_varargs, va_r)>{});
  53. CT_ASSERT(std::is_same<va_c, TRAIT(add_varargs, va_c)>{});
  54. CT_ASSERT(std::is_same<va_cl, TRAIT(add_varargs, va_cl)>{});
  55. CT_ASSERT(std::is_same<va_cr, TRAIT(add_varargs, va_cr)>{});
  56. CT_ASSERT(std::is_same<va_v, TRAIT(add_varargs, va_v)>{});
  57. CT_ASSERT(std::is_same<va_vl, TRAIT(add_varargs, va_vl)>{});
  58. CT_ASSERT(std::is_same<va_vr, TRAIT(add_varargs, va_vr)>{});
  59. CT_ASSERT(std::is_same<va_cv, TRAIT(add_varargs, va_cv)>{});
  60. CT_ASSERT(std::is_same<va_cvl, TRAIT(add_varargs, va_cvl)>{});
  61. CT_ASSERT(std::is_same<va_cvr, TRAIT(add_varargs, va_cvr)>{});
  62. }
  63. {
  64. using f = void(foo::*)(int&, int&&);
  65. using l = void(foo::*)(int&, int&&) LREF;
  66. using r = void(foo::*)(int&, int&&) RREF ;
  67. using c = void(foo::*)(int&, int&&) const;
  68. using cl = void(foo::*)(int&, int&&) const LREF;
  69. using cr = void(foo::*)(int&, int&&) const RREF;
  70. using v = void(foo::*)(int&, int&&) volatile;
  71. using vl = void(foo::*)(int&, int&&) volatile LREF;
  72. using vr = void(foo::*)(int&, int&&) volatile RREF;
  73. using cv = void(foo::*)(int&, int&&) const volatile;
  74. using cvl = void(foo::*)(int&, int&&) const volatile LREF;
  75. using cvr = void(foo::*)(int&, int&&) const volatile RREF;
  76. using va_f = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(int&, int&&, ...);
  77. using va_l = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(int&, int&&, ...) LREF;
  78. using va_r = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(int&, int&&, ...) RREF ;
  79. using va_c = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(int&, int&&, ...) const;
  80. using va_cl = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(int&, int&&, ...) const LREF;
  81. using va_cr = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(int&, int&&, ...) const RREF;
  82. using va_v = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(int&, int&&, ...) volatile;
  83. using va_vl = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(int&, int&&, ...) volatile LREF;
  84. using va_vr = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(int&, int&&, ...) volatile RREF;
  85. using va_cv = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(int&, int&&, ...) const volatile;
  86. using va_cvl = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(int&, int&&, ...) const volatile LREF;
  87. using va_cvr = void(BOOST_CLBL_TRTS_DEFAULT_VARARGS_CC foo::*)(int&, int&&, ...) const volatile RREF;
  88. CT_ASSERT(std::is_same<va_f, TRAIT(add_varargs, f)>{});
  89. CT_ASSERT(std::is_same<va_l, TRAIT(add_varargs, l)>{});
  90. CT_ASSERT(std::is_same<va_r, TRAIT(add_varargs, r)>{});
  91. CT_ASSERT(std::is_same<va_c, TRAIT(add_varargs, c)>{});
  92. CT_ASSERT(std::is_same<va_cl, TRAIT(add_varargs, cl)>{});
  93. CT_ASSERT(std::is_same<va_cr, TRAIT(add_varargs, cr)>{});
  94. CT_ASSERT(std::is_same<va_v, TRAIT(add_varargs, v)>{});
  95. CT_ASSERT(std::is_same<va_vl, TRAIT(add_varargs, vl)>{});
  96. CT_ASSERT(std::is_same<va_vr, TRAIT(add_varargs, vr)>{});
  97. CT_ASSERT(std::is_same<va_cv, TRAIT(add_varargs, cv)>{});
  98. CT_ASSERT(std::is_same<va_cvl, TRAIT(add_varargs, cvl)>{});
  99. CT_ASSERT(std::is_same<va_cvr, TRAIT(add_varargs, cvr)>{});
  100. CT_ASSERT(std::is_same<va_f, TRAIT(add_varargs, va_f)>{});
  101. CT_ASSERT(std::is_same<va_l, TRAIT(add_varargs, va_l)>{});
  102. CT_ASSERT(std::is_same<va_r, TRAIT(add_varargs, va_r)>{});
  103. CT_ASSERT(std::is_same<va_c, TRAIT(add_varargs, va_c)>{});
  104. CT_ASSERT(std::is_same<va_cl, TRAIT(add_varargs, va_cl)>{});
  105. CT_ASSERT(std::is_same<va_cr, TRAIT(add_varargs, va_cr)>{});
  106. CT_ASSERT(std::is_same<va_v, TRAIT(add_varargs, va_v)>{});
  107. CT_ASSERT(std::is_same<va_vl, TRAIT(add_varargs, va_vl)>{});
  108. CT_ASSERT(std::is_same<va_vr, TRAIT(add_varargs, va_vr)>{});
  109. CT_ASSERT(std::is_same<va_cv, TRAIT(add_varargs, va_cv)>{});
  110. CT_ASSERT(std::is_same<va_cvl, TRAIT(add_varargs, va_cvl)>{});
  111. CT_ASSERT(std::is_same<va_cvr, TRAIT(add_varargs, va_cvr)>{});
  112. }
  113. #ifndef BOOST_CLBL_TRTS_DISABLE_ABOMINABLE_FUNCTIONS
  114. {
  115. using f = void();
  116. using l = void() LREF;
  117. using r = void() RREF ;
  118. using c = void() const;
  119. using cl = void() const LREF;
  120. using cr = void() const RREF;
  121. using v = void() volatile;
  122. using vl = void() volatile LREF;
  123. using vr = void() volatile RREF;
  124. using cv = void() const volatile;
  125. using cvl = void() const volatile LREF;
  126. using cvr = void() const volatile RREF;
  127. using va_f = void(...);
  128. using va_l = void(...) LREF;
  129. using va_r = void(...) RREF ;
  130. using va_c = void(...) const;
  131. using va_cl = void(...) const LREF;
  132. using va_cr = void(...) const RREF;
  133. using va_v = void(...) volatile;
  134. using va_vl = void(...) volatile LREF;
  135. using va_vr = void(...) volatile RREF;
  136. using va_cv = void(...) const volatile;
  137. using va_cvl = void(...) const volatile LREF;
  138. using va_cvr = void(...) const volatile RREF;
  139. CT_ASSERT(std::is_same<va_f, TRAIT(add_varargs, f)>{});
  140. CT_ASSERT(std::is_same<va_l, TRAIT(add_varargs, l)>{});
  141. CT_ASSERT(std::is_same<va_r, TRAIT(add_varargs, r)>{});
  142. CT_ASSERT(std::is_same<va_c, TRAIT(add_varargs, c)>{});
  143. CT_ASSERT(std::is_same<va_cl, TRAIT(add_varargs, cl)>{});
  144. CT_ASSERT(std::is_same<va_cr, TRAIT(add_varargs, cr)>{});
  145. CT_ASSERT(std::is_same<va_v, TRAIT(add_varargs, v)>{});
  146. CT_ASSERT(std::is_same<va_vl, TRAIT(add_varargs, vl)>{});
  147. CT_ASSERT(std::is_same<va_vr, TRAIT(add_varargs, vr)>{});
  148. CT_ASSERT(std::is_same<va_cv, TRAIT(add_varargs, cv)>{});
  149. CT_ASSERT(std::is_same<va_cvl, TRAIT(add_varargs, cvl)>{});
  150. CT_ASSERT(std::is_same<va_cvr, TRAIT(add_varargs, cvr)>{});
  151. CT_ASSERT(std::is_same<va_f, TRAIT(add_varargs, va_f)>{});
  152. CT_ASSERT(std::is_same<va_l, TRAIT(add_varargs, va_l)>{});
  153. CT_ASSERT(std::is_same<va_r, TRAIT(add_varargs, va_r)>{});
  154. CT_ASSERT(std::is_same<va_c, TRAIT(add_varargs, va_c)>{});
  155. CT_ASSERT(std::is_same<va_cl, TRAIT(add_varargs, va_cl)>{});
  156. CT_ASSERT(std::is_same<va_cr, TRAIT(add_varargs, va_cr)>{});
  157. CT_ASSERT(std::is_same<va_v, TRAIT(add_varargs, va_v)>{});
  158. CT_ASSERT(std::is_same<va_vl, TRAIT(add_varargs, va_vl)>{});
  159. CT_ASSERT(std::is_same<va_vr, TRAIT(add_varargs, va_vr)>{});
  160. CT_ASSERT(std::is_same<va_cv, TRAIT(add_varargs, va_cv)>{});
  161. CT_ASSERT(std::is_same<va_cvl, TRAIT(add_varargs, va_cvl)>{});
  162. CT_ASSERT(std::is_same<va_cvr, TRAIT(add_varargs, va_cvr)>{});
  163. }
  164. #endif //#ifndef BOOST_CLBL_TRTS_DISABLE_ABOMINABLE_FUNCTIONS
  165. {
  166. using f = void(&)();
  167. using va_f = void(&)(...);
  168. CT_ASSERT(std::is_same<va_f, TRAIT(add_varargs, f)>{});
  169. }
  170. }