avogelsgesang added inline comments.

================
Comment at: clang/include/clang/Format/Format.h:3691
+  ///  COULD lead to incorrect code formatting due to incorrect decisions made
+  ///  due to clang-formats lack of complete semantic information. As such 
extra
+  ///  care should be taken to review code changes made by the use of this
----------------
curdeius wrote:
> Nit.
Good catch!

I just copied that phrase from `QualifierAlignment` and overlooked that I also 
copied the typo. Fixed the typo in both locations.


================
Comment at: clang/lib/Format/TemplateArgumentKeywordFixer.cpp:55
+    // For `auto` language version, be conservative and assume we are < C++17
+    KeepTemplateTemplateKW = (Style.Standard == FormatStyle::LS_Auto) ||
+                             (Style.Standard < FormatStyle::LS_Cpp17);
----------------
curdeius wrote:
> Isn't it a better name?
This flag is actually about the usage of the `class` keyword instead of the 
`typename` keyword for template-template arguments.
`true` means: "Keep using the `class` instead of the `typename` keyword for 
template-template arguments."

I think the name `KeepTemplateTypenameKW` is wrong. "[...]TypenameKW = true" 
would mean "use `typename` instead of `class`" to me, and that's exactly the 
opposite way around.

As such, I think `KeepTemplateTemplateKW` is in fact the better name. If we 
want to make it even more explicit, we could also use 
`KeepTemplateTemplateClassKW`. What do you think?


================
Comment at: clang/lib/Format/TemplateArgumentKeywordFixer.cpp:65
+  }
+
+  for (size_t I = 0, E = AnnotatedLines.size(); I != E; ++I) {
----------------
curdeius wrote:
> Could we check `KeepTemplateTypenameKW` and early return here?
> The optimizer might do some job, but I doubt it will get rid of the 
> unnecessary finding of template keyword etc.
> We could maybe avoid this variable altogether and return inside the switch, 
> no?
I think you misunderstood the semantics of `KeepTemplateTypenameKW`? Or did I 
misunderstand your comment?

For both `KeepTemplateTemplateKW = true` and `KeepTemplateTemplateKW = false`, 
the loop below still reformats `class` to `typename`.

E.g., for the input
```
template<template<class> class X>
```
and `KeepTemplateTemplateKW = true`, we produce
```
template<template<typename> class X>
```
For the same input with `KeepTemplateTemplateKW = false`, we produce
```
template<template<typename> typename X>
```


================
Comment at: clang/lib/Format/TemplateArgumentKeywordFixer.cpp:69
+
+    // Find the first `template` keyword on this line
+    while (Tok && Tok->isNot(tok::kw_template))
----------------
curdeius wrote:
> Please finish comments with full stops, here and below.
Fixed here and all other places I could find in my change


================
Comment at: clang/lib/Format/TemplateArgumentKeywordFixer.h:36
+} // end namespace format
+} // end namespace clang
+
----------------
curdeius wrote:
> Please make the comments consistent with other files.
Consistent with which other files?
My comments here are consistent with `NamespaceEndCommentsFixer.h` and 
`QualifierAlignmentFixer.h` which I used for reference while writing this change


================
Comment at: clang/unittests/Format/TemplateArgumentKeywordFixerTest.cpp:155
+  // We also format template argument lists for `using`.
+  // There are no special semantics re. deduction guides and the normal
+  // implementation just works. But better test it before this breaks due to
----------------
curdeius wrote:
> Don't repeat comments, please. It's the same as below in deduction guides 
> test.
removed comment in both test cases. Reading it again, I agree that the comment 
didn't provide much value in the first place


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D116290

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

Reply via email to