annotate clang-tools-extra/clang-tidy/objc/SuperSelfCheck.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
150
anatofuz
parents:
diff changeset
1 //===--- SuperSelfCheck.cpp - clang-tidy ----------------------------------===//
anatofuz
parents:
diff changeset
2 //
236
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
150
anatofuz
parents:
diff changeset
6 //
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 #include "SuperSelfCheck.h"
anatofuz
parents:
diff changeset
10 #include "clang/AST/ASTContext.h"
anatofuz
parents:
diff changeset
11 #include "clang/ASTMatchers/ASTMatchFinder.h"
anatofuz
parents:
diff changeset
12
anatofuz
parents:
diff changeset
13 using namespace clang::ast_matchers;
anatofuz
parents:
diff changeset
14
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
15 namespace clang::tidy::objc {
150
anatofuz
parents:
diff changeset
16
anatofuz
parents:
diff changeset
17 namespace {
anatofuz
parents:
diff changeset
18
anatofuz
parents:
diff changeset
19 /// Matches Objective-C methods in the initializer family.
anatofuz
parents:
diff changeset
20 ///
anatofuz
parents:
diff changeset
21 /// Example matches -init and -initWithInt:.
anatofuz
parents:
diff changeset
22 /// (matcher = objcMethodDecl(isInitializer()))
anatofuz
parents:
diff changeset
23 /// \code
anatofuz
parents:
diff changeset
24 /// @interface Foo
anatofuz
parents:
diff changeset
25 /// - (instancetype)init;
anatofuz
parents:
diff changeset
26 /// - (instancetype)initWithInt:(int)i;
anatofuz
parents:
diff changeset
27 /// + (instancetype)init;
anatofuz
parents:
diff changeset
28 /// - (void)bar;
anatofuz
parents:
diff changeset
29 /// @end
anatofuz
parents:
diff changeset
30 /// \endcode
anatofuz
parents:
diff changeset
31 AST_MATCHER(ObjCMethodDecl, isInitializer) {
anatofuz
parents:
diff changeset
32 return Node.getMethodFamily() == OMF_init;
anatofuz
parents:
diff changeset
33 }
anatofuz
parents:
diff changeset
34
anatofuz
parents:
diff changeset
35 /// Matches Objective-C implementations with interfaces that match
anatofuz
parents:
diff changeset
36 /// \c Base.
anatofuz
parents:
diff changeset
37 ///
anatofuz
parents:
diff changeset
38 /// Example matches implementation declarations for X.
anatofuz
parents:
diff changeset
39 /// (matcher = objcImplementationDecl(hasInterface(hasName("X"))))
anatofuz
parents:
diff changeset
40 /// \code
anatofuz
parents:
diff changeset
41 /// @interface X
anatofuz
parents:
diff changeset
42 /// @end
anatofuz
parents:
diff changeset
43 /// @implementation X
anatofuz
parents:
diff changeset
44 /// @end
anatofuz
parents:
diff changeset
45 /// @interface Y
anatofuz
parents:
diff changeset
46 // @end
anatofuz
parents:
diff changeset
47 /// @implementation Y
anatofuz
parents:
diff changeset
48 /// @end
anatofuz
parents:
diff changeset
49 /// \endcode
anatofuz
parents:
diff changeset
50 AST_MATCHER_P(ObjCImplementationDecl, hasInterface,
anatofuz
parents:
diff changeset
51 ast_matchers::internal::Matcher<ObjCInterfaceDecl>, Base) {
anatofuz
parents:
diff changeset
52 const ObjCInterfaceDecl *InterfaceDecl = Node.getClassInterface();
anatofuz
parents:
diff changeset
53 return Base.matches(*InterfaceDecl, Finder, Builder);
anatofuz
parents:
diff changeset
54 }
anatofuz
parents:
diff changeset
55
anatofuz
parents:
diff changeset
56 /// Matches Objective-C message expressions where the receiver is the
anatofuz
parents:
diff changeset
57 /// super instance.
anatofuz
parents:
diff changeset
58 ///
anatofuz
parents:
diff changeset
59 /// Example matches the invocations of -banana and -orange.
anatofuz
parents:
diff changeset
60 /// (matcher = objcMessageExpr(isMessagingSuperInstance()))
anatofuz
parents:
diff changeset
61 /// \code
anatofuz
parents:
diff changeset
62 /// - (void)banana {
anatofuz
parents:
diff changeset
63 /// [self apple]
anatofuz
parents:
diff changeset
64 /// [super banana];
anatofuz
parents:
diff changeset
65 /// [super orange];
anatofuz
parents:
diff changeset
66 /// }
anatofuz
parents:
diff changeset
67 /// \endcode
anatofuz
parents:
diff changeset
68 AST_MATCHER(ObjCMessageExpr, isMessagingSuperInstance) {
anatofuz
parents:
diff changeset
69 return Node.getReceiverKind() == ObjCMessageExpr::SuperInstance;
anatofuz
parents:
diff changeset
70 }
anatofuz
parents:
diff changeset
71
anatofuz
parents:
diff changeset
72 } // namespace
anatofuz
parents:
diff changeset
73
anatofuz
parents:
diff changeset
74 void SuperSelfCheck::registerMatchers(MatchFinder *Finder) {
anatofuz
parents:
diff changeset
75 Finder->addMatcher(
anatofuz
parents:
diff changeset
76 objcMessageExpr(hasSelector("self"), isMessagingSuperInstance(),
anatofuz
parents:
diff changeset
77 hasAncestor(objcMethodDecl(
anatofuz
parents:
diff changeset
78 isInitializer(),
anatofuz
parents:
diff changeset
79 hasDeclContext(objcImplementationDecl(hasInterface(
anatofuz
parents:
diff changeset
80 isDerivedFrom(hasName("NSObject"))))))))
anatofuz
parents:
diff changeset
81 .bind("message"),
anatofuz
parents:
diff changeset
82 this);
anatofuz
parents:
diff changeset
83 }
anatofuz
parents:
diff changeset
84
anatofuz
parents:
diff changeset
85 void SuperSelfCheck::check(const MatchFinder::MatchResult &Result) {
anatofuz
parents:
diff changeset
86 const auto *Message = Result.Nodes.getNodeAs<ObjCMessageExpr>("message");
anatofuz
parents:
diff changeset
87
anatofuz
parents:
diff changeset
88 auto Diag = diag(Message->getExprLoc(), "suspicious invocation of %0 in "
anatofuz
parents:
diff changeset
89 "initializer; did you mean to "
anatofuz
parents:
diff changeset
90 "invoke a superclass initializer?")
anatofuz
parents:
diff changeset
91 << Message->getMethodDecl();
anatofuz
parents:
diff changeset
92
anatofuz
parents:
diff changeset
93 SourceLocation ReceiverLoc = Message->getReceiverRange().getBegin();
anatofuz
parents:
diff changeset
94 if (ReceiverLoc.isMacroID() || ReceiverLoc.isInvalid())
anatofuz
parents:
diff changeset
95 return;
anatofuz
parents:
diff changeset
96
anatofuz
parents:
diff changeset
97 SourceLocation SelectorLoc = Message->getSelectorStartLoc();
anatofuz
parents:
diff changeset
98 if (SelectorLoc.isMacroID() || SelectorLoc.isInvalid())
anatofuz
parents:
diff changeset
99 return;
anatofuz
parents:
diff changeset
100
anatofuz
parents:
diff changeset
101 Diag << FixItHint::CreateReplacement(Message->getSourceRange(),
anatofuz
parents:
diff changeset
102 StringRef("[super init]"));
anatofuz
parents:
diff changeset
103 }
anatofuz
parents:
diff changeset
104
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
105 } // namespace clang::tidy::objc