llvm-capstone/clang/test/FixIt/fixit-cxx0x.cpp

62 lines
1.8 KiB
C++
Raw Normal View History

// RUN: %clang_cc1 -verify -std=c++0x %s
// RUN: cp %s %t
// RUN: not %clang_cc1 -x c++ -std=c++0x -Werror -fixit %t
// RUN: %clang_cc1 -Wall -pedantic -x c++ -std=c++0x %t
/* This is a test of the various code modification hints that only
apply in C++0x. */
struct A {
explicit operator int(); // expected-note{{conversion to integral type}}
};
void x() {
switch(A()) { // expected-error{{explicit conversion to}}
}
}
using ::T = void; // expected-error {{name defined in alias declaration must be an identifier}}
using typename U = void; // expected-error {{name defined in alias declaration must be an identifier}}
using typename ::V = void; // expected-error {{name defined in alias declaration must be an identifier}}
namespace Constexpr {
extern constexpr int a; // expected-error {{must be a definition}}
// -> extern const int a;
extern constexpr int *b; // expected-error {{must be a definition}}
// -> extern int *const b;
extern constexpr int &c; // expected-error {{must be a definition}}
// -> extern int &b;
extern constexpr const int d; // expected-error {{must be a definition}}
// -> extern const int d;
int z;
constexpr int a = 0;
constexpr int *b = &z;
constexpr int &c = z;
constexpr int d = a;
// FIXME: Provide FixIts for static data members too.
#if 0
struct S {
static constexpr int a = 0;
static constexpr int b; // xpected-error {{requires an initializer}}
// -> const int b;
};
constexpr int S::a; // xpected-error {{requires an initializer}}
// -> const int S::a;
constexpr int S::b = 0;
#endif
struct S {
static const double d = 0.0; // expected-warning {{accepted as an extension}}
// -> constexpr static const double d = 0.0;
static char *const p = 0; // expected-warning {{accepted as an extension}}
// -> constexpr static char *const p = 0;
};
}