haberman added inline comments.

================
Comment at: clang/lib/Sema/SemaStmt.cpp:605-609
+  while (!isa<CallExpr>(Ex)) {
+    auto *PE = cast<ParenExpr>(Ex);
+    Ex = IgnoreImplicitAsWritten(PE->getSubExpr());
+    PE->setSubExpr(Ex);
+  }
----------------
rsmith wrote:
> This loop is problematic: it's generally not safe to modify an expression 
> that is used as a subexpression of another expression. (Modifying the 
> `ReturnStmt` is, by contrast, much less problematic because the properties of 
> a statement have less complex dependencies on the properties of its 
> subexpressions.) In particular, if there were any implicit conversions here 
> that changed the type or value category or similar, the enclosing parentheses 
> would have the wrong type / value category / similar. Also there are 
> possibilities here other than `CallExpr` and `ParenExpr`, such as anything 
> else that we consider to be "parentheses" (such as a `GenericSelectionExpr`).
> 
> But I think this loop should never be necessary, because all implicit 
> conversions should always be on the outside of the parentheses. Do you have a 
> testcase that needs it?
I removed it and my test cases still pass. I'm glad to know this isn't 
necessary: I was coding defensively because I didn't know that I could count on 
this invariant:

> all implicit conversions should always be on the outside of the parentheses.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D99517

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

Reply via email to