hokein created this revision. hokein added a reviewer: kadircet. Herald added a project: All. hokein requested review of this revision. Herald added a project: clang-tools-extra.
Repository: rG LLVM Github Monorepo https://reviews.llvm.org/D145364 Files: clang-tools-extra/include-cleaner/lib/FindHeaders.cpp clang-tools-extra/include-cleaner/test/nocrash.cpp Index: clang-tools-extra/include-cleaner/test/nocrash.cpp =================================================================== --- /dev/null +++ clang-tools-extra/include-cleaner/test/nocrash.cpp @@ -0,0 +1,8 @@ +// RUN: clang-include-cleaner %s -- + +namespace std { +class Foo {}; +bool operator==(Foo, int) { return false; } +} +// no crash on a reference to a non-identifier symbol (operator ==). +bool s = std::operator==(std::Foo(), 1); Index: clang-tools-extra/include-cleaner/lib/FindHeaders.cpp =================================================================== --- clang-tools-extra/include-cleaner/lib/FindHeaders.cpp +++ clang-tools-extra/include-cleaner/lib/FindHeaders.cpp @@ -118,7 +118,7 @@ if (!FD) return {}; - llvm::StringRef FName = FD->getName(); + llvm::StringRef FName = symbolName(S); llvm::SmallVector<tooling::stdlib::Header> Headers; if (FName == "move") { if (FD->getNumParams() == 1)
Index: clang-tools-extra/include-cleaner/test/nocrash.cpp =================================================================== --- /dev/null +++ clang-tools-extra/include-cleaner/test/nocrash.cpp @@ -0,0 +1,8 @@ +// RUN: clang-include-cleaner %s -- + +namespace std { +class Foo {}; +bool operator==(Foo, int) { return false; } +} +// no crash on a reference to a non-identifier symbol (operator ==). +bool s = std::operator==(std::Foo(), 1); Index: clang-tools-extra/include-cleaner/lib/FindHeaders.cpp =================================================================== --- clang-tools-extra/include-cleaner/lib/FindHeaders.cpp +++ clang-tools-extra/include-cleaner/lib/FindHeaders.cpp @@ -118,7 +118,7 @@ if (!FD) return {}; - llvm::StringRef FName = FD->getName(); + llvm::StringRef FName = symbolName(S); llvm::SmallVector<tooling::stdlib::Header> Headers; if (FName == "move") { if (FD->getNumParams() == 1)
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits