https://github.com/GS-GOAT updated https://github.com/llvm/llvm-project/pull/127211
>From e815f24bf50a96b0b919c0d7a07a1ce1c7fcb606 Mon Sep 17 00:00:00 2001 From: GS-GOAT <86884129+gs-g...@users.noreply.github.com> Date: Sat, 15 Feb 2025 11:11:43 +0530 Subject: [PATCH] Fixing the logic issue in TransformTypos::TransformDesignatedInitExpr llvm#126113 -Transforming Indices: For array designators, transform the index expression and update ExprChanged if it's modified. -Correct Initializer Check: Compare the transformed initializer against the original to accurately track changes. -Single Initializer Transformation: The initializer is processed once, not per designator, as each DesignatedInitExpr has one initializer. Fixes llvm#126113 --- clang/lib/Sema/TreeTransform.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/clang/lib/Sema/TreeTransform.h b/clang/lib/Sema/TreeTransform.h index fc1e3f7d58f4d..73e979927b4f3 100644 --- a/clang/lib/Sema/TreeTransform.h +++ b/clang/lib/Sema/TreeTransform.h @@ -13672,7 +13672,7 @@ TreeTransform<Derived>::TransformDesignatedInitExpr(DesignatedInitExpr *E) { Desig.AddDesignator( Designator::CreateArrayDesignator(Index.get(), D.getLBracketLoc())); - ExprChanged = ExprChanged || Init.get() != E->getArrayIndex(D); + ExprChanged = ExprChanged || Index.get() != E->getArrayIndex(D); ArrayExprs.push_back(Index.get()); continue; } _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits