From a77cf9d92ad3cf9ce5d552b7b42cec572a460378 Mon Sep 17 00:00:00 2001 From: Vassil Vassilev Date: Thu, 26 Dec 2024 15:56:48 +0000 Subject: [PATCH] Use CloneParmVarDecl instead of manual cloning. NFC Partially addresses #721 --- lib/Differentiator/BaseForwardModeVisitor.cpp | 17 +++-------------- 1 file changed, 3 insertions(+), 14 deletions(-) diff --git a/lib/Differentiator/BaseForwardModeVisitor.cpp b/lib/Differentiator/BaseForwardModeVisitor.cpp index 41b174f5c..3fd8a17d7 100644 --- a/lib/Differentiator/BaseForwardModeVisitor.cpp +++ b/lib/Differentiator/BaseForwardModeVisitor.cpp @@ -178,7 +178,6 @@ DerivativeAndOverload BaseForwardModeVisitor::Derive() { m_Derivative = derivedFD; llvm::SmallVector params; - ParmVarDecl* newPVD = nullptr; const ParmVarDecl* PVD = nullptr; // Function declaration scope @@ -187,17 +186,11 @@ DerivativeAndOverload BaseForwardModeVisitor::Derive() { m_Sema.PushFunctionScope(); m_Sema.PushDeclContext(getCurrentScope(), m_Derivative); - // FIXME: We should implement FunctionDecl and ParamVarDecl cloning. for (size_t i = 0, e = FD->getNumParams(); i < e; ++i) { PVD = FD->getParamDecl(i); - Expr* clonedPVDDefaultArg = 0; - if (PVD->hasDefaultArg()) - clonedPVDDefaultArg = Clone(PVD->getDefaultArg()); - - newPVD = ParmVarDecl::Create(m_Context, m_Sema.CurContext, validLoc, - validLoc, PVD->getIdentifier(), PVD->getType(), - PVD->getTypeSourceInfo(), - PVD->getStorageClass(), clonedPVDDefaultArg); + auto* newPVD = CloneParmVarDecl(PVD, PVD->getIdentifier(), + /*pushOnScopeChains=*/true, + /*cloneDefaultArg=*/false); // Make m_IndependentVar to point to the argument of the newly created // derivedFD. @@ -205,10 +198,6 @@ DerivativeAndOverload BaseForwardModeVisitor::Derive() { m_IndependentVar = newPVD; params.push_back(newPVD); - // Add the args in the scope and id chain so that they could be found. - if (newPVD->getIdentifier()) - m_Sema.PushOnScopeChains(newPVD, getCurrentScope(), - /*AddToContext*/ false); } llvm::ArrayRef paramsRef =