From: Sebastian Redl Date: Tue, 15 Mar 2011 20:41:09 +0000 (+0000) Subject: More robust check for the special C++0x operator new workaround. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=d8f2e8ed63072ec5a1a8329aa772ae940f1dc3bc;p=clang More robust check for the special C++0x operator new workaround. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@127692 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/SemaExceptionSpec.cpp b/lib/Sema/SemaExceptionSpec.cpp index 1d21b9760c..490934c4b0 100644 --- a/lib/Sema/SemaExceptionSpec.cpp +++ b/lib/Sema/SemaExceptionSpec.cpp @@ -396,14 +396,14 @@ bool Sema::CheckEquivalentExceptionSpec(const PartialDiagnostic &DiagID, if (Name && Name->getName() == "bad_alloc") { // It's called bad_alloc, but is it in std? DeclContext* DC = ExRecord->getDeclContext(); - while (DC && !isa(DC)) - DC = DC->getParent(); - if (DC) { - NamespaceDecl* NS = cast(DC); + DC = DC->getEnclosingNamespaceContext(); + if (NamespaceDecl* NS = dyn_cast(DC)) { IdentifierInfo* NSName = NS->getIdentifier(); + DC = DC->getParent(); if (NSName && NSName->getName() == "std" && - isa(NS->getParent())) + DC->getEnclosingNamespaceContext()->isTranslationUnit()) { return false; + } } } } diff --git a/test/CXX/except/except.spec/p3.cpp b/test/CXX/except/except.spec/p3.cpp index 10e027b719..09b1a4e102 100644 --- a/test/CXX/except/except.spec/p3.cpp +++ b/test/CXX/except/except.spec/p3.cpp @@ -97,9 +97,9 @@ extern void (*r21)() noexcept(true); // expected-error {{does not match}} // As a very special workaround, we allow operator new to match no spec // with a throw(bad_alloc) spec, because C++0x makes an incompatible change // here. -namespace std { class bad_alloc {}; } +extern "C++" { namespace std { class bad_alloc {}; } } void* operator new(unsigned long) throw(std::bad_alloc); void* operator new(unsigned long); -void* operator new[](unsigned long) throw(std::bad_alloc); void* operator new[](unsigned long); +void* operator new[](unsigned long) throw(std::bad_alloc);