that was present in a prior declaration, emit a warning rather than a
hard error (which we did before, and still do with mismatched
exception specifications). Moreover, provide a fix-it hint with the
throw() clause that should be added, e.g.,
t.C:10:7: warning: 'operator new' is missing exception specification
'throw(std::bad_alloc)'
void *operator new(unsigned long sz)
^
throw(std::bad_alloc)
As part of this, disable the warning when we're missing an exception
specification on operator new, operator new[], operator delete, or
operator delete[] when exceptions are turned off (-fno-exceptions).
Fixes PR5957.
llvm-svn: 99388
29 lines
826 B
C++
29 lines
826 B
C++
// RUN: %clang_cc1 -fsyntax-only -fexceptions -verify %s
|
|
int *use_new(int N) {
|
|
if (N == 1)
|
|
return new int;
|
|
|
|
return new int [N];
|
|
}
|
|
|
|
void use_delete(int* ip, int N) {
|
|
if (N == 1)
|
|
delete ip;
|
|
else
|
|
delete [] ip;
|
|
}
|
|
|
|
namespace std {
|
|
class bad_alloc { };
|
|
|
|
typedef __SIZE_TYPE__ size_t;
|
|
}
|
|
|
|
void* operator new(std::size_t) throw(std::bad_alloc); // expected-note{{previous declaration}}
|
|
void* operator new[](std::size_t) throw(std::bad_alloc);
|
|
void operator delete(void*) throw(); // expected-note{{previous declaration}}
|
|
void operator delete[](void*) throw();
|
|
|
|
void* operator new(std::size_t); // expected-warning{{'operator new' is missing exception specification 'throw(std::bad_alloc)'}}
|
|
void operator delete(void*); // expected-warning{{'operator delete' is missing exception specification 'throw()'}}
|