12b391ab7SFaisal Vali // RUN: %clang_cc1 -fsyntax-only -verify %s -std=c++1y -DCXX1Y 22b391ab7SFaisal Vali 32b391ab7SFaisal Vali // prvalue prvalue()42b391ab7SFaisal Valivoid prvalue() { 52b391ab7SFaisal Vali auto&& x = [](auto a)->void { }; 62b391ab7SFaisal Vali auto& y = [](auto *a)->void { }; // expected-error{{cannot bind to a temporary of type}} 72b391ab7SFaisal Vali } 82b391ab7SFaisal Vali 92b391ab7SFaisal Vali namespace std { 102b391ab7SFaisal Vali class type_info; 112b391ab7SFaisal Vali } 122b391ab7SFaisal Vali 132b391ab7SFaisal Vali struct P { 142b391ab7SFaisal Vali virtual ~P(); 152b391ab7SFaisal Vali }; 162b391ab7SFaisal Vali unevaluated_operand(P & p,int i)17a17d19fbSFaisal Valivoid unevaluated_operand(P &p, int i) { //expected-note{{declared here}} 182b391ab7SFaisal Vali // FIXME: this should only emit one error. 192b391ab7SFaisal Vali int i2 = sizeof([](auto a, auto b)->void{}(3, '4')); // expected-error{{lambda expression in an unevaluated operand}} \ 202b391ab7SFaisal Vali // expected-error{{invalid application of 'sizeof'}} 216c93b3e2SAaron Ballman const std::type_info &ti1 = typeid([](auto &a) -> P& { static P p; return p; }(i)); // expected-warning {{expression with side effects will be evaluated despite being used as an operand to 'typeid'}} 22a17d19fbSFaisal Vali const std::type_info &ti2 = typeid([](auto) -> int { return i; }(i)); // expected-error{{lambda expression in an unevaluated operand}}\ 23a17d19fbSFaisal Vali // expected-error{{cannot be implicitly captured}}\ 24*cb559c8dSNathan James // expected-note{{begins here}}\ 25*cb559c8dSNathan James // expected-note 2 {{capture 'i' by}}\ 26*cb559c8dSNathan James // expected-note 2 {{default capture by}} 272b391ab7SFaisal Vali } 28