erichkeane added inline comments.

================
Comment at: clang/lib/AST/ExprCXX.cpp:1214-1216
+  return (C->capturesVariable() && isa<VarDecl>(C->getCapturedVar()) &&
+          cast<VarDecl>(C->getCapturedVar())->isInitCapture() &&
           (getCallOperator() == C->getCapturedVar()->getDeclContext()));
----------------
aaron.ballman wrote:
> I think early returns help make this a bit more clear.
I might suggest making that:

```
if (const auto *VD = dyn_cast<VarDecl(C->getCapturedVar())
   return VD->...
return false;
```

But otherwise agree with the suggestion.


================
Comment at: clang/lib/Analysis/AnalysisDeclContext.cpp:173
+    ValueDecl *VD = LC.getCapturedVar();
+    if (isSelfDecl(dyn_cast<VarDecl>(VD)))
       return dyn_cast<ImplicitParamDecl>(VD);
----------------
aaron.ballman wrote:
> This looks dangerous -- `isSelfDecl()` uses the pointer variable in ways that 
> would be Bad News for null pointers.
Yep, `isSelfDecl` seems to do:

`return isa<ImplicitParamDecl>(VD) && VD->getName() == "self";`

`isa` isn't nullptr safe, we have `isa_and_nonnull` for that (if we want to 
update `isSelfDecl`).


================
Comment at: clang/lib/Sema/SemaDecl.cpp:14594-14596
+      ValueDecl *VD = C.getCapturedVar();
+      if (VarDecl *Var = dyn_cast<VarDecl>(VD)) {
+        if (Var->isInitCapture())
----------------



Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D122768/new/

https://reviews.llvm.org/D122768

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to