erichkeane added inline comments.

================
Comment at: clang/include/clang/AST/ExprConcepts.h:103
 
+  bool hasSubstitutionFailureInArgs() const {
+    return ArgsHasSubstitutionFailure;
----------------
usaxena95 wrote:
> erichkeane wrote:
> > Does this really belong here instead of as a part of the 
> > ConceptSpecializationDecl?
> I am not aware of the original goals for this. For example, 
> `ASTTemplateArgumentListInfo` is part of `ConceptReference` while 
> `TemplateArgument` is part of `ImplicitConceptSpecializationDecl`. Both of 
> them are invalid in such a case.
> I am open to suggestion to where to place this.
Yeah, the design of all of these is a little wonky unfortunately.  The 
ConceptReference is so it can be a base of a TypeConstraint as well, so 
anything that also needs to be in type-constraint belongs there.

ConceptSpecializationDecl is a recent split off ConstraintSpecializationExpr 
whose intent is to be something that later instantiation (like instantiating a 
lambda defined in a concept decl) can use to make sure we get template 
arguments correct.  So I suspect the args failure needs to be contained in that 
as well.

IF this is something that can also be invalid in a TypeConstraint, it belongs 
in ConceptReference AND ConceptSpecializationDecl separately I believe (as 
we'll likely need to check that's validity later).


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D137712

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

Reply via email to