================
@@ -7416,10 +7416,11 @@ NamedDecl *Sema::ActOnVariableDeclarator(
     tryToFixVariablyModifiedVarType(TInfo, R, D.getIdentifierLoc(),
                                     /*DiagID=*/0);
 
-  if (const AutoType *AutoT = R->getAs<AutoType>())
-    CheckConstrainedAuto(
-        AutoT,
-        TInfo->getTypeLoc().getContainedAutoTypeLoc().getConceptNameLoc());
+  if (const AutoType *AutoT = R->getAs<AutoType>()) {
+    AutoTypeLoc Loc = TInfo->getTypeLoc().getContainedAutoTypeLoc();
----------------
mizvekov wrote:

These two lines are analyzing the type in very different ways, so there seems 
to be further bugs here.

`Type::getAs<AutoType>` will simply desugar a type until it finds a node with 
type 'AutoType'.

`getContainedAutoTypeLoc()` will dig through a certain list of type nodes until 
it finds an 'AutoType'.
This list includes non-sugar nodes as well.

Let's assume for now we really want `R->getAs<AutoType>()` in the if condition 
here, which would not find the AutoType in `auto *`. This seems wrong, as these 
can be constrained as well. But we can handle that as a separate issue.

So to hit your bug, you are finding an AutoType through getAs, but not finding 
it through getContainedAutoTypeLoc().

My first suspicion would be that the type contains a sugar node not handled by 
`GetContainedAutoTypeLocVisitor`, in `AST/TypeLoc.cpp`.

Can you check that?

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

Reply via email to