diff options
author | Chih-Hung Hsieh <chh@google.com> | 2017-08-14 17:04:16 +0000 |
---|---|---|
committer | Chih-Hung Hsieh <chh@google.com> | 2017-08-14 17:04:16 +0000 |
commit | 56650e7fc58770fbfecfad746222da47cb208f5e (patch) | |
tree | 1f1e316c2060697275b4cd1a14d0a5237b848c5e /clang-tools-extra/test/clang-tidy/android-cloexec-dup.cpp | |
parent | 533d4c90bda5aa40a81671bbf8b059e91fb24925 (diff) | |
download | bcm5719-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.cpp | 31 |
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); + } +}; |