summaryrefslogtreecommitdiffstats
path: root/clang-tools-extra/clang-tidy/android/CloexecInotifyInitCheck.cpp
diff options
context:
space:
mode:
authorChih-Hung Hsieh <chh@google.com>2017-08-14 17:25:41 +0000
committerChih-Hung Hsieh <chh@google.com>2017-08-14 17:25:41 +0000
commit2e6f9a16f936d3ef754cdb1bd0dd59a8680f374d (patch)
tree386fbcf3b021a529b8ea16ddd5748cdeacf57b80 /clang-tools-extra/clang-tidy/android/CloexecInotifyInitCheck.cpp
parent86021a2345078c13010cb12179a1ac2af7a7d045 (diff)
downloadbcm5719-llvm-2e6f9a16f936d3ef754cdb1bd0dd59a8680f374d.tar.gz
bcm5719-llvm-2e6f9a16f936d3ef754cdb1bd0dd59a8680f374d.zip
[clang-tidy] Add a close-on-exec check on inotify_init() in Android module.
Summary: inotify_init() is better to be replaced by inotify_init1() with IN_CLOEXEC flag to avoid file descriptor leakage. Differential Revision: https://reviews.llvm.org/D35370 llvm-svn: 310861
Diffstat (limited to 'clang-tools-extra/clang-tidy/android/CloexecInotifyInitCheck.cpp')
-rw-r--r--clang-tools-extra/clang-tidy/android/CloexecInotifyInitCheck.cpp34
1 files changed, 34 insertions, 0 deletions
diff --git a/clang-tools-extra/clang-tidy/android/CloexecInotifyInitCheck.cpp b/clang-tools-extra/clang-tidy/android/CloexecInotifyInitCheck.cpp
new file mode 100644
index 00000000000..0d5a56daaf5
--- /dev/null
+++ b/clang-tools-extra/clang-tidy/android/CloexecInotifyInitCheck.cpp
@@ -0,0 +1,34 @@
+//===--- CloexecInotifyInitCheck.cpp - clang-tidy--------------------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#include "CloexecInotifyInitCheck.h"
+#include "clang/AST/ASTContext.h"
+#include "clang/ASTMatchers/ASTMatchFinder.h"
+
+using namespace clang::ast_matchers;
+
+namespace clang {
+namespace tidy {
+namespace android {
+
+void CloexecInotifyInitCheck::registerMatchers(MatchFinder *Finder) {
+ registerMatchersImpl(
+ Finder, functionDecl(returns(isInteger()), hasName("inotify_init")));
+}
+
+void CloexecInotifyInitCheck::check(const MatchFinder::MatchResult &Result) {
+ replaceFunc(Result, /*WarningMsg=*/
+ "prefer inotify_init() to inotify_init1() "
+ "because inotify_init1() allows IN_CLOEXEC",
+ /*FixMsg=*/"inotify_init1(IN_CLOEXEC)");
+}
+
+} // namespace android
+} // namespace tidy
+} // namespace clang
OpenPOWER on IntegriCloud