clang-tools 20.0.0git
CloexecFopenCheck.h
Go to the documentation of this file.
1//===--- 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::tidy::android {
15
16/// fopen() is suggested to include "e" in their mode string; like "re" would be
17/// better than "r".
18///
19/// This check only works when corresponding argument is StringLiteral. No
20/// constant propagation.
21///
22/// http://clang.llvm.org/extra/clang-tidy/checks/android/cloexec-fopen.html
24public:
26 : CloexecCheck(Name, Context) {}
27 void registerMatchers(ast_matchers::MatchFinder *Finder) override;
28 void check(const ast_matchers::MatchFinder::MatchResult &Result) override;
29};
30
31} // namespace clang::tidy::android
32
33#endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_ANDROID_CLOEXEC_FOPEN_H
llvm::SmallString< 256U > Name
This file contains the declaration of the CloexecCheck class, which is the base class for all of the ...
Every ClangTidyCheck reports errors through a DiagnosticsEngine provided by this context.
The base class for all close-on-exec checks in Android module.
Definition: CloexecCheck.h:26
fopen() is suggested to include "e" in their mode string; like "re" would be better than "r".
CloexecFopenCheck(StringRef Name, ClangTidyContext *Context)
void check(const ast_matchers::MatchFinder::MatchResult &Result) override
ClangTidyChecks that register ASTMatchers should do the actual work in here.
void registerMatchers(ast_matchers::MatchFinder *Finder) override
Override this to register AST matchers with Finder.