This revision was automatically updated to reflect the committed changes. Closed by commit rG159dd447fe98: [clangd][ObjC] Highlight Objc Ivar refs (authored by dgoldman).
Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D101785/new/ https://reviews.llvm.org/D101785 Files: clang-tools-extra/clangd/FindTarget.cpp clang-tools-extra/clangd/unittests/FindTargetTests.cpp clang-tools-extra/clangd/unittests/SemanticHighlightingTests.cpp Index: clang-tools-extra/clangd/unittests/SemanticHighlightingTests.cpp =================================================================== --- clang-tools-extra/clangd/unittests/SemanticHighlightingTests.cpp +++ clang-tools-extra/clangd/unittests/SemanticHighlightingTests.cpp @@ -687,6 +687,21 @@ @implementation $Class[[Foo]]($Namespace_decl[[Bar]]) @end )cpp", + R"cpp( + // ObjC: Properties and Ivars. + @interface $Class_decl[[Foo]] { + int $Field_decl[[_someProperty]]; + } + @property(nonatomic, assign) int $Field_decl[[someProperty]]; + @end + @implementation $Class_decl[[Foo]] + @synthesize someProperty = _someProperty; + - (int)$Method_decl[[doSomething]] { + self.$Field[[someProperty]] = self.$Field[[someProperty]] + 1; + self->$Field[[_someProperty]] = $Field[[_someProperty]] + 1; + } + @end + )cpp", // Member imported from dependent base R"cpp( template <typename> struct $Class_decl[[Base]] { Index: clang-tools-extra/clangd/unittests/FindTargetTests.cpp =================================================================== --- clang-tools-extra/clangd/unittests/FindTargetTests.cpp +++ clang-tools-extra/clangd/unittests/FindTargetTests.cpp @@ -1607,6 +1607,21 @@ "5: targets = {t}, decl\n" "6: targets = {t}\n" "7: targets = {}\n"}, + // Objective-C: instance variables + { + R"cpp( + @interface I { + @public + I *_z; + } + @end + I *f; + void foo() { + $0^f->$1^_z = 0; + } + )cpp", + "0: targets = {f}\n" + "1: targets = {I::_z}\n"}, // Objective-C: properties { R"cpp( Index: clang-tools-extra/clangd/FindTarget.cpp =================================================================== --- clang-tools-extra/clangd/FindTarget.cpp +++ clang-tools-extra/clangd/FindTarget.cpp @@ -780,6 +780,13 @@ explicitReferenceTargets(DynTypedNode::create(*E), {}, Resolver)}); } + void VisitObjCIvarRefExpr(const ObjCIvarRefExpr *OIRE) { + Refs.push_back(ReferenceLoc{NestedNameSpecifierLoc(), + OIRE->getLocation(), + /*IsDecl=*/false, + {OIRE->getDecl()}}); + } + void VisitObjCMessageExpr(const ObjCMessageExpr *E) { // The name may have several tokens, we can only report the first. Refs.push_back(ReferenceLoc{NestedNameSpecifierLoc(),
Index: clang-tools-extra/clangd/unittests/SemanticHighlightingTests.cpp =================================================================== --- clang-tools-extra/clangd/unittests/SemanticHighlightingTests.cpp +++ clang-tools-extra/clangd/unittests/SemanticHighlightingTests.cpp @@ -687,6 +687,21 @@ @implementation $Class[[Foo]]($Namespace_decl[[Bar]]) @end )cpp", + R"cpp( + // ObjC: Properties and Ivars. + @interface $Class_decl[[Foo]] { + int $Field_decl[[_someProperty]]; + } + @property(nonatomic, assign) int $Field_decl[[someProperty]]; + @end + @implementation $Class_decl[[Foo]] + @synthesize someProperty = _someProperty; + - (int)$Method_decl[[doSomething]] { + self.$Field[[someProperty]] = self.$Field[[someProperty]] + 1; + self->$Field[[_someProperty]] = $Field[[_someProperty]] + 1; + } + @end + )cpp", // Member imported from dependent base R"cpp( template <typename> struct $Class_decl[[Base]] { Index: clang-tools-extra/clangd/unittests/FindTargetTests.cpp =================================================================== --- clang-tools-extra/clangd/unittests/FindTargetTests.cpp +++ clang-tools-extra/clangd/unittests/FindTargetTests.cpp @@ -1607,6 +1607,21 @@ "5: targets = {t}, decl\n" "6: targets = {t}\n" "7: targets = {}\n"}, + // Objective-C: instance variables + { + R"cpp( + @interface I { + @public + I *_z; + } + @end + I *f; + void foo() { + $0^f->$1^_z = 0; + } + )cpp", + "0: targets = {f}\n" + "1: targets = {I::_z}\n"}, // Objective-C: properties { R"cpp( Index: clang-tools-extra/clangd/FindTarget.cpp =================================================================== --- clang-tools-extra/clangd/FindTarget.cpp +++ clang-tools-extra/clangd/FindTarget.cpp @@ -780,6 +780,13 @@ explicitReferenceTargets(DynTypedNode::create(*E), {}, Resolver)}); } + void VisitObjCIvarRefExpr(const ObjCIvarRefExpr *OIRE) { + Refs.push_back(ReferenceLoc{NestedNameSpecifierLoc(), + OIRE->getLocation(), + /*IsDecl=*/false, + {OIRE->getDecl()}}); + } + void VisitObjCMessageExpr(const ObjCMessageExpr *E) { // The name may have several tokens, we can only report the first. Refs.push_back(ReferenceLoc{NestedNameSpecifierLoc(),
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits