steveire added a comment.

Good progress! This check also implements its own `StmtAncestorASTVisitor` 
which should probably be removed in favor of the `ParentMapContext` eventually 
(not in this patch).



================
Comment at: clang-tools-extra/clang-tidy/modernize/LoopConvertCheck.cpp:118
+
+AST_MATCHER(ParmVarDecl, hasDefaultArg) {
+  return Node.getDefaultArg() != nullptr;
----------------
There's already a (deprecated)  `hasDefaultArgument` in `ASTMatchers.h` with 
the same implementation. 

It is deprecated in favor of `hasInitializer`.


================
Comment at: clang-tools-extra/clang-tidy/modernize/LoopConvertCheck.cpp:152
+  struct Predicate {
+    bool operator()(const ast_matchers::internal::BoundNodesMap &Nodes) const {
+      const auto *BeginMember =
----------------
Why not use lambdas?


================
Comment at: clang-tools-extra/clang-tidy/modernize/LoopConvertCheck.cpp:236
 
-  DeclarationMatcher EndDeclMatcher =
-      varDecl(hasInitializer(anything())).bind(EndVarName);
-
-  StatementMatcher EndCallMatcher = cxxMemberCallExpr(
-      argumentCountIs(0), callee(cxxMethodDecl(EndNameMatcher)));
+  StatementMatcher EndCallMatcher =
+      cxxMemberCallExpr(argumentCountIs(0),
----------------
It always makes sense to use `auto` for matchers. Here, you hide an unnecessary 
implicit conversion from `BindableMatcher<Stmt>` to `Matcher<Stmt>`. 

Below you use `auto` for a matcher. Why be inconsistent?


================
Comment at: clang-tools-extra/clang-tidy/modernize/LoopConvertCheck.cpp:859
   const auto *LoopVar = Nodes.getNodeAs<VarDecl>(InitVarName);
-  const auto *EndVar = Nodes.getNodeAs<VarDecl>(EndVarName);
-
-  // If the loop calls end()/size() after each iteration, lower our confidence
-  // level.
-  if (FixerKind != LFK_Array && !EndVar)
-    ConfidenceLevel.lowerTo(Confidence::CL_Reasonable);
+  const VarDecl *EndVar = Nodes.getNodeAs<VarDecl>(EndVarName);
 
----------------
Why change `auto` to `VarDecl` (repeated) here?


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D97955

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

Reply via email to