28 const auto TypesMatcher = hasUnqualifiedDesugaredType(
29 recordType(hasDeclaration(cxxRecordDecl(hasAnyName(Types)))));
33 hasBase(cxxMemberCallExpr(
34 has(memberExpr().bind(
"member")),
35 on(hasType(qualType(anyOf(
36 TypesMatcher, pointerType(pointee(TypesMatcher)))))),
37 callee(namedDecl(hasName(
"data"))))
43 const auto *Call = Result.Nodes.getNodeAs<CXXMemberCallExpr>(
"call");
44 if (Result.Context->getSourceManager().isMacroBodyExpansion(
48 const auto *Member = Result.Nodes.getNodeAs<MemberExpr>(
"member");
50 diag(Member->getMemberLoc(),
51 "accessing an element of the container does not require a call to "
52 "'data()'; did you mean to use 'operator[]'?");
53 if (Member->isArrow())
54 DiagBuilder << FixItHint::CreateInsertion(Member->getBeginLoc(),
"(*")
55 << FixItHint::CreateInsertion(Member->getOperatorLoc(),
")");
56 DiagBuilder << FixItHint::CreateRemoval(
57 {Member->getOperatorLoc(), Call->getEndLoc()});
Every ClangTidyCheck reports errors through a DiagnosticsEngine provided by this context.