Merged in r295375. Thanks, Hans
On Wed, Feb 15, 2017 at 12:14 PM, Richard Smith <rich...@metafoo.co.uk> wrote: > Hans, this would be a good candidate for Clang 4. The bug in question is not > a regression, but it is an accepts-invalid / wrong-code bug. > > On 15 February 2017 at 11:57, Richard Smith via cfe-commits > <cfe-commits@lists.llvm.org> wrote: >> >> Author: rsmith >> Date: Wed Feb 15 13:57:10 2017 >> New Revision: 295224 >> >> URL: http://llvm.org/viewvc/llvm-project?rev=295224&view=rev >> Log: >> PR24440: Do not silently discard a fold-expression appearing as the >> operand of a cast-expression. >> >> Modified: >> cfe/trunk/lib/Parse/ParseExpr.cpp >> cfe/trunk/lib/Sema/SemaTemplateVariadic.cpp >> cfe/trunk/test/Parser/cxx1z-fold-expressions.cpp >> >> Modified: cfe/trunk/lib/Parse/ParseExpr.cpp >> URL: >> http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Parse/ParseExpr.cpp?rev=295224&r1=295223&r2=295224&view=diff >> >> ============================================================================== >> --- cfe/trunk/lib/Parse/ParseExpr.cpp (original) >> +++ cfe/trunk/lib/Parse/ParseExpr.cpp Wed Feb 15 13:57:10 2017 >> @@ -2409,7 +2409,7 @@ Parser::ParseParenExpression(ParenParseO >> // fold-expressions, we'll need to allow multiple ArgExprs here. >> if (ArgExprs.size() == 1 && isFoldOperator(Tok.getKind()) && >> NextToken().is(tok::ellipsis)) >> - return ParseFoldExpression(Result, T); >> + return ParseFoldExpression(ArgExprs[0], T); >> >> ExprType = SimpleExpr; >> Result = Actions.ActOnParenListExpr(OpenLoc, Tok.getLocation(), >> >> Modified: cfe/trunk/lib/Sema/SemaTemplateVariadic.cpp >> URL: >> http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaTemplateVariadic.cpp?rev=295224&r1=295223&r2=295224&view=diff >> >> ============================================================================== >> --- cfe/trunk/lib/Sema/SemaTemplateVariadic.cpp (original) >> +++ cfe/trunk/lib/Sema/SemaTemplateVariadic.cpp Wed Feb 15 13:57:10 2017 >> @@ -1015,6 +1015,11 @@ ExprResult Sema::ActOnCXXFoldExpr(Source >> CheckFoldOperand(*this, LHS); >> CheckFoldOperand(*this, RHS); >> >> + auto DiscardOperands = [&] { >> + CorrectDelayedTyposInExpr(LHS); >> + CorrectDelayedTyposInExpr(RHS); >> + }; >> + >> // [expr.prim.fold]p3: >> // In a binary fold, op1 and op2 shall be the same fold-operator, and >> // either e1 shall contain an unexpanded parameter pack or e2 shall >> contain >> @@ -1022,6 +1027,7 @@ ExprResult Sema::ActOnCXXFoldExpr(Source >> if (LHS && RHS && >> LHS->containsUnexpandedParameterPack() == >> RHS->containsUnexpandedParameterPack()) { >> + DiscardOperands(); >> return Diag(EllipsisLoc, >> LHS->containsUnexpandedParameterPack() >> ? diag::err_fold_expression_packs_both_sides >> @@ -1035,6 +1041,7 @@ ExprResult Sema::ActOnCXXFoldExpr(Source >> if (!LHS || !RHS) { >> Expr *Pack = LHS ? LHS : RHS; >> assert(Pack && "fold expression with neither LHS nor RHS"); >> + DiscardOperands(); >> if (!Pack->containsUnexpandedParameterPack()) >> return Diag(EllipsisLoc, >> diag::err_pack_expansion_without_parameter_packs) >> << Pack->getSourceRange(); >> >> Modified: cfe/trunk/test/Parser/cxx1z-fold-expressions.cpp >> URL: >> http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Parser/cxx1z-fold-expressions.cpp?rev=295224&r1=295223&r2=295224&view=diff >> >> ============================================================================== >> --- cfe/trunk/test/Parser/cxx1z-fold-expressions.cpp (original) >> +++ cfe/trunk/test/Parser/cxx1z-fold-expressions.cpp Wed Feb 15 13:57:10 >> 2017 >> @@ -34,3 +34,12 @@ template<int ...N> int bad9() { return ( >> template<int ...N> int bad10() { return (3 ? ... : N); } // >> expected-error +{{}} expected-note {{to match}} >> template<int ...N> int bad11() { return (N + ... 0); } // expected-error >> {{expected a foldable binary operator}} expected-error {{expected >> expression}} >> template<int ...N> int bad12() { return (... N); } // expected-error >> {{expected expression}} >> + >> +template<typename ...T> void as_operand_of_cast(int a, T ...t) { >> + return >> + (int)(a + ... + undeclared_junk) + // expected-error {{undeclared}} >> expected-error {{does not contain any unexpanded}} >> + (int)(t + ... + undeclared_junk) + // expected-error {{undeclared}} >> + (int)(... + undeclared_junk) + // expected-error {{undeclared}} >> expected-error {{does not contain any unexpanded}} >> + (int)(undeclared_junk + ...) + // expected-error {{undeclared}} >> + (int)(a + ...); // expected-error {{does not contain any unexpanded}} >> +} >> >> >> _______________________________________________ >> cfe-commits mailing list >> cfe-commits@lists.llvm.org >> http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits > > _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits