JonasToth added a comment. I agree with @Eugene.Zelenko that this check should rather live in `bugprone-` as the issue its diagnosing is not LLVM specific. It is ok to add an alias into the llvm module.
================ Comment at: clang-tidy/llvm/ProblematicStaticsCheck.cpp:22 +void ProblematicStaticsCheck::registerMatchers(MatchFinder *Finder) { + auto Matcher = returnStmt(hasReturnValue(ignoringImplicit(unaryOperator( + hasOperatorName("&"), ---------------- Nit: you can inline this variable, having it does not improve readability (IMHO) nor does it reduce duplication. ================ Comment at: clang-tidy/llvm/ProblematicStaticsCheck.cpp:26 + varDecl(isStaticLocal()).bind("var"))))))), + isExpansionInFileMatching("/include/.*\\.h")) + .bind("return"); ---------------- I think the matching on `include` should not be done. Maybe it's ok to filter for header files, but we should not assume they live in `include/...` (as i think this check is generally useful and not too LLVM specific). More filters for false positives could be checking if the function itself is `static` or in an anonymous namespace. ================ Comment at: clang-tidy/llvm/ProblematicStaticsCheck.cpp:33 + const auto *VD = Result.Nodes.getNodeAs<VarDecl>("var"); + const auto *Return = Result.Nodes.getNodeAs<ReturnStmt>("return"); + diag(Return->getBeginLoc(), "address of static local variable %0 may not " ---------------- Please `assert` on `VD` and `Return` ================ Comment at: test/clang-tidy/llvm-problematic-statics.cpp:3 + +#include "include/ProblematicStatics.h" +// CHECK-MESSAGES: ProblematicStatics.h:7:5: warning: address of static local variable 'index' may not be identical across library boundaries [llvm-problematic-statics] ---------------- I think the testing should include more cases. At least normal functions, and a false case as well. Repository: rCTE Clang Tools Extra https://reviews.llvm.org/D54222 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits