clang-tools
22.0.0git
llvm-project
clang-tools-extra
clang-tidy
cppcoreguidelines
ProTypeUnionAccessCheck.cpp
Go to the documentation of this file.
1
//===----------------------------------------------------------------------===//
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
#include "
ProTypeUnionAccessCheck.h
"
10
#include "clang/ASTMatchers/ASTMatchFinder.h"
11
12
using namespace
clang::ast_matchers
;
13
14
namespace
clang::tidy::cppcoreguidelines
{
15
16
void
ProTypeUnionAccessCheck::registerMatchers
(MatchFinder *Finder) {
17
Finder->addMatcher(
18
memberExpr(hasObjectExpression(hasType(recordDecl(isUnion()))))
19
.bind(
"expr"
),
20
this
);
21
}
22
23
void
ProTypeUnionAccessCheck::check
(
const
MatchFinder::MatchResult &Result) {
24
const
auto
*Matched = Result.Nodes.getNodeAs<MemberExpr>(
"expr"
);
25
SourceLocation Loc = Matched->getMemberLoc();
26
if
(Loc.isInvalid())
27
Loc = Matched->getBeginLoc();
28
diag(Loc,
"do not access members of unions; consider using (boost::)variant "
29
"instead"
);
30
}
31
32
}
// namespace clang::tidy::cppcoreguidelines
ProTypeUnionAccessCheck.h
clang::tidy::cppcoreguidelines::ProTypeUnionAccessCheck::registerMatchers
void registerMatchers(ast_matchers::MatchFinder *Finder) override
Definition
ProTypeUnionAccessCheck.cpp:16
clang::tidy::cppcoreguidelines::ProTypeUnionAccessCheck::check
void check(const ast_matchers::MatchFinder::MatchResult &Result) override
Definition
ProTypeUnionAccessCheck.cpp:23
clang::ast_matchers
Definition
AbseilMatcher.h:13
clang::tidy::cppcoreguidelines
Definition
AvoidCapturingLambdaCoroutinesCheck.cpp:15
Generated on
for clang-tools by
1.14.0