summaryrefslogtreecommitdiffstats
path: root/clang-tools-extra/test/clang-tidy/android-cloexec-dup.cpp
diff options
context:
space:
mode:
authorChih-Hung Hsieh <chh@google.com>2017-08-14 17:04:16 +0000
committerChih-Hung Hsieh <chh@google.com>2017-08-14 17:04:16 +0000
commit56650e7fc58770fbfecfad746222da47cb208f5e (patch)
tree1f1e316c2060697275b4cd1a14d0a5237b848c5e /clang-tools-extra/test/clang-tidy/android-cloexec-dup.cpp
parent533d4c90bda5aa40a81671bbf8b059e91fb24925 (diff)
downloadbcm5719-llvm-56650e7fc58770fbfecfad746222da47cb208f5e.tar.gz
bcm5719-llvm-56650e7fc58770fbfecfad746222da47cb208f5e.zip
[clang-tidy] Add a close-on-exec check on dup() in Android module.
Summary: dup() is better to be replaced by fcntl() to avoid file descriptor leakage. Differential Revision: https://reviews.llvm.org/D35364 llvm-svn: 310858
Diffstat (limited to 'clang-tools-extra/test/clang-tidy/android-cloexec-dup.cpp')
-rw-r--r--clang-tools-extra/test/clang-tidy/android-cloexec-dup.cpp31
1 files changed, 31 insertions, 0 deletions
diff --git a/clang-tools-extra/test/clang-tidy/android-cloexec-dup.cpp b/clang-tools-extra/test/clang-tidy/android-cloexec-dup.cpp
new file mode 100644
index 00000000000..f7011b8b835
--- /dev/null
+++ b/clang-tools-extra/test/clang-tidy/android-cloexec-dup.cpp
@@ -0,0 +1,31 @@
+// RUN: %check_clang_tidy %s android-cloexec-dup %t
+
+extern "C" int dup(int oldfd);
+void f() {
+ dup(1);
+ // CHECK-MESSAGES: :[[@LINE-1]]:3: warning: prefer fcntl() to dup() because fcntl() allows F_DUPFD_CLOEXEC [android-cloexec-dup]
+ // CHECK-FIXES: fcntl(1, F_DUPFD_CLOEXEC);
+ int oldfd = 0;
+ dup(oldfd);
+ // CHECK-MESSAGES: :[[@LINE-1]]:3: warning: prefer
+ // CHECK-FIXES: fcntl(oldfd, F_DUPFD_CLOEXEC);
+}
+
+namespace i {
+int dup(int oldfd);
+void g() {
+ dup(0);
+ int oldfd = 1;
+ dup(oldfd);
+}
+} // namespace i
+
+class C {
+public:
+ int dup(int oldfd);
+ void h() {
+ dup(0);
+ int oldfd = 1;
+ dup(oldfd);
+ }
+};
OpenPOWER on IntegriCloud