ymandel added inline comments.

================
Comment at: clang-tools-extra/clang-tidy/utils/Matchers.h:60
+                     return RegexAndScope{
+                         .Regex = llvm::Regex(Name),
+                         .MatchQualifiedName = Name.contains("::"),
----------------
I don't think that the clang style-guide accepts designated initializers yet.


================
Comment at: clang-tools-extra/clang-tidy/utils/Matchers.h:79
+    llvm::Regex Regex;
+    bool MatchQualifiedName = false;
+  };
----------------
Worth a comment i think.


================
Comment at: clang-tools-extra/clang-tidy/utils/Matchers.h:86
+// Returns a matcher that matches NamedDecls against a list of provided regular
+// expressions. If a regular expression contains '::' the NamedDecls qualified
+// name will be used for matching, otherwise its name will be used.
----------------
nit: s/NamedDecls/`NamedDecl`'s/


================
Comment at: clang-tools-extra/clang-tidy/utils/Matchers.h:55
   return llvm::any_of(NameList, [&Node](const std::string &Name) {
-      return llvm::Regex(Name).match(Node.getName());
-    });
+    if (Name.find("::") != std::string::npos) {
+      return llvm::Regex(Name).match(Node.getQualifiedNameAsString());
----------------
flx wrote:
> hokein wrote:
> > hokein wrote:
> > > If we pass the name as a `llvm::StringRef`, we can use `if 
> > > (Name.contains("::"))` which seems a bit clearer to me.
> > there is a tricky case where the `::` is a prefix of the Name, e.g.  a 
> > global symbol x, the Name is `::x`, and `getQualifiedNameAsString` of 
> > symbol x is `x` (without the `::` prefix), then the matcher will not find a 
> > match, but we expect this is a match right?
> > 
> I agree that's a tricky case.
> 
> We could prepend "::" to getQualifiedNameAsString() and always match against 
> it. Would this work?
> 
> Or we could do this only for regex names that have a leading "::".  This 
> would avoid extra string operations, and users could still match using 
> "^foo::Bar$" to match ::foo::Bar.
>Or we could do this only for regex names that have a leading "::". This would 
>avoid extra string operations, and users could still match using "^foo::Bar$" 
>to match ::foo::Bar.

This should work most of the time. There could still be mistakes, like if a 
user spells the "::" in some odd way, like "[:][:]", but that seems quite 
unlikely in practice.





Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D98738

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

Reply via email to