blob: 0b617ffdc3f5df571ec06a71a4e369cc565c2966 [file] [log] [blame]
Olivier Deprezf4ef2d02021-04-20 13:36:24 +02001//===--- CloexecFopenCheck.h - clang-tidy------------------------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
9#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_ANDROID_CLOEXEC_FOPEN_H
10#define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_ANDROID_CLOEXEC_FOPEN_H
11
12#include "CloexecCheck.h"
13
14namespace clang {
15namespace tidy {
16namespace android {
17
18/// fopen() is suggested to include "e" in their mode string; like "re" would be
19/// better than "r".
20///
21/// This check only works when corresponding argument is StringLiteral. No
22/// constant propagation.
23///
24/// http://clang.llvm.org/extra/clang-tidy/checks/android-cloexec-fopen.html
25class CloexecFopenCheck : public CloexecCheck {
26public:
27 CloexecFopenCheck(StringRef Name, ClangTidyContext *Context)
28 : CloexecCheck(Name, Context) {}
29 void registerMatchers(ast_matchers::MatchFinder *Finder) override;
30 void check(const ast_matchers::MatchFinder::MatchResult &Result) override;
31};
32
33} // namespace android
34} // namespace tidy
35} // namespace clang
36
37#endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_ANDROID_CLOEXEC_FOPEN_H