ChuanqiXu added a comment.

In D126907#3588708 <https://reviews.llvm.org/D126907#3588708>, @erichkeane 
wrote:

> In D126907#3588417 <https://reviews.llvm.org/D126907#3588417>, @ChuanqiXu 
> wrote:
>
>> From what I can see, the crash reason would be the mismatch depth and the 
>> setting of MultiLevelTemplateArgumentList. In 
>> `::CheckConstraintSatisfaction`, the depth of `RawCompletionToken ` is 0, 
>> while the depth of corresponding MultiLevelTemplateArgumentList is 2. So the 
>> compiler would get the outermost template argument incorrectly (which is a 
>> template pack in the example) in TransformTemplateTypeParmType.
>>
>> The first though was that we should set the depth of `RawCompletionToken ` 
>> to 1 correctly. But I felt this might not be good later since in the normal 
>> process of template instantiation (without concepts and constraints), the 
>> depth of `RawCompletionToken ` is 0 indeed. What is different that time is 
>> the depth of corresponding `MultiLevelTemplateArgumentList ` is 1. So it 
>> looks like the process is constructed on the fly. It makes sense for the 
>> perspective of compilation speed.
>>
>> So I feel like what we should do here is in 
>> `Sema::CheckInstantiatedFunctionTemplateConstraints`, when we are computing 
>> the desired MultiLevelTemplateArgumentList, we should compute a result with 
>> depth of 1 in the particular case.
>>
>> ---
>>
>> Another idea is to not do instantiation when we're checking constraints. But 
>> I need to think more about this.
>
> I don't know of the 'another idea'?  We have to do instantiation before 
> checking, and if we do it too early, we aren't doing the deferred 
> instantiation.  And the problem is that the RawCompletionToken uses a concept 
> to refer to 'itself'.  However, this version of 'itself' isn't valid, since 
> the 'depth' is wrong once it tries to instantiate relative to the 'top 
> level'.  However, this IS happening during instantiation?
>
> My latest thought is that perhaps the "IsEvaluatingAConstraint" should NOT 
> happen at the Sema level (but at the instantiator level), since it ends up 
> catching things it shouldn't?  I tried it and have a handful of failures of 
> trying to check uninstantiated constraints, but I've not dug completely into 
> it.

Yeah, we have to do instantiation before checking. My point is that it looks 
like we're doing **another** instantiation when we check the concepts. And my 
point is that if it we should avoid the second instantiation.


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

https://reviews.llvm.org/D126907

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

Reply via email to