From: Sean Hunt Date: Tue, 31 May 2011 19:54:49 +0000 (+0000) Subject: Ensure we enter an unevaluated context when instantiating a noexcept X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=eea06c609b73afc7bcfdf3e101efb8d9e7b3560c;p=clang Ensure we enter an unevaluated context when instantiating a noexcept expression. Fixes bug raised by hhinnant to cfe-dev git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@132350 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/TreeTransform.h b/lib/Sema/TreeTransform.h index 1473ae5ac2..9186767c03 100644 --- a/lib/Sema/TreeTransform.h +++ b/lib/Sema/TreeTransform.h @@ -7516,6 +7516,7 @@ TreeTransform::TransformUnresolvedMemberExpr(UnresolvedMemberExpr *Old) template ExprResult TreeTransform::TransformCXXNoexceptExpr(CXXNoexceptExpr *E) { + EnterExpressionEvaluationContext Unevaluated(SemaRef, Sema::Unevaluated); ExprResult SubExpr = getDerived().TransformExpr(E->getOperand()); if (SubExpr.isInvalid()) return ExprError(); diff --git a/test/SemaCXX/dependent-noexcept-unevaluated.cpp b/test/SemaCXX/dependent-noexcept-unevaluated.cpp new file mode 100644 index 0000000000..5bf6f9e96a --- /dev/null +++ b/test/SemaCXX/dependent-noexcept-unevaluated.cpp @@ -0,0 +1,41 @@ +// RUN: %clang_cc1 -fsyntax-only -std=c++0x %s + +template +T&& +declval() noexcept; + +template +struct some_trait +{ + static const bool value = false; +}; + +template +void swap(T& x, T& y) noexcept(some_trait::value) +{ + T tmp(static_cast(x)); + x = static_cast(y); + y = static_cast(tmp); +} + +template +struct array +{ + T data[N]; + + void swap(array& a) noexcept(noexcept(swap(declval(), declval()))); +}; + +struct DefaultOnly +{ + DefaultOnly() = default; + DefaultOnly(const DefaultOnly&) = delete; + DefaultOnly& operator=(const DefaultOnly&) = delete; + ~DefaultOnly() = default; +}; + +int main() +{ + array a, b; +} +