26 lines
1.2 KiB
C++
26 lines
1.2 KiB
C++
|
// RUN: %clang_cc1 -fsyntax-only -verify %s -std=c++1y -DCXX1Y
|
||
|
|
||
|
// prvalue
|
||
|
void prvalue() {
|
||
|
auto&& x = [](auto a)->void { };
|
||
|
auto& y = [](auto *a)->void { }; // expected-error{{cannot bind to a temporary of type}}
|
||
|
}
|
||
|
|
||
|
namespace std {
|
||
|
class type_info;
|
||
|
}
|
||
|
|
||
|
struct P {
|
||
|
virtual ~P();
|
||
|
};
|
||
|
|
||
|
void unevaluated_operand(P &p, int i) { //expected-note{{declared here}}
|
||
|
// FIXME: this should only emit one error.
|
||
|
int i2 = sizeof([](auto a, auto b)->void{}(3, '4')); // expected-error{{lambda expression in an unevaluated operand}} \
|
||
|
// expected-error{{invalid application of 'sizeof'}}
|
||
|
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'}}
|
||
|
const std::type_info &ti2 = typeid([](auto) -> int { return i; }(i)); // expected-error{{lambda expression in an unevaluated operand}}\
|
||
|
// expected-error{{cannot be implicitly captured}}\
|
||
|
// expected-note{{begins here}}
|
||
|
}
|