29 const auto TypesMatcher = hasUnqualifiedDesugaredType(
30 recordType(hasDeclaration(cxxRecordDecl(hasAnyName(Types)))));
33 arraySubscriptExpr(hasBase(
35 has(memberExpr().bind(
"member")),
37 unless(anyOf(substTemplateTypeParmType(),
38 hasDescendant(substTemplateTypeParmType()))),
39 anyOf(TypesMatcher, pointerType(pointee(TypesMatcher)))))),
40 callee(namedDecl(hasName(
"data"))))
46 const auto *Call = Result.Nodes.getNodeAs<CXXMemberCallExpr>(
"call");
47 if (Result.Context->getSourceManager().isMacroBodyExpansion(
51 const auto *Member = Result.Nodes.getNodeAs<MemberExpr>(
"member");
53 diag(Member->getMemberLoc(),
54 "accessing an element of the container does not require a call to "
55 "'data()'; did you mean to use 'operator[]'?");
56 if (Member->isArrow())
57 DiagBuilder << FixItHint::CreateInsertion(Member->getBeginLoc(),
"(*")
58 << FixItHint::CreateInsertion(Member->getOperatorLoc(),
")");
59 DiagBuilder << FixItHint::CreateRemoval(
60 {Member->getOperatorLoc(), Call->getEndLoc()});
Every ClangTidyCheck reports errors through a DiagnosticsEngine provided by this context.