summaryrefslogtreecommitdiffstats
path: root/clang-tools-extra/clang-tidy/misc/VirtualNearMissCheck.h
diff options
context:
space:
mode:
authorAlexander Kornienko <alexfh@google.com>2016-01-13 14:16:35 +0000
committerAlexander Kornienko <alexfh@google.com>2016-01-13 14:16:35 +0000
commit98ba0813e6084e699483743f3b58ee3c54c2480c (patch)
treef86725764007d1001562c726f94fec42e5b84f75 /clang-tools-extra/clang-tidy/misc/VirtualNearMissCheck.h
parent73f018e381ca3848da094f6611a73ada2c68467a (diff)
downloadbcm5719-llvm-98ba0813e6084e699483743f3b58ee3c54c2480c.tar.gz
bcm5719-llvm-98ba0813e6084e699483743f3b58ee3c54c2480c.zip
Support virtual-near-miss check.
Summary: Virtual function override near miss detection. Function complete. Test complete. Do not conduct Fix for now. Reviewers: alexfh Subscribers: cfe-commits Patch by Cong Liu! Differential Revision: http://reviews.llvm.org/D15823 llvm-svn: 257599
Diffstat (limited to 'clang-tools-extra/clang-tidy/misc/VirtualNearMissCheck.h')
-rw-r--r--clang-tools-extra/clang-tidy/misc/VirtualNearMissCheck.h65
1 files changed, 65 insertions, 0 deletions
diff --git a/clang-tools-extra/clang-tidy/misc/VirtualNearMissCheck.h b/clang-tools-extra/clang-tidy/misc/VirtualNearMissCheck.h
new file mode 100644
index 00000000000..fda279b573d
--- /dev/null
+++ b/clang-tools-extra/clang-tidy/misc/VirtualNearMissCheck.h
@@ -0,0 +1,65 @@
+//===--- VirtualNearMissCheck.h - clang-tidy---------------------*- C++ -*-===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MISC_VIRTUAL_NEAR_MISS_H
+#define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MISC_VIRTUAL_NEAR_MISS_H
+
+#include "../ClangTidy.h"
+#include <map>
+#include <string>
+
+namespace clang {
+namespace tidy {
+namespace misc {
+
+/// \brief Checks for near miss of virtual methods.
+///
+/// For a method in a derived class, this check looks for virtual method with a
+/// very similar name and an identical signature defined in a base class.
+///
+/// For the user-facing documentation see:
+/// http://clang.llvm.org/extra/clang-tidy/checks/misc-virtual-near-miss.html
+class VirtualNearMissCheck : public ClangTidyCheck {
+public:
+ VirtualNearMissCheck(StringRef Name, ClangTidyContext *Context)
+ : ClangTidyCheck(Name, Context) {}
+ void registerMatchers(ast_matchers::MatchFinder *Finder) override;
+ void check(const ast_matchers::MatchFinder::MatchResult &Result) override;
+
+private:
+ /// Check if the given method is possible to be overridden by some other
+ /// method.
+ ///
+ /// It should look up the PossibleMap or update it.
+ bool isPossibleToBeOverridden(const CXXMethodDecl *BaseMD);
+
+ /// Check if the given base method is overridden by some methods in the given
+ /// derived class.
+ ///
+ /// It should look up the OverriddenMap or update it.
+ bool isOverriddenByDerivedClass(const CXXMethodDecl *BaseMD,
+ const CXXRecordDecl *DerivedRD);
+
+ /// key: the unique ID of a method;
+ /// value: whether the method is possible to be overridden.
+ std::map<std::string, bool> PossibleMap;
+
+ /// key: <unique ID of base method, name of derived class>
+ /// value: whether the base method is overridden by some method in the derived
+ /// class.
+ std::map<std::pair<std::string, std::string>, bool> OverriddenMap;
+
+ const unsigned EditDistanceThreshold = 1;
+};
+
+} // namespace misc
+} // namespace tidy
+} // namespace clang
+
+#endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MISC_VIRTUAL_NEAR_MISS_H
OpenPOWER on IntegriCloud