Fznamznon added inline comments.

================
Comment at: clang/lib/Sema/TreeTransform.h:11940-11943
-  ExprResult Callee = getDerived().TransformExpr(E->getCallee());
-  if (Callee.isInvalid())
-    return ExprError();
-
----------------
rsmith wrote:
> Fznamznon wrote:
> > cor3ntin wrote:
> > > I don't understand why we would not need to transform the callee. do we 
> > > do that elsewhere?
> > For example, the code above for call and subscript operators never 
> > transforms the callee.
> > This `TransFormExpr` call  seems to be a no-op for overloaded operator call 
> > case, and the result never ends up in the resulting ast.
> > 
> To me it looks like we need to transform the callee in order to transform the 
> declarations in the `UnresolvedLookupExpr`, if the operator has such 
> functions. For example, in:
> 
> ```
> namespace A {
>   template<typename T> T f(T t) {
>     T operator+(T, T);
>     return t + t;
>   }
> }
> namespace B {
>   struct X {};
> }
> void g(B::X x) { A::f(x); }
> ```
> 
> ... we need to transform the `UnresolvedLookupExpr` for the `t + t` to map 
> from the `operator+` declaration in the `A::f` template to the instantiated 
> `operator+` declaration in `A::f<B::X>`.
> 
> But I think this patch is going in the right direction. We don't *actually* 
> want to transform the callee; all we want to do is to transform the function 
> or list of functions contained in the callee to form an `UnresolvedSet` of 
> candidates found during the template parse. Building and then throwing away a 
> `DeclRefExpr` or `UnresolvedLookupExpr` denoting that function or set of 
> functions is both a waste of time and (as demonstrated by the bug being 
> addressed here) problematic.
> 
> Instead of calling `TransformExpr` on the callee, we should be calling 
> `TransformOverloadExprDecls` if the callee is an `UnresolvedLookupExpr` or 
> `TransformDecl` if it's a `DeclRefExpr`, and I think 
> `RebuildCXXOperatorCallExpr` should be changed to take an `UnresolvedSet` and 
> a `RequiresADL` flag, and it looks like we can then remove the `OrigCallee` 
> parameter, if we pass in some extra source locations.
Thank you for the feedback @rsmith , I appreciate it very much.
I tried the described approach, and it fixes the original bug I was trying to 
resolve as well as makes the mentioned example work correctly whereas my 
original change broke it. Apparently, we don't have test like that in 
check-clang set. I'm going to polish the resulting code a bit and put up to 
review tomorrow.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D151553

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

Reply via email to