// RUN: %clang_cc1 -fsyntax-only -verify %s -std=c++1y -DCXX1Y -emit-llvm | |
namespace test_factorial { | |
auto Fact = [](auto Self, unsigned n) -> unsigned { | |
return !n ? 1 : Self(Self, n - 1) * n; | |
}; | |
auto six = Fact(Fact, 3); | |
} | |
namespace overload_generic_lambda { | |
template <class F1, class F2> struct overload : F1, F2 { | |
using F1::operator(); | |
using F2::operator(); | |
overload(F1 f1, F2 f2) : F1(f1), F2(f2) { } | |
}; | |
auto NumParams = [](auto Self, auto h, auto ... rest) -> unsigned { | |
return 1 + Self(Self, rest...); | |
}; | |
auto Base = [](auto Self, auto h) -> unsigned { | |
return 1; | |
}; | |
overload<decltype(Base), decltype(NumParams)> O(Base, NumParams); | |
int num_params = O(O, 5, 3, "abc", 3.14, 'a'); | |
} | |
namespace overload_generic_lambda_return_type_deduction { | |
template <class F1, class F2> struct overload : F1, F2 { | |
using F1::operator(); | |
using F2::operator(); | |
overload(F1 f1, F2 f2) : F1(f1), F2(f2) { } | |
}; | |
auto NumParams = [](auto Self, auto h, auto ... rest) { | |
return 1 + Self(Self, rest...); | |
}; | |
auto Base = [](auto Self, auto h) { | |
return 1; | |
}; | |
overload<decltype(Base), decltype(NumParams)> O(Base, NumParams); | |
int num_params = O(O, 5, 3, "abc", 3.14, 'a'); | |
} | |
namespace test_standard_p5 { | |
// FIXME: This test should eventually compile without an explicit trailing return type | |
auto glambda = [](auto a, auto&& b) ->bool { return a < b; }; | |
bool b = glambda(3, 3.14); // OK | |
} | |
namespace test_deduction_failure { | |
int test() { | |
auto g = [](auto *a) { //expected-note{{candidate template ignored}} | |
return a; | |
}; | |
struct X { }; | |
X *x; | |
g(x); | |
g(3); //expected-error{{no matching function}} | |
return 0; | |
} | |
} | |
namespace test_instantiation_or_sfinae_failure { | |
int test2() { | |
{ | |
auto L = [](auto *a) { | |
return (*a)(a); }; //expected-error{{called object type 'double' is not a function}} | |
//l(&l); | |
double d; | |
L(&d); //expected-note{{in instantiation of}} | |
auto M = [](auto b) { return b; }; | |
L(&M); // ok | |
} | |
{ | |
auto L = [](auto *a) ->decltype (a->foo()) { //expected-note2{{candidate template ignored:}} | |
return (*a)(a); }; | |
//l(&l); | |
double d; | |
L(&d); //expected-error{{no matching function for call}} | |
auto M = [](auto b) { return b; }; | |
L(&M); //expected-error{{no matching function for call}} | |
} | |
return 0; | |
} | |
} | |
namespace test_misc { | |
auto GL = [](auto a, decltype(a) b) //expected-note{{candidate function}} | |
-> int { return a + b; }; | |
void test() { | |
struct X { }; | |
GL(3, X{}); //expected-error{{no matching function}} | |
} | |
void test2() { | |
auto l = [](auto *a) -> int { | |
(*a)(a); return 0; }; //expected-error{{called object type 'double' is not a function}} | |
l(&l); | |
double d; | |
l(&d); //expected-note{{in instantiation of}} | |
} | |
} | |
namespace nested_lambdas { | |
int test() { | |
auto L = [](auto a) { | |
return [=](auto b) { //expected-error{{unimplemented}} | |
return a + b; | |
}; | |
}; | |
// auto M = L(3.14); | |
// return M('4'); | |
} | |
auto get_lambda() { | |
return [](auto a) { | |
return a; | |
}; | |
}; | |
int test2() { | |
auto L = get_lambda(); | |
L(3); | |
} | |
} | |