summaryrefslogtreecommitdiff
path: root/compilerplugins/clang/unreffun.cxx
diff options
context:
space:
mode:
authorStephan Bergmann <sbergman@redhat.com>2018-06-01 16:22:53 +0200
committerStephan Bergmann <sbergman@redhat.com>2018-06-01 20:52:41 +0200
commite1ab04440195092aa0bfbf445e97530082843569 (patch)
tree2f4b8014439fb97b2e37683bf1b260dd9191da2d /compilerplugins/clang/unreffun.cxx
parent29dbb864097cc3136b036fbeb0bfa7d24b1147d7 (diff)
Improve loplugin:unreffun
...to avoid a false positive in --enable-qt5 > [build CXX] vcl/qt5/Qt5Widget.cxx > /home/sbergman/lo/core/vcl/qt5/Qt5Widget.cxx:466:21: error: Unreferenced function declaration [loplugin:unreffun] > friend QWidget* createQt5Widget(Qt5Frame& rFrame, QWidget* parent, Qt::WindowFlags f); > ~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ > 1 error generated. Change-Id: I01e47bc5f5147916737d62fe18ce5312a0221a3f Reviewed-on: https://gerrit.libreoffice.org/55189 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Stephan Bergmann <sbergman@redhat.com>
Diffstat (limited to 'compilerplugins/clang/unreffun.cxx')
-rw-r--r--compilerplugins/clang/unreffun.cxx18
1 files changed, 18 insertions, 0 deletions
diff --git a/compilerplugins/clang/unreffun.cxx b/compilerplugins/clang/unreffun.cxx
index d825423bfeaa..bfd48b328300 100644
--- a/compilerplugins/clang/unreffun.cxx
+++ b/compilerplugins/clang/unreffun.cxx
@@ -58,7 +58,18 @@ public:
void run() override
{ TraverseDecl(compiler.getASTContext().getTranslationUnitDecl()); }
+ bool TraverseFriendDecl(FriendDecl * decl) {
+ auto const old = friendFunction_;
+ friendFunction_ = dyn_cast_or_null<FunctionDecl>(decl->getFriendDecl());
+ auto const ret = RecursiveASTVisitor::TraverseFriendDecl(decl);
+ friendFunction_ = old;
+ return ret;
+ }
+
bool VisitFunctionDecl(FunctionDecl const * decl);
+
+private:
+ FunctionDecl const * friendFunction_ = nullptr;
};
bool UnrefFun::VisitFunctionDecl(FunctionDecl const * decl) {
@@ -74,6 +85,13 @@ bool UnrefFun::VisitFunctionDecl(FunctionDecl const * decl) {
{
return true;
}
+ if (decl == friendFunction_) {
+ if (auto const lex = dyn_cast<CXXRecordDecl>(decl->getLexicalDeclContext())) {
+ if (lex->isDependentContext()) {
+ return true;
+ }
+ }
+ }
if (!(decl->isThisDeclarationADefinition() || isFriendDecl(decl)
|| decl->isFunctionTemplateSpecialization()))