// RUN: %clang_cc1 -fsyntax-only -verify %s -std=c++98
// RUN: %clang_cc1 -fsyntax-only -verify %s -std=c++11
typedef __SIZE_TYPE__ size_t;
#if __cplusplus >= 201103L
struct S1 {
void *operator new(size_t n) {
return nullptr; // expected-warning {{'operator new' should not return a null pointer unless it is declared 'throw()' or 'noexcept'}}
}
void *operator new[](size_t n) noexcept {
return __null;
}
};
#endif
struct S2 {
static size_t x;
void *operator new(size_t n) throw() {
return 0;
}
void *operator new[](size_t n) {
return (void*)0;
#if __cplusplus >= 201103L
// expected-warning@-2 {{'operator new[]' should not return a null pointer unless it is declared 'throw()' or 'noexcept'}}
#else
// expected-warning-re@-4 {{'operator new[]' should not return a null pointer unless it is declared 'throw()'{{$}}}}
#endif
}
};
struct S3 {
void *operator new(size_t n) {
return 1-1;
#if __cplusplus >= 201103L
// expected-error@-2 {{cannot initialize return object of type 'void *' with an rvalue of type 'int'}}
#else
// expected-warning@-4 {{expression which evaluates to zero treated as a null pointer constant of type 'void *'}}
// expected-warning@-5 {{'operator new' should not return a null pointer unless it is declared 'throw()'}}
#endif
}
void *operator new[](size_t n) {
return (void*)(1-1); // expected-warning {{'operator new[]' should not return a null pointer unless it is declared 'throw()'}}
}
};
#if __cplusplus >= 201103L
template<bool B> struct S4 {
void *operator new(size_t n) noexcept(B) {
return 0; // expected-warning {{'operator new' should not return a null pointer}}
}
};
template struct S4<true>;
template struct S4<false>; // expected-note {{in instantiation of}}
#endif
template<typename ...T> struct S5 { // expected-warning 0-1{{extension}}
void *operator new(size_t n) throw(T...) {
return 0; // expected-warning {{'operator new' should not return a null pointer}}
}
};
template struct S5<>;
template struct S5<int>; // expected-note {{in instantiation of}}