1 // RUN: %clang_cc1 -fsyntax-only -std=c++11 -verify %s
2 // expected-no-diagnostics
3 
4 // Test default template arguments for function templates.
5 template<typename T = int>
6 void f0();
7 
8 template<typename T>
9 void f0();
10 
g0()11 void g0() {
12   f0(); // okay!
13 }
14 
15 template<typename T, int N = T::value>
16 int &f1(T);
17 
18 float &f1(...);
19 
20 struct HasValue {
21   static const int value = 17;
22 };
23 
g1()24 void g1() {
25   float &fr = f1(15);
26   int &ir = f1(HasValue());
27 }
28 
29 namespace PR16689 {
30   template <typename T1, typename T2> class tuple {
31   public:
32       template <typename = T2>
tuple()33       constexpr tuple() {}
34   };
35   template <class X, class... Y> struct a : public X {
36     using X::X;
37   };
38   auto x = a<tuple<int, int> >();
39 }
40 
41 namespace PR16975 {
42   template <typename...> struct is {
operator boolPR16975::is43     constexpr operator bool() const { return false; }
44   };
45 
46   template <typename... Types>
47   struct bar {
48     template <typename T,
49               bool = is<Types...>()>
50     bar(T);
51   };
52 
53   struct baz : public bar<> {
54     using bar::bar;
55   };
56 
57   baz data{0};
58 }
59 
60 // rdar://23810407
61 // An IRGen failure due to a symbol collision due to a default argument
62 // being instantiated twice.  Credit goes to Richard Smith for this
63 // reduction to a -fsyntax-only failure.
64 namespace rdar23810407 {
65   // Instantiating the default argument multiple times will produce two
66   // different lambda types and thus instantiate this function multiple
67   // times, which will produce conflicting extern variable declarations.
f(T t)68   template<typename T> int f(T t) {
69     extern T rdar23810407_variable;
70     return 0;
71   }
__anon5ce6d9860102null72   template<typename T> int g(int a = f([] {}));
test()73   void test() {
74     g<int>();
75     g<int>();
76   }
77 }
78 
79 // rdar://problem/24480205
80 namespace PR13986 {
81   constexpr unsigned Dynamic = 0;
82   template <unsigned> class A { template <unsigned = Dynamic> void m_fn1(); };
83   class Test {
~Test()84     ~Test() {}
85     A<1> m_target;
86   };
87 }
88