flx marked 6 inline comments as done.
flx added inline comments.

================
Comment at: clang-tools-extra/clang-tidy/utils/Matchers.h:52
 
 AST_MATCHER_P(NamedDecl, matchesAnyListedName, std::vector<std::string>,
               NameList) {
----------------
hokein wrote:
> worth some comments on this.
Done in its new location.


================
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());
----------------
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.


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