[clang] [libcxx] [llvm] Reapply "[Clang] Implement resolution for CWG1835 (#92957)" (PR #98547)
Haojian Wu via llvm-commits
llvm-commits at lists.llvm.org
Mon Jul 15 00:37:41 PDT 2024
hokein wrote:
> @pranavk see #98613.
>
> edit: sorry, the error recovery that is currently performed will not detect cases where the template argument list does not contain a a type. i can look into this monday.
Some analysis:
given the example `this->StorageT<I>` where `I` is an `int`, the error recovery mechanism uses `isTemplateArgumentList` [here](https://github.com/llvm/llvm-project/blob/main/clang/lib/Parse/ParseExprCXX.cpp#L563) to check if the current token sequence `< I >` forms a `< template-argument-list >`. However, since `I` is an expression, this becomes an ambiguous caseāit could be interpreted as a less than comparison. Consequently, the error recovery doesn't activate for this case, and a hard error is emitted.
We might be able to tweak or improve the heuristic, but I don't have a good idea for an easy fix.
https://github.com/llvm/llvm-project/pull/98547
More information about the llvm-commits
mailing list