
Do not spuriously reject constexpr functions that access elements of an array of unknown bound; this may later become valid once the bound is known. Permit array-to-pointer decay on such arrays, but disallow pointer arithmetic (since we do not know whether it will have defined behavior). The standard is not clear on how this should work, but this seems to be a decent answer. Patch by Robert Haberlach! llvm-svn: 301822
26 lines
984 B
C++
26 lines
984 B
C++
// RUN: %clang_cc1 %s -Wno-uninitialized -std=c++1z -fsyntax-only -verify
|
|
|
|
const extern int arr[];
|
|
constexpr auto p = arr; // ok
|
|
constexpr int f(int i) {return p[i];} // expected-note {{read of dereferenced one-past-the-end pointer}}
|
|
|
|
constexpr int arr[] {1, 2, 3};
|
|
constexpr auto p2 = arr + 2; // ok
|
|
constexpr int x = f(2); // ok
|
|
constexpr int y = f(3); // expected-error {{constant expression}}
|
|
// expected-note-re@-1 {{in call to 'f({{.*}})'}}
|
|
|
|
struct A {int m[];} a;
|
|
constexpr auto p3 = a.m; // ok
|
|
constexpr auto p4 = a.m + 1; // expected-error {{constant expression}} expected-note {{constant bound}}
|
|
|
|
void g(int i) {
|
|
int arr[i];
|
|
constexpr auto *p = arr + 2; // expected-error {{constant expression}} expected-note {{constant bound}}
|
|
|
|
// FIXME: Give a better diagnostic here. The issue is that computing
|
|
// sizeof(*arr2) within the array indexing fails due to the VLA.
|
|
int arr2[2][i];
|
|
constexpr int m = ((void)arr2[2], 0); // expected-error {{constant expression}}
|
|
}
|