================
@@ -7939,7 +7927,14 @@ ExprResult Sema::ActOnStartCXXMemberReference(Scope *S, 
Expr *Base,
           }
         }
         return ExprError();
+      } else if (Result.isUnset()) {
+        // BuildOverloadedArrowExpr returns an empty expression to indicate
+        // that we need to build a dependent overloaded arrow expression.
----------------
sdkrystian wrote:

> I have 2 concerns with that 
> 1/ It's a bit too clever of an interface

Although I agree it's an imperfect interface, this is more of a "transitional" 
fix. Ideally we will build the full AST for calls to members of the current 
instantiation in the future. For now, the usage of `ExprEmpty` in this patch 
isn't unfounded so I think it's "good enough". Alternatively I can add a `bool& 
IsDependent` out parameter to implement this functionality. 

> 2/ We should make sure this can only happens in Sema, right? I wonder if we 
> need an ActOnOverloadedArrowExpr to wrap that logic such that (it would 
> duplicate the lookup code but i think that's a better outcome)

I'm not entirely sure what this means. Are you saying that we should expect the 
result to _not_ be `ExprEmpty` during instantiation?

https://github.com/llvm/llvm-project/pull/104458
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to