// RUN: %clang_cc1 -fsyntax-only -verify %s
// RUN: %clang_cc1 -fsyntax-only -verify -std=c++98 %s
// RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s
namespace A { // expected-note 2 {{previous definition is here}}
int A;
void f() { A = 0; }
}
void f() { A = 0; } // expected-error {{unexpected namespace name 'A': expected expression}}
int A; // expected-error {{redefinition of 'A' as different kind of symbol}}
class A; // expected-error {{redefinition of 'A' as different kind of symbol}}
class B {}; // expected-note {{previous definition is here}}
// expected-note@-1 {{candidate function (the implicit copy assignment operator) not viable}}
#if __cplusplus >= 201103L // C++11 or later
// expected-note@-3 {{candidate function (the implicit move assignment operator) not viable}}
#endif
void C(); // expected-note {{previous definition is here}}
namespace C {} // expected-error {{redefinition of 'C' as different kind of symbol}}
namespace D {
class D {};
}
namespace S1 {
int x;
namespace S2 {
namespace S3 {
B x;
}
}
}
namespace S1 {
void f() {
x = 0;
}
namespace S2 {
namespace S3 {
void f() {
x = 0; // expected-error {{no viable overloaded '='}}
}
}
int y;
}
}
namespace S1 {
namespace S2 {
namespace S3 {
void f3() {
y = 0;
}
}
}
}
namespace B {} // expected-error {{redefinition of 'B' as different kind of symbol}}
namespace foo {
enum x {
Y
};
}
static foo::x test1; // ok
static foo::X test2; // typo: expected-error {{no type named 'X' in}}
namespace PR6620 {
namespace numeric {
namespace op {
struct greater {};
}
namespace {
extern op::greater const greater;
}
}
namespace numeric {
namespace {
op::greater const greater = op::greater();
}
template<typename T, typename U>
int f(T& l, U& r)
{ numeric::greater(l, r); }
}
}