curdeius added a comment.

Thanks for addressing the comments quickly. I'll have one more thorough look in 
the coming days.



================
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);
----------------
avogelsgesang wrote:
> 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?
I did understand it correctly that it is about class keyword in template 
template parameters, but my brain somehow melted down the road:). You can keep 
the name as is.


================
Comment at: clang/lib/Format/TemplateArgumentKeywordFixer.cpp:65
+  }
+
+  for (size_t I = 0, E = AnnotatedLines.size(); I != E; ++I) {
----------------
avogelsgesang wrote:
> 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>
> ```
As above, forget my previous comment.


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