1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173
|
// RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify -Wno-c99-designator %s
// PR5290
int const f0();
void f0_test() {
decltype(0, f0()) i = 0;
i = 0;
}
struct A { int a[1]; A() { } };
typedef A const AC;
int &f1(int*);
float &f2(int const*);
void test_f2() {
float &fr = f2(AC().a);
}
template <class T>
struct Future {
explicit Future(T v);
template <class F>
auto call(F&& fn) -> decltype(fn(T())) {
return fn(T());
}
template <class B, class F>
auto then(F&& fn) -> decltype(call(fn))
{
return fn(T());
}
};
void rdar16527205() {
Future<int> f1(42);
f1.call([](int){ return Future<float>(0); });
}
namespace pr10154 {
class A{
A(decltype(nullptr) param);
};
}
template<typename T> struct S {};
template<typename T> auto f(T t) -> decltype(S<int>(t)) {
using U = decltype(S<int>(t));
using U = S<int>;
return S<int>(t);
}
struct B {
B(decltype(undeclared)); // expected-error {{undeclared identifier}}
};
struct C {
C(decltype(undeclared; // expected-error {{undeclared identifier}} \
// expected-error {{expected ')'}} expected-note {{to match this '('}}
};
namespace PR16529 {
struct U {};
template <typename T> struct S {
static decltype(T{}, U{}) &f();
};
U &r = S<int>::f();
}
namespace PR18876 {
struct A { ~A() = delete; }; // expected-note +{{here}}
A f();
decltype(f()) *a; // ok, function call
decltype(A()) *b; // expected-error {{attempt to use a deleted function}}
decltype(0, f()) *c; // ok, function call on RHS of comma
decltype(0, A()) *d; // expected-error {{attempt to use a deleted function}}
decltype(f(), 0) *e; // expected-error {{attempt to use a deleted function}}
}
namespace D5789 {
struct P1 { char x[6]; } g1 = { "foo" };
struct LP1 { struct P1 p1; };
// expected-warning@+3 {{initializer partially overrides}}
// expected-note@+2 {{previous initialization}}
// expected-note@+1 {{previous definition}}
template<class T> void foo(decltype(T(LP1{ .p1 = g1, .p1.x[1] = 'x' }))) {}
// expected-warning@+3 {{initializer partially overrides}}
// expected-note@+2 {{previous initialization}}
template<class T>
void foo(decltype(T(LP1{ .p1 = g1, .p1.x[1] = 'r' }))) {} // okay
// expected-warning@+3 {{initializer partially overrides}}
// expected-note@+2 {{previous initialization}}
template<class T>
void foo(decltype(T(LP1{ .p1 = { "foo" }, .p1.x[1] = 'x'}))) {} // okay
// expected-warning@+3 {{initializer partially overrides}}
// expected-note@+2 {{previous initialization}}
// expected-error@+1 {{redefinition of 'foo'}}
template<class T> void foo(decltype(T(LP1{ .p1 = g1, .p1.x[1] = 'x' }))) {}
}
namespace GH58674 {
struct Foo {
float value_;
struct nested {
float value_;
};
};
template <typename T>
struct TemplateFoo {
float value_;
};
float bar;
template <typename T>
struct Animal{};
template <typename T>
class Cat : Animal<T> {
using okay = decltype(Foo::value_);
using also_okay = decltype(bar);
using okay2 = decltype(Foo::nested::value_);
using okay3 = decltype(TemplateFoo<T>::value_);
public:
void meow() {
using okay = decltype(Foo::value_);
using also_okay = decltype(bar);
using okay2 = decltype(Foo::nested::value_);
using okay3 = decltype(TemplateFoo<T>::value_);
}
};
void baz() {
Cat<void>{}.meow();
}
}
namespace GH99873 {
struct B {
int x;
};
template<typename T>
struct A {
template<typename U>
constexpr int f() const {
return 1;
}
template<>
constexpr int f<int>() const {
return decltype(B::x)();
}
};
// This shouldn't crash.
static_assert(A<int>().f<int>() == 0, "");
// The result should not be dependent.
static_assert(A<int>().f<int>() != 0, ""); // expected-error {{static assertion failed due to requirement 'GH99873::A<int>().f<int>() != 0'}}
// expected-note@-1 {{expression evaluates to '0 != 0'}}
}
template<typename>
class conditional {
};
// FIXME: The diagnostics here are produced twice.
void foo(conditional<decltype((1),int>) { // expected-note 2 {{to match this '('}} expected-error {{expected ')'}} expected-note 2{{to match this '<'}}
} // expected-error {{expected function body after function declarator}} expected-error 2 {{expected '>'}} expected-error {{expected ')'}}
|