mangle-lambda-explicit-template-params.cpp 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. // RUN: %clang_cc1 -std=c++2a -triple %itanium_abi_triple -emit-llvm -o - %s -w | FileCheck %s
  2. template<class, int, class>
  3. struct DummyType { };
  4. inline void inline_func() {
  5. // CHECK: UlvE
  6. []{}();
  7. // CHECK: UlTyvE
  8. []<class>{}.operator()<int>();
  9. // CHECK: UlTyT_E
  10. []<class T>(T){}(1);
  11. // CHECK: UlTyTyT_T0_E
  12. []<class T1, class T2>(T1, T2){}(1, 2);
  13. // CHECK: UlTyTyT0_T_E
  14. []<class T1, class T2>(T2, T1){}(2, 1);
  15. // CHECK: UlTniTyTnjT0_E
  16. []<int I, class T, unsigned U>(T){}.operator()<1, int, 2>(3);
  17. // CHECK: UlTyTtTyTniTyETniTyvE
  18. []<class,
  19. template<class, int, class> class,
  20. int,
  21. class>{}.operator()<unsigned, DummyType, 5, int>();
  22. }
  23. void call_inline_func() {
  24. inline_func();
  25. }
  26. template<typename T, int> struct X {};
  27. inline auto pack = []<typename ...T, T ...N>(T (&...)[N]) {};
  28. int arr1[] = {1};
  29. int arr2[] = {1, 2};
  30. // CHECK: @_ZNK4packMUlTpTyTpTnT_DpRAT0__S_E_clIJiiEJLi1ELi2EEEEDaS2_(
  31. void use_pack() { pack(arr1, arr2); }
  32. inline void collision() {
  33. auto a = []<typename T, template<typename U, T> typename>{};
  34. auto b = []<typename T, template<typename U, U> typename>{};
  35. auto c = []<typename T, template<typename U, T> typename>{};
  36. a.operator()<int, X>();
  37. // CHECK: @_ZZ9collisionvENKUlTyTtTyTnT_EvE_clIi1XEEDav
  38. b.operator()<int, X>();
  39. // CHECK: @_ZZ9collisionvENKUlTyTtTyTnTL0__EvE_clIi1XEEDav
  40. c.operator()<int, X>();
  41. // CHECK: @_ZZ9collisionvENKUlTyTtTyTnT_EvE0_clIi1XEEDav
  42. }
  43. void use_collision() { collision(); }
  44. template<typename> void f() {
  45. // CHECK: define linkonce_odr {{.*}} @_ZZ1fIiEvvENKUlT_E_clIiEEDaS0_(
  46. auto x = [](auto){};
  47. x(0);
  48. }
  49. void use_f() { f<int>(); }
  50. template<typename> struct Y {
  51. template<int> struct Z {};
  52. };
  53. template<typename ...T> void expanded() {
  54. auto x = []<T..., template<T> typename...>{};
  55. auto y = []<int, template<int> typename>{};
  56. auto z = []<int, int, template<int> typename, template<int> typename>{};
  57. // FIXME: Should we really require 'template' for y and z?
  58. x.template operator()<(T())..., Y<T>::template Z...>();
  59. y.template operator()<0, Y<int>::Z>();
  60. y.template operator()<1, Y<int>::Z>();
  61. z.template operator()<1, 2, Y<int>::Z, Y<float>::Z>();
  62. }
  63. void use_expanded() {
  64. // CHECK: @_ZZ8expandedIJEEvvENKUlvE_clIJEJEEEDav(
  65. // CHECK: @_ZZ8expandedIJEEvvENKUlTniTtTniEvE_clILi0EN1YIiE1ZEEEDav(
  66. // CHECK: @_ZZ8expandedIJEEvvENKUlTniTtTniEvE_clILi1EN1YIiE1ZEEEDav(
  67. // CHECK: @_ZZ8expandedIJEEvvENKUlTniTniTtTniETtTniEvE_clILi1ELi2EN1YIiE1ZENS2_IfE1ZEEEDav(
  68. expanded<>();
  69. // FIXME: Should we really be using J...E for arguments corresponding to an
  70. // expanded parameter pack?
  71. // Note that the <lambda-sig>s of 'x' and 'y' collide here, after pack expansion.
  72. // CHECK: @_ZZ8expandedIJiEEvvENKUlTniTtTniEvE_clIJLi0EEJN1YIiE1ZEEEEDav(
  73. // CHECK: @_ZZ8expandedIJiEEvvENKUlTniTtTniEvE0_clILi0EN1YIiE1ZEEEDav(
  74. // CHECK: @_ZZ8expandedIJiEEvvENKUlTniTtTniEvE0_clILi1EN1YIiE1ZEEEDav(
  75. // CHECK: @_ZZ8expandedIJiEEvvENKUlTniTniTtTniETtTniEvE_clILi1ELi2EN1YIiE1ZENS2_IfE1ZEEEDav(
  76. expanded<int>();
  77. // Note that the <lambda-sig>s of 'x' and 'z' collide here, after pack expansion.
  78. // CHECK: @_ZZ8expandedIJiiEEvvENKUlTniTniTtTniETtTniEvE_clIJLi0ELi0EEJN1YIiE1ZES4_EEEDav(
  79. // CHECK: @_ZZ8expandedIJiiEEvvENKUlTniTtTniEvE_clILi0EN1YIiE1ZEEEDav(
  80. // CHECK: @_ZZ8expandedIJiiEEvvENKUlTniTtTniEvE_clILi1EN1YIiE1ZEEEDav(
  81. // CHECK: @_ZZ8expandedIJiiEEvvENKUlTniTniTtTniETtTniEvE0_clILi1ELi2EN1YIiE1ZENS2_IfE1ZEEEDav(
  82. expanded<int, int>();
  83. }