annotate clang-tools-extra/clang-tidy/objc/AssertEquals.cpp @ 265:31d058e83c98 current

fix llvm again
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 14 Oct 2023 10:13:49 +0900
parents 1f2b6ac9f198
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
236
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
1 //===--- AssertEquals.cpp - clang-tidy --------------------------*- C++ -*-===//
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
2 //
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
6 //
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
8
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
9 #include "AssertEquals.h"
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
10
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
11 #include <map>
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
12 #include <string>
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
13
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
14 using namespace clang::ast_matchers;
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
15
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
16 namespace clang::tidy::objc {
236
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
17
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
18 // Mapping from `XCTAssert*Equal` to `XCTAssert*EqualObjects` name.
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
19 static const std::map<std::string, std::string> &NameMap() {
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
20 static std::map<std::string, std::string> map{
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
21 {"XCTAssertEqual", "XCTAssertEqualObjects"},
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
22 {"XCTAssertNotEqual", "XCTAssertNotEqualObjects"},
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
23
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
24 };
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
25 return map;
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
26 }
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
27
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
28 void AssertEquals::registerMatchers(MatchFinder *finder) {
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
29 for (const auto &pair : NameMap()) {
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
30 finder->addMatcher(
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
31 binaryOperator(anyOf(hasOperatorName("!="), hasOperatorName("==")),
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
32 isExpandedFromMacro(pair.first),
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
33 anyOf(hasLHS(hasType(qualType(
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
34 hasCanonicalType(asString("NSString *"))))),
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
35 hasRHS(hasType(qualType(
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
36 hasCanonicalType(asString("NSString *"))))))
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
37
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
38 )
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
39 .bind(pair.first),
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
40 this);
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
41 }
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
42 }
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
43
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
44 void AssertEquals::check(const ast_matchers::MatchFinder::MatchResult &result) {
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
45 for (const auto &pair : NameMap()) {
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
46 if (const auto *root = result.Nodes.getNodeAs<BinaryOperator>(pair.first)) {
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
47 SourceManager *sm = result.SourceManager;
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
48 // The macros are nested two levels, so going up twice.
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
49 auto macro_callsite = sm->getImmediateMacroCallerLoc(
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
50 sm->getImmediateMacroCallerLoc(root->getBeginLoc()));
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
51 diag(macro_callsite, "use " + pair.second + " for comparing objects")
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
52 << FixItHint::CreateReplacement(
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
53 clang::CharSourceRange::getCharRange(
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
54 macro_callsite,
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
55 macro_callsite.getLocWithOffset(pair.first.length())),
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
56 pair.second);
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
57 }
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
58 }
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
59 }
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
60
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
61 } // namespace clang::tidy::objc