[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / clang-tools-extra / clang-tidy / android / CloexecAcceptCheck.cpp
blob80be6fe326a28ac836065e44174b5dfb0660f0f6
1 //===--- CloexecAcceptCheck.cpp - clang-tidy-------------------------------===//
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 //===----------------------------------------------------------------------===//
9 #include "CloexecAcceptCheck.h"
10 #include "clang/AST/ASTContext.h"
11 #include "clang/ASTMatchers/ASTMatchFinder.h"
13 using namespace clang::ast_matchers;
15 namespace clang::tidy::android {
17 void CloexecAcceptCheck::registerMatchers(MatchFinder *Finder) {
18 auto SockAddrPointerType =
19 hasType(pointsTo(recordDecl(isStruct(), hasName("sockaddr"))));
20 auto SockLenPointerType = hasType(pointsTo(namedDecl(hasName("socklen_t"))));
22 registerMatchersImpl(Finder,
23 functionDecl(returns(isInteger()), hasName("accept"),
24 hasParameter(0, hasType(isInteger())),
25 hasParameter(1, SockAddrPointerType),
26 hasParameter(2, SockLenPointerType)));
29 void CloexecAcceptCheck::check(const MatchFinder::MatchResult &Result) {
30 std::string ReplacementText =
31 (Twine("accept4(") + getSpellingArg(Result, 0) + ", " +
32 getSpellingArg(Result, 1) + ", " + getSpellingArg(Result, 2) +
33 ", SOCK_CLOEXEC)")
34 .str();
36 replaceFunc(
37 Result,
38 "prefer accept4() to accept() because accept4() allows SOCK_CLOEXEC",
39 ReplacementText);
42 } // namespace clang::tidy::android