1 //===-- FindTargetTests.cpp --------------------------*- C++ -*------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 #include "FindTarget.h"
9
10 #include "Selection.h"
11 #include "TestTU.h"
12 #include "clang/AST/Decl.h"
13 #include "clang/AST/DeclTemplate.h"
14 #include "clang/Basic/SourceLocation.h"
15 #include "llvm/ADT/StringRef.h"
16 #include "llvm/Support/Casting.h"
17 #include "llvm/Support/raw_ostream.h"
18 #include "llvm/Testing/Support/Annotations.h"
19 #include "gmock/gmock.h"
20 #include "gtest/gtest.h"
21 #include <initializer_list>
22
23 namespace clang {
24 namespace clangd {
25 namespace {
26
27 // A referenced Decl together with its DeclRelationSet, for assertions.
28 //
29 // There's no great way to assert on the "content" of a Decl in the general case
30 // that's both expressive and unambiguous (e.g. clearly distinguishes between
31 // templated decls and their specializations).
32 //
33 // We use the result of pretty-printing the decl, with the {body} truncated.
34 struct PrintedDecl {
PrintedDeclclang::clangd::__anon68e0b0880111::PrintedDecl35 PrintedDecl(const char *Name, DeclRelationSet Relations = {})
36 : Name(Name), Relations(Relations) {}
PrintedDeclclang::clangd::__anon68e0b0880111::PrintedDecl37 PrintedDecl(const NamedDecl *D, DeclRelationSet Relations = {})
38 : Relations(Relations) {
39 std::string S;
40 llvm::raw_string_ostream OS(S);
41 D->print(OS);
42 llvm::StringRef FirstLine =
__anon68e0b0880202(char C) 43 llvm::StringRef(OS.str()).take_until([](char C) { return C == '\n'; });
44 FirstLine = FirstLine.rtrim(" {");
45 Name = std::string(FirstLine.rtrim(" {"));
46 }
47
48 std::string Name;
49 DeclRelationSet Relations;
50 };
operator ==(const PrintedDecl & L,const PrintedDecl & R)51 bool operator==(const PrintedDecl &L, const PrintedDecl &R) {
52 return std::tie(L.Name, L.Relations) == std::tie(R.Name, R.Relations);
53 }
operator <<(llvm::raw_ostream & OS,const PrintedDecl & D)54 llvm::raw_ostream &operator<<(llvm::raw_ostream &OS, const PrintedDecl &D) {
55 return OS << D.Name << " Rel=" << D.Relations;
56 }
57
58 // The test cases in for targetDecl() take the form
59 // - a piece of code (Code = "...")
60 // - Code should have a single AST node marked as a [[range]]
61 // - an EXPECT_DECLS() assertion that verify the type of node selected, and
62 // all the decls that targetDecl() considers it to reference
63 // Despite the name, these cases actually test allTargetDecls() for brevity.
64 class TargetDeclTest : public ::testing::Test {
65 protected:
66 using Rel = DeclRelation;
67 std::string Code;
68 std::vector<std::string> Flags;
69
70 // Asserts that `Code` has a marked selection of a node `NodeType`,
71 // and returns allTargetDecls() as PrintedDecl structs.
72 // Use via EXPECT_DECLS().
assertNodeAndPrintDecls(const char * NodeType)73 std::vector<PrintedDecl> assertNodeAndPrintDecls(const char *NodeType) {
74 llvm::Annotations A(Code);
75 auto TU = TestTU::withCode(A.code());
76 TU.ExtraArgs = Flags;
77 auto AST = TU.build();
78 llvm::Annotations::Range R = A.range();
79 auto Selection = SelectionTree::createRight(
80 AST.getASTContext(), AST.getTokens(), R.Begin, R.End);
81 const SelectionTree::Node *N = Selection.commonAncestor();
82 if (!N) {
83 ADD_FAILURE() << "No node selected!\n" << Code;
84 return {};
85 }
86 EXPECT_EQ(N->kind(), NodeType) << Selection;
87
88 std::vector<PrintedDecl> ActualDecls;
89 for (const auto &Entry : allTargetDecls(N->ASTNode))
90 ActualDecls.emplace_back(Entry.first, Entry.second);
91 return ActualDecls;
92 }
93 };
94
95 // This is a macro to preserve line numbers in assertion failures.
96 // It takes the expected decls as varargs to work around comma-in-macro issues.
97 #define EXPECT_DECLS(NodeType, ...) \
98 EXPECT_THAT(assertNodeAndPrintDecls(NodeType), \
99 ::testing::UnorderedElementsAreArray( \
100 std::vector<PrintedDecl>({__VA_ARGS__}))) \
101 << Code
102 using ExpectedDecls = std::vector<PrintedDecl>;
103
TEST_F(TargetDeclTest,Exprs)104 TEST_F(TargetDeclTest, Exprs) {
105 Code = R"cpp(
106 int f();
107 int x = [[f]]();
108 )cpp";
109 EXPECT_DECLS("DeclRefExpr", "int f()");
110
111 Code = R"cpp(
112 struct S { S operator+(S) const; };
113 auto X = S() [[+]] S();
114 )cpp";
115 EXPECT_DECLS("DeclRefExpr", "S operator+(S) const");
116
117 Code = R"cpp(
118 int foo();
119 int s = foo[[()]];
120 )cpp";
121 EXPECT_DECLS("CallExpr", "int foo()");
122
123 Code = R"cpp(
124 struct X {
125 void operator()(int n);
126 };
127 void test() {
128 X x;
129 x[[(123)]];
130 }
131 )cpp";
132 EXPECT_DECLS("CXXOperatorCallExpr", "void operator()(int n)");
133
134 Code = R"cpp(
135 void test() {
136 goto [[label]];
137 label:
138 return;
139 }
140 )cpp";
141 EXPECT_DECLS("GotoStmt", "label:");
142 Code = R"cpp(
143 void test() {
144 [[label]]:
145 return;
146 }
147 )cpp";
148 EXPECT_DECLS("LabelStmt", "label:");
149 }
150
TEST_F(TargetDeclTest,RecoveryForC)151 TEST_F(TargetDeclTest, RecoveryForC) {
152 Flags = {"-xc", "-Xclang", "-frecovery-ast"};
153 Code = R"cpp(
154 // error-ok: testing behavior on broken code
155 // int f();
156 int f(int);
157 int x = [[f]]();
158 )cpp";
159 EXPECT_DECLS("DeclRefExpr", "int f(int)");
160 }
161
TEST_F(TargetDeclTest,Recovery)162 TEST_F(TargetDeclTest, Recovery) {
163 Code = R"cpp(
164 // error-ok: testing behavior on broken code
165 int f();
166 int f(int, int);
167 int x = [[f]](42);
168 )cpp";
169 EXPECT_DECLS("UnresolvedLookupExpr", "int f()", "int f(int, int)");
170 }
171
TEST_F(TargetDeclTest,RecoveryType)172 TEST_F(TargetDeclTest, RecoveryType) {
173 Code = R"cpp(
174 // error-ok: testing behavior on broken code
175 struct S { int member; };
176 S overloaded(int);
177 void foo() {
178 // No overload matches, but we have recovery-expr with the correct type.
179 overloaded().[[member]];
180 }
181 )cpp";
182 EXPECT_DECLS("MemberExpr", "int member");
183 }
184
TEST_F(TargetDeclTest,UsingDecl)185 TEST_F(TargetDeclTest, UsingDecl) {
186 Code = R"cpp(
187 namespace foo {
188 int f(int);
189 int f(char);
190 }
191 using foo::f;
192 int x = [[f]](42);
193 )cpp";
194 // f(char) is not referenced!
195 EXPECT_DECLS("DeclRefExpr", {"using foo::f", Rel::Alias}, {"int f(int)"});
196
197 Code = R"cpp(
198 namespace foo {
199 int f(int);
200 int f(char);
201 }
202 [[using foo::f]];
203 )cpp";
204 // All overloads are referenced.
205 EXPECT_DECLS("UsingDecl", {"using foo::f", Rel::Alias}, {"int f(int)"},
206 {"int f(char)"});
207
208 Code = R"cpp(
209 struct X {
210 int foo();
211 };
212 struct Y : X {
213 using X::foo;
214 };
215 int x = Y().[[foo]]();
216 )cpp";
217 EXPECT_DECLS("MemberExpr", {"using X::foo", Rel::Alias}, {"int foo()"});
218
219 Code = R"cpp(
220 template <typename T>
221 struct Base {
222 void waldo() {}
223 };
224 template <typename T>
225 struct Derived : Base<T> {
226 using Base<T>::[[waldo]];
227 };
228 )cpp";
229 EXPECT_DECLS("UnresolvedUsingValueDecl", {"using Base<T>::waldo", Rel::Alias},
230 {"void waldo()"});
231 }
232
TEST_F(TargetDeclTest,ConstructorInitList)233 TEST_F(TargetDeclTest, ConstructorInitList) {
234 Code = R"cpp(
235 struct X {
236 int a;
237 X() : [[a]](42) {}
238 };
239 )cpp";
240 EXPECT_DECLS("CXXCtorInitializer", "int a");
241
242 Code = R"cpp(
243 struct X {
244 X() : [[X]](1) {}
245 X(int);
246 };
247 )cpp";
248 EXPECT_DECLS("RecordTypeLoc", "struct X");
249 }
250
TEST_F(TargetDeclTest,DesignatedInit)251 TEST_F(TargetDeclTest, DesignatedInit) {
252 Flags = {"-xc"}; // array designators are a C99 extension.
253 Code = R"c(
254 struct X { int a; };
255 struct Y { int b; struct X c[2]; };
256 struct Y y = { .c[0].[[a]] = 1 };
257 )c";
258 EXPECT_DECLS("DesignatedInitExpr", "int a");
259 }
260
TEST_F(TargetDeclTest,NestedNameSpecifier)261 TEST_F(TargetDeclTest, NestedNameSpecifier) {
262 Code = R"cpp(
263 namespace a { namespace b { int c; } }
264 int x = a::[[b::]]c;
265 )cpp";
266 EXPECT_DECLS("NestedNameSpecifierLoc", "namespace b");
267
268 Code = R"cpp(
269 namespace a { struct X { enum { y }; }; }
270 int x = a::[[X::]]y;
271 )cpp";
272 EXPECT_DECLS("NestedNameSpecifierLoc", "struct X");
273
274 Code = R"cpp(
275 template <typename T>
276 int x = [[T::]]y;
277 )cpp";
278 EXPECT_DECLS("NestedNameSpecifierLoc", "typename T");
279
280 Code = R"cpp(
281 namespace a { int x; }
282 namespace b = a;
283 int y = [[b]]::x;
284 )cpp";
285 EXPECT_DECLS("NestedNameSpecifierLoc", {"namespace b = a", Rel::Alias},
286 {"namespace a", Rel::Underlying});
287 }
288
TEST_F(TargetDeclTest,Types)289 TEST_F(TargetDeclTest, Types) {
290 Code = R"cpp(
291 struct X{};
292 [[X]] x;
293 )cpp";
294 EXPECT_DECLS("RecordTypeLoc", "struct X");
295
296 Code = R"cpp(
297 struct S{};
298 typedef S X;
299 [[X]] x;
300 )cpp";
301 EXPECT_DECLS("TypedefTypeLoc", {"typedef S X", Rel::Alias},
302 {"struct S", Rel::Underlying});
303 Code = R"cpp(
304 namespace ns { struct S{}; }
305 typedef ns::S X;
306 [[X]] x;
307 )cpp";
308 EXPECT_DECLS("TypedefTypeLoc", {"typedef ns::S X", Rel::Alias},
309 {"struct S", Rel::Underlying});
310
311 // FIXME: Auto-completion in a template requires disabling delayed template
312 // parsing.
313 Flags = {"-fno-delayed-template-parsing"};
314 Code = R"cpp(
315 template<class T>
316 void foo() { [[T]] x; }
317 )cpp";
318 EXPECT_DECLS("TemplateTypeParmTypeLoc", "class T");
319 Flags.clear();
320
321 // FIXME: Auto-completion in a template requires disabling delayed template
322 // parsing.
323 Flags = {"-fno-delayed-template-parsing"};
324 Code = R"cpp(
325 template<template<typename> class T>
326 void foo() { [[T<int>]] x; }
327 )cpp";
328 EXPECT_DECLS("TemplateSpecializationTypeLoc", "template <typename> class T");
329 Flags.clear();
330
331 Code = R"cpp(
332 struct S{};
333 S X;
334 [[decltype]](X) Y;
335 )cpp";
336 EXPECT_DECLS("DecltypeTypeLoc", {"struct S", Rel::Underlying});
337
338 Code = R"cpp(
339 struct S{};
340 [[auto]] X = S{};
341 )cpp";
342 // FIXME: deduced type missing in AST. https://llvm.org/PR42914
343 EXPECT_DECLS("AutoTypeLoc");
344
345 Code = R"cpp(
346 template <typename... E>
347 struct S {
348 static const int size = sizeof...([[E]]);
349 };
350 )cpp";
351 EXPECT_DECLS("SizeOfPackExpr", "typename ...E");
352
353 Code = R"cpp(
354 template <typename T>
355 class Foo {
356 void f([[Foo]] x);
357 };
358 )cpp";
359 EXPECT_DECLS("InjectedClassNameTypeLoc", "class Foo");
360 }
361
TEST_F(TargetDeclTest,ClassTemplate)362 TEST_F(TargetDeclTest, ClassTemplate) {
363 Code = R"cpp(
364 // Implicit specialization.
365 template<int x> class Foo{};
366 [[Foo<42>]] B;
367 )cpp";
368 EXPECT_DECLS("TemplateSpecializationTypeLoc",
369 {"template<> class Foo<42>", Rel::TemplateInstantiation},
370 {"class Foo", Rel::TemplatePattern});
371
372 Code = R"cpp(
373 template<typename T> class Foo {};
374 // The "Foo<int>" SpecializationDecl is incomplete, there is no
375 // instantiation happening.
376 void func([[Foo<int>]] *);
377 )cpp";
378 EXPECT_DECLS("TemplateSpecializationTypeLoc",
379 {"class Foo", Rel::TemplatePattern},
380 {"template<> class Foo<int>", Rel::TemplateInstantiation});
381
382 Code = R"cpp(
383 // Explicit specialization.
384 template<int x> class Foo{};
385 template<> class Foo<42>{};
386 [[Foo<42>]] B;
387 )cpp";
388 EXPECT_DECLS("TemplateSpecializationTypeLoc", "template<> class Foo<42>");
389
390 Code = R"cpp(
391 // Partial specialization.
392 template<typename T> class Foo{};
393 template<typename T> class Foo<T*>{};
394 [[Foo<int*>]] B;
395 )cpp";
396 EXPECT_DECLS("TemplateSpecializationTypeLoc",
397 {"template<> class Foo<int *>", Rel::TemplateInstantiation},
398 {"template <typename T> class Foo<T *>", Rel::TemplatePattern});
399
400 Code = R"cpp(
401 // Template template argument.
402 template<typename T> struct Vector {};
403 template <template <typename> class Container>
404 struct A {};
405 A<[[Vector]]> a;
406 )cpp";
407 EXPECT_DECLS("TemplateArgumentLoc", {"template <typename T> struct Vector"});
408
409 Flags.push_back("-std=c++17"); // for CTAD tests
410
411 Code = R"cpp(
412 // Class template argument deduction
413 template <typename T>
414 struct Test {
415 Test(T);
416 };
417 void foo() {
418 [[Test]] a(5);
419 }
420 )cpp";
421 EXPECT_DECLS("DeducedTemplateSpecializationTypeLoc",
422 {"struct Test", Rel::TemplatePattern});
423
424 Code = R"cpp(
425 // Deduction guide
426 template <typename T>
427 struct Test {
428 template <typename I>
429 Test(I, I);
430 };
431 template <typename I>
432 [[Test]](I, I) -> Test<typename I::type>;
433 )cpp";
434 EXPECT_DECLS("CXXDeductionGuideDecl", {"template <typename T> struct Test"});
435 }
436
TEST_F(TargetDeclTest,Concept)437 TEST_F(TargetDeclTest, Concept) {
438 Flags.push_back("-std=c++20");
439
440 // FIXME: Should we truncate the pretty-printed form of a concept decl
441 // somewhere?
442
443 Code = R"cpp(
444 template <typename T>
445 concept Fooable = requires (T t) { t.foo(); };
446
447 template <typename T> requires [[Fooable]]<T>
448 void bar(T t) {
449 t.foo();
450 }
451 )cpp";
452 EXPECT_DECLS(
453 "ConceptSpecializationExpr",
454 {"template <typename T> concept Fooable = requires (T t) { t.foo(); };"});
455
456 // trailing requires clause
457 Code = R"cpp(
458 template <typename T>
459 concept Fooable = true;
460
461 template <typename T>
462 void foo() requires [[Fooable]]<T>;
463 )cpp";
464 EXPECT_DECLS("ConceptSpecializationExpr",
465 {"template <typename T> concept Fooable = true;"});
466
467 // constrained-parameter
468 Code = R"cpp(
469 template <typename T>
470 concept Fooable = true;
471
472 template <[[Fooable]] T>
473 void bar(T t);
474 )cpp";
475 EXPECT_DECLS("ConceptSpecializationExpr",
476 {"template <typename T> concept Fooable = true;"});
477
478 // partial-concept-id
479 Code = R"cpp(
480 template <typename T, typename U>
481 concept Fooable = true;
482
483 template <[[Fooable]]<int> T>
484 void bar(T t);
485 )cpp";
486 EXPECT_DECLS("ConceptSpecializationExpr",
487 {"template <typename T, typename U> concept Fooable = true;"});
488 }
489
TEST_F(TargetDeclTest,FunctionTemplate)490 TEST_F(TargetDeclTest, FunctionTemplate) {
491 Code = R"cpp(
492 // Implicit specialization.
493 template<typename T> bool foo(T) { return false; };
494 bool x = [[foo]](42);
495 )cpp";
496 EXPECT_DECLS("DeclRefExpr",
497 {"template<> bool foo<int>(int)", Rel::TemplateInstantiation},
498 {"bool foo(T)", Rel::TemplatePattern});
499
500 Code = R"cpp(
501 // Explicit specialization.
502 template<typename T> bool foo(T) { return false; };
503 template<> bool foo<int>(int) { return false; };
504 bool x = [[foo]](42);
505 )cpp";
506 EXPECT_DECLS("DeclRefExpr", "template<> bool foo<int>(int)");
507 }
508
TEST_F(TargetDeclTest,VariableTemplate)509 TEST_F(TargetDeclTest, VariableTemplate) {
510 // Pretty-printer doesn't do a very good job of variable templates :-(
511 Code = R"cpp(
512 // Implicit specialization.
513 template<typename T> int foo;
514 int x = [[foo]]<char>;
515 )cpp";
516 EXPECT_DECLS("DeclRefExpr", {"int foo", Rel::TemplateInstantiation},
517 {"int foo", Rel::TemplatePattern});
518
519 Code = R"cpp(
520 // Explicit specialization.
521 template<typename T> int foo;
522 template <> bool foo<char>;
523 int x = [[foo]]<char>;
524 )cpp";
525 EXPECT_DECLS("DeclRefExpr", "bool foo");
526
527 Code = R"cpp(
528 // Partial specialization.
529 template<typename T> int foo;
530 template<typename T> bool foo<T*>;
531 bool x = [[foo]]<char*>;
532 )cpp";
533 EXPECT_DECLS("DeclRefExpr", {"bool foo", Rel::TemplateInstantiation},
534 {"bool foo", Rel::TemplatePattern});
535 }
536
TEST_F(TargetDeclTest,TypeAliasTemplate)537 TEST_F(TargetDeclTest, TypeAliasTemplate) {
538 Code = R"cpp(
539 template<typename T, int X> class SmallVector {};
540 template<typename U> using TinyVector = SmallVector<U, 1>;
541 [[TinyVector<int>]] X;
542 )cpp";
543 EXPECT_DECLS("TemplateSpecializationTypeLoc",
544 {"template<> class SmallVector<int, 1>",
545 Rel::TemplateInstantiation | Rel::Underlying},
546 {"class SmallVector", Rel::TemplatePattern | Rel::Underlying},
547 {"using TinyVector = SmallVector<U, 1>",
548 Rel::Alias | Rel::TemplatePattern});
549 }
550
TEST_F(TargetDeclTest,MemberOfTemplate)551 TEST_F(TargetDeclTest, MemberOfTemplate) {
552 Code = R"cpp(
553 template <typename T> struct Foo {
554 int x(T);
555 };
556 int y = Foo<int>().[[x]](42);
557 )cpp";
558 EXPECT_DECLS("MemberExpr", {"int x(int)", Rel::TemplateInstantiation},
559 {"int x(T)", Rel::TemplatePattern});
560
561 Code = R"cpp(
562 template <typename T> struct Foo {
563 template <typename U>
564 int x(T, U);
565 };
566 int y = Foo<char>().[[x]]('c', 42);
567 )cpp";
568 EXPECT_DECLS("MemberExpr",
569 {"template<> int x<int>(char, int)", Rel::TemplateInstantiation},
570 {"int x(T, U)", Rel::TemplatePattern});
571 }
572
TEST_F(TargetDeclTest,Lambda)573 TEST_F(TargetDeclTest, Lambda) {
574 Code = R"cpp(
575 void foo(int x = 42) {
576 auto l = [ [[x]] ]{ return x + 1; };
577 };
578 )cpp";
579 EXPECT_DECLS("DeclRefExpr", "int x = 42");
580
581 // It seems like this should refer to another var, with the outer param being
582 // an underlying decl. But it doesn't seem to exist.
583 Code = R"cpp(
584 void foo(int x = 42) {
585 auto l = [x]{ return [[x]] + 1; };
586 };
587 )cpp";
588 EXPECT_DECLS("DeclRefExpr", "int x = 42");
589
590 Code = R"cpp(
591 void foo() {
592 auto l = [x = 1]{ return [[x]] + 1; };
593 };
594 )cpp";
595 // FIXME: why both auto and int?
596 EXPECT_DECLS("DeclRefExpr", "auto int x = 1");
597 }
598
TEST_F(TargetDeclTest,OverloadExpr)599 TEST_F(TargetDeclTest, OverloadExpr) {
600 // FIXME: Auto-completion in a template requires disabling delayed template
601 // parsing.
602 Flags = {"-fno-delayed-template-parsing"};
603 Flags.push_back("--target=x86_64-pc-linux-gnu");
604
605 Code = R"cpp(
606 void func(int*);
607 void func(char*);
608
609 template <class T>
610 void foo(T t) {
611 [[func]](t);
612 };
613 )cpp";
614 EXPECT_DECLS("UnresolvedLookupExpr", "void func(int *)", "void func(char *)");
615
616 Code = R"cpp(
617 struct X {
618 void func(int*);
619 void func(char*);
620 };
621
622 template <class T>
623 void foo(X x, T t) {
624 x.[[func]](t);
625 };
626 )cpp";
627 EXPECT_DECLS("UnresolvedMemberExpr", "void func(int *)", "void func(char *)");
628
629 Code = R"cpp(
630 struct X {
631 static void *operator new(unsigned long);
632 };
633 auto* k = [[new]] X();
634 )cpp";
635 EXPECT_DECLS("CXXNewExpr", "static void *operator new(unsigned long)");
636 Code = R"cpp(
637 void *operator new(unsigned long);
638 auto* k = [[new]] int();
639 )cpp";
640 EXPECT_DECLS("CXXNewExpr", "void *operator new(unsigned long)");
641
642 Code = R"cpp(
643 struct X {
644 static void operator delete(void *) noexcept;
645 };
646 void k(X* x) {
647 [[delete]] x;
648 }
649 )cpp";
650 EXPECT_DECLS("CXXDeleteExpr", "static void operator delete(void *) noexcept");
651 Code = R"cpp(
652 void operator delete(void *) noexcept;
653 void k(int* x) {
654 [[delete]] x;
655 }
656 )cpp";
657 EXPECT_DECLS("CXXDeleteExpr", "void operator delete(void *) noexcept");
658 }
659
TEST_F(TargetDeclTest,DependentExprs)660 TEST_F(TargetDeclTest, DependentExprs) {
661 Flags = {"-fno-delayed-template-parsing"};
662
663 // Heuristic resolution of method of dependent field
664 Code = R"cpp(
665 struct A { void foo() {} };
666 template <typename T>
667 struct B {
668 A a;
669 void bar() {
670 this->a.[[foo]]();
671 }
672 };
673 )cpp";
674 EXPECT_DECLS("CXXDependentScopeMemberExpr", "void foo()");
675
676 // Similar to above but base expression involves a function call.
677 Code = R"cpp(
678 struct A {
679 void foo() {}
680 };
681 struct B {
682 A getA();
683 };
684 template <typename T>
685 struct C {
686 B c;
687 void bar() {
688 this->c.getA().[[foo]]();
689 }
690 };
691 )cpp";
692 EXPECT_DECLS("CXXDependentScopeMemberExpr", "void foo()");
693
694 // Similar to above but uses a function pointer.
695 Code = R"cpp(
696 struct A {
697 void foo() {}
698 };
699 struct B {
700 using FPtr = A(*)();
701 FPtr fptr;
702 };
703 template <typename T>
704 struct C {
705 B c;
706 void bar() {
707 this->c.fptr().[[foo]]();
708 }
709 };
710 )cpp";
711 EXPECT_DECLS("CXXDependentScopeMemberExpr", "void foo()");
712
713 // Base expression involves a member access into this.
714 Code = R"cpp(
715 struct Bar {
716 int aaaa;
717 };
718 template <typename T> struct Foo {
719 Bar func(int);
720 void test() {
721 func(1).[[aaaa]];
722 }
723 };
724 )cpp";
725 EXPECT_DECLS("CXXDependentScopeMemberExpr", "int aaaa");
726
727 Code = R"cpp(
728 class Foo {
729 public:
730 static Foo k(int);
731 template <typename T> T convert() const;
732 };
733 template <typename T>
734 void test() {
735 Foo::k(T()).template [[convert]]<T>();
736 }
737 )cpp";
738 EXPECT_DECLS("CXXDependentScopeMemberExpr",
739 "template <typename T> T convert() const");
740 }
741
TEST_F(TargetDeclTest,DependentTypes)742 TEST_F(TargetDeclTest, DependentTypes) {
743 Flags = {"-fno-delayed-template-parsing"};
744
745 // Heuristic resolution of dependent type name
746 Code = R"cpp(
747 template <typename>
748 struct A { struct B {}; };
749
750 template <typename T>
751 void foo(typename A<T>::[[B]]);
752 )cpp";
753 EXPECT_DECLS("DependentNameTypeLoc", "struct B");
754
755 // Heuristic resolution of dependent type name which doesn't get a TypeLoc
756 Code = R"cpp(
757 template <typename>
758 struct A { struct B { struct C {}; }; };
759
760 template <typename T>
761 void foo(typename A<T>::[[B]]::C);
762 )cpp";
763 EXPECT_DECLS("NestedNameSpecifierLoc", "struct B");
764
765 // Heuristic resolution of dependent type name whose qualifier is also
766 // dependent
767 Code = R"cpp(
768 template <typename>
769 struct A { struct B { struct C {}; }; };
770
771 template <typename T>
772 void foo(typename A<T>::B::[[C]]);
773 )cpp";
774 EXPECT_DECLS("DependentNameTypeLoc", "struct C");
775
776 // Heuristic resolution of dependent template name
777 Code = R"cpp(
778 template <typename>
779 struct A {
780 template <typename> struct B {};
781 };
782
783 template <typename T>
784 void foo(typename A<T>::template [[B]]<int>);
785 )cpp";
786 EXPECT_DECLS("DependentTemplateSpecializationTypeLoc",
787 "template <typename> struct B");
788 }
789
TEST_F(TargetDeclTest,ObjC)790 TEST_F(TargetDeclTest, ObjC) {
791 Flags = {"-xobjective-c"};
792 Code = R"cpp(
793 @interface Foo {}
794 -(void)bar;
795 @end
796 void test(Foo *f) {
797 [f [[bar]] ];
798 }
799 )cpp";
800 EXPECT_DECLS("ObjCMessageExpr", "- (void)bar");
801
802 Code = R"cpp(
803 @interface Foo { @public int bar; }
804 @end
805 int test(Foo *f) {
806 return [[f->bar]];
807 }
808 )cpp";
809 EXPECT_DECLS("ObjCIvarRefExpr", "int bar");
810
811 Code = R"cpp(
812 @interface Foo {}
813 -(int) x;
814 -(void) setX:(int)x;
815 @end
816 void test(Foo *f) {
817 [[f.x]] = 42;
818 }
819 )cpp";
820 EXPECT_DECLS("ObjCPropertyRefExpr", "- (void)setX:(int)x");
821
822 Code = R"cpp(
823 @interface I {}
824 @property(retain) I* x;
825 @property(retain) I* y;
826 @end
827 void test(I *f) {
828 [[f.x]].y = 0;
829 }
830 )cpp";
831 EXPECT_DECLS("ObjCPropertyRefExpr",
832 "@property(atomic, retain, readwrite) I *x");
833
834 Code = R"cpp(
835 @interface MYObject
836 @end
837 @interface Interface
838 @property(retain) [[MYObject]] *x;
839 @end
840 )cpp";
841 EXPECT_DECLS("ObjCInterfaceTypeLoc", "@interface MYObject");
842
843 Code = R"cpp(
844 @interface MYObject2
845 @end
846 @interface Interface
847 @property(retain, nonnull) [[MYObject2]] *x;
848 @end
849 )cpp";
850 EXPECT_DECLS("ObjCInterfaceTypeLoc", "@interface MYObject2");
851
852 Code = R"cpp(
853 @protocol Foo
854 @end
855 id test() {
856 return [[@protocol(Foo)]];
857 }
858 )cpp";
859 EXPECT_DECLS("ObjCProtocolExpr", "@protocol Foo");
860
861 Code = R"cpp(
862 @interface Foo
863 @end
864 void test([[Foo]] *p);
865 )cpp";
866 EXPECT_DECLS("ObjCInterfaceTypeLoc", "@interface Foo");
867
868 Code = R"cpp(// Don't consider implicit interface as the target.
869 @implementation [[Implicit]]
870 @end
871 )cpp";
872 EXPECT_DECLS("ObjCImplementationDecl", "@implementation Implicit");
873
874 Code = R"cpp(
875 @interface Foo
876 @end
877 @implementation [[Foo]]
878 @end
879 )cpp";
880 EXPECT_DECLS("ObjCImplementationDecl", "@interface Foo");
881
882 Code = R"cpp(
883 @interface Foo
884 @end
885 @interface Foo (Ext)
886 @end
887 @implementation [[Foo]] (Ext)
888 @end
889 )cpp";
890 EXPECT_DECLS("ObjCCategoryImplDecl", "@interface Foo(Ext)");
891
892 Code = R"cpp(
893 @protocol Foo
894 @end
895 void test([[id<Foo>]] p);
896 )cpp";
897 EXPECT_DECLS("ObjCObjectTypeLoc", "@protocol Foo");
898
899 Code = R"cpp(
900 @class C;
901 @protocol Foo
902 @end
903 void test(C<[[Foo]]> *p);
904 )cpp";
905 // FIXME: there's no AST node corresponding to 'Foo', so we're stuck.
906 EXPECT_DECLS("ObjCObjectTypeLoc");
907 }
908
909 class FindExplicitReferencesTest : public ::testing::Test {
910 protected:
911 struct AllRefs {
912 std::string AnnotatedCode;
913 std::string DumpedReferences;
914 };
915
916 /// Parses \p Code, finds function or namespace '::foo' and annotates its body
917 /// with results of findExplicitReferences.
918 /// See actual tests for examples of annotation format.
annotateReferencesInFoo(llvm::StringRef Code)919 AllRefs annotateReferencesInFoo(llvm::StringRef Code) {
920 TestTU TU;
921 TU.Code = std::string(Code);
922
923 // FIXME: Auto-completion in a template requires disabling delayed template
924 // parsing.
925 TU.ExtraArgs.push_back("-fno-delayed-template-parsing");
926 TU.ExtraArgs.push_back("-std=c++20");
927 TU.ExtraArgs.push_back("-xobjective-c++");
928
929 auto AST = TU.build();
930 auto *TestDecl = &findDecl(AST, "foo");
931 if (auto *T = llvm::dyn_cast<FunctionTemplateDecl>(TestDecl))
932 TestDecl = T->getTemplatedDecl();
933
934 std::vector<ReferenceLoc> Refs;
935 if (const auto *Func = llvm::dyn_cast<FunctionDecl>(TestDecl))
936 findExplicitReferences(Func->getBody(), [&Refs](ReferenceLoc R) {
937 Refs.push_back(std::move(R));
938 });
939 else if (const auto *NS = llvm::dyn_cast<NamespaceDecl>(TestDecl))
940 findExplicitReferences(NS, [&Refs, &NS](ReferenceLoc R) {
941 // Avoid adding the namespace foo decl to the results.
942 if (R.Targets.size() == 1 && R.Targets.front() == NS)
943 return;
944 Refs.push_back(std::move(R));
945 });
946 else
947 ADD_FAILURE() << "Failed to find ::foo decl for test";
948
949 auto &SM = AST.getSourceManager();
950 llvm::sort(Refs, [&](const ReferenceLoc &L, const ReferenceLoc &R) {
951 return SM.isBeforeInTranslationUnit(L.NameLoc, R.NameLoc);
952 });
953
954 std::string AnnotatedCode;
955 unsigned NextCodeChar = 0;
956 for (unsigned I = 0; I < Refs.size(); ++I) {
957 auto &R = Refs[I];
958
959 SourceLocation Pos = R.NameLoc;
960 assert(Pos.isValid());
961 if (Pos.isMacroID()) // FIXME: figure out how to show macro locations.
962 Pos = SM.getExpansionLoc(Pos);
963 assert(Pos.isFileID());
964
965 FileID File;
966 unsigned Offset;
967 std::tie(File, Offset) = SM.getDecomposedLoc(Pos);
968 if (File == SM.getMainFileID()) {
969 // Print the reference in a source code.
970 assert(NextCodeChar <= Offset);
971 AnnotatedCode += Code.substr(NextCodeChar, Offset - NextCodeChar);
972 AnnotatedCode += "$" + std::to_string(I) + "^";
973
974 NextCodeChar = Offset;
975 }
976 }
977 AnnotatedCode += Code.substr(NextCodeChar);
978
979 std::string DumpedReferences;
980 for (unsigned I = 0; I < Refs.size(); ++I)
981 DumpedReferences += std::string(llvm::formatv("{0}: {1}\n", I, Refs[I]));
982
983 return AllRefs{std::move(AnnotatedCode), std::move(DumpedReferences)};
984 }
985 };
986
TEST_F(FindExplicitReferencesTest,All)987 TEST_F(FindExplicitReferencesTest, All) {
988 std::pair</*Code*/ llvm::StringRef, /*References*/ llvm::StringRef> Cases[] =
989 {
990 // Simple expressions.
991 {R"cpp(
992 int global;
993 int func();
994 void foo(int param) {
995 $0^global = $1^param + $2^func();
996 }
997 )cpp",
998 "0: targets = {global}\n"
999 "1: targets = {param}\n"
1000 "2: targets = {func}\n"},
1001 {R"cpp(
1002 struct X { int a; };
1003 void foo(X x) {
1004 $0^x.$1^a = 10;
1005 }
1006 )cpp",
1007 "0: targets = {x}\n"
1008 "1: targets = {X::a}\n"},
1009 {R"cpp(
1010 // error-ok: testing with broken code
1011 int bar();
1012 int foo() {
1013 return $0^bar() + $1^bar(42);
1014 }
1015 )cpp",
1016 "0: targets = {bar}\n"
1017 "1: targets = {bar}\n"},
1018 // Namespaces and aliases.
1019 {R"cpp(
1020 namespace ns {}
1021 namespace alias = ns;
1022 void foo() {
1023 using namespace $0^ns;
1024 using namespace $1^alias;
1025 }
1026 )cpp",
1027 "0: targets = {ns}\n"
1028 "1: targets = {alias}\n"},
1029 // Using declarations.
1030 {R"cpp(
1031 namespace ns { int global; }
1032 void foo() {
1033 using $0^ns::$1^global;
1034 }
1035 )cpp",
1036 "0: targets = {ns}\n"
1037 "1: targets = {ns::global}, qualifier = 'ns::'\n"},
1038 // Simple types.
1039 {R"cpp(
1040 struct Struct { int a; };
1041 using Typedef = int;
1042 void foo() {
1043 $0^Struct $1^x;
1044 $2^Typedef $3^y;
1045 static_cast<$4^Struct*>(0);
1046 }
1047 )cpp",
1048 "0: targets = {Struct}\n"
1049 "1: targets = {x}, decl\n"
1050 "2: targets = {Typedef}\n"
1051 "3: targets = {y}, decl\n"
1052 "4: targets = {Struct}\n"},
1053 // Name qualifiers.
1054 {R"cpp(
1055 namespace a { namespace b { struct S { typedef int type; }; } }
1056 void foo() {
1057 $0^a::$1^b::$2^S $3^x;
1058 using namespace $4^a::$5^b;
1059 $6^S::$7^type $8^y;
1060 }
1061 )cpp",
1062 "0: targets = {a}\n"
1063 "1: targets = {a::b}, qualifier = 'a::'\n"
1064 "2: targets = {a::b::S}, qualifier = 'a::b::'\n"
1065 "3: targets = {x}, decl\n"
1066 "4: targets = {a}\n"
1067 "5: targets = {a::b}, qualifier = 'a::'\n"
1068 "6: targets = {a::b::S}\n"
1069 "7: targets = {a::b::S::type}, qualifier = 'struct S::'\n"
1070 "8: targets = {y}, decl\n"},
1071 {R"cpp(
1072 void foo() {
1073 $0^ten: // PRINT "HELLO WORLD!"
1074 goto $1^ten;
1075 }
1076 )cpp",
1077 "0: targets = {ten}, decl\n"
1078 "1: targets = {ten}\n"},
1079 // Simple templates.
1080 {R"cpp(
1081 template <class T> struct vector { using value_type = T; };
1082 template <> struct vector<bool> { using value_type = bool; };
1083 void foo() {
1084 $0^vector<int> $1^vi;
1085 $2^vector<bool> $3^vb;
1086 }
1087 )cpp",
1088 "0: targets = {vector<int>}\n"
1089 "1: targets = {vi}, decl\n"
1090 "2: targets = {vector<bool>}\n"
1091 "3: targets = {vb}, decl\n"},
1092 // Template type aliases.
1093 {R"cpp(
1094 template <class T> struct vector { using value_type = T; };
1095 template <> struct vector<bool> { using value_type = bool; };
1096 template <class T> using valias = vector<T>;
1097 void foo() {
1098 $0^valias<int> $1^vi;
1099 $2^valias<bool> $3^vb;
1100 }
1101 )cpp",
1102 "0: targets = {valias}\n"
1103 "1: targets = {vi}, decl\n"
1104 "2: targets = {valias}\n"
1105 "3: targets = {vb}, decl\n"},
1106 // Injected class name.
1107 {R"cpp(
1108 namespace foo {
1109 template <typename $0^T>
1110 class $1^Bar {
1111 ~$2^Bar();
1112 void $3^f($4^Bar);
1113 };
1114 }
1115 )cpp",
1116 "0: targets = {foo::Bar::T}, decl\n"
1117 "1: targets = {foo::Bar}, decl\n"
1118 "2: targets = {foo::Bar}\n"
1119 "3: targets = {foo::Bar::f}, decl\n"
1120 "4: targets = {foo::Bar}\n"},
1121 // MemberExpr should know their using declaration.
1122 {R"cpp(
1123 struct X { void func(int); };
1124 struct Y : X {
1125 using X::func;
1126 };
1127 void foo(Y y) {
1128 $0^y.$1^func(1);
1129 }
1130 )cpp",
1131 "0: targets = {y}\n"
1132 "1: targets = {Y::func}\n"},
1133 // DeclRefExpr should know their using declaration.
1134 {R"cpp(
1135 namespace ns { void bar(int); }
1136 using ns::bar;
1137
1138 void foo() {
1139 $0^bar(10);
1140 }
1141 )cpp",
1142 "0: targets = {bar}\n"},
1143 // References from a macro.
1144 {R"cpp(
1145 #define FOO a
1146 #define BAR b
1147
1148 void foo(int a, int b) {
1149 $0^FOO+$1^BAR;
1150 }
1151 )cpp",
1152 "0: targets = {a}\n"
1153 "1: targets = {b}\n"},
1154 // No references from implicit nodes.
1155 {R"cpp(
1156 struct vector {
1157 int *begin();
1158 int *end();
1159 };
1160
1161 void foo() {
1162 for (int $0^x : $1^vector()) {
1163 $2^x = 10;
1164 }
1165 }
1166 )cpp",
1167 "0: targets = {x}, decl\n"
1168 "1: targets = {vector}\n"
1169 "2: targets = {x}\n"},
1170 // Handle UnresolvedLookupExpr.
1171 // FIXME
1172 // This case fails when expensive checks are enabled.
1173 // Seems like the order of ns1::func and ns2::func isn't defined.
1174 #ifndef EXPENSIVE_CHECKS
1175 {R"cpp(
1176 namespace ns1 { void func(char*); }
1177 namespace ns2 { void func(int*); }
1178 using namespace ns1;
1179 using namespace ns2;
1180
1181 template <class T>
1182 void foo(T t) {
1183 $0^func($1^t);
1184 }
1185 )cpp",
1186 "0: targets = {ns1::func, ns2::func}\n"
1187 "1: targets = {t}\n"},
1188 #endif
1189 // Handle UnresolvedMemberExpr.
1190 {R"cpp(
1191 struct X {
1192 void func(char*);
1193 void func(int*);
1194 };
1195
1196 template <class T>
1197 void foo(X x, T t) {
1198 $0^x.$1^func($2^t);
1199 }
1200 )cpp",
1201 "0: targets = {x}\n"
1202 "1: targets = {X::func, X::func}\n"
1203 "2: targets = {t}\n"},
1204 // Handle DependentScopeDeclRefExpr.
1205 {R"cpp(
1206 template <class T>
1207 struct S {
1208 static int value;
1209 };
1210
1211 template <class T>
1212 void foo() {
1213 $0^S<$1^T>::$2^value;
1214 }
1215 )cpp",
1216 "0: targets = {S}\n"
1217 "1: targets = {T}\n"
1218 "2: targets = {S::value}, qualifier = 'S<T>::'\n"},
1219 // Handle CXXDependentScopeMemberExpr.
1220 {R"cpp(
1221 template <class T>
1222 struct S {
1223 int value;
1224 };
1225
1226 template <class T>
1227 void foo(S<T> t) {
1228 $0^t.$1^value;
1229 }
1230 )cpp",
1231 "0: targets = {t}\n"
1232 "1: targets = {S::value}\n"},
1233 // Type template parameters.
1234 {R"cpp(
1235 template <class T>
1236 void foo() {
1237 static_cast<$0^T>(0);
1238 $1^T();
1239 $2^T $3^t;
1240 }
1241 )cpp",
1242 "0: targets = {T}\n"
1243 "1: targets = {T}\n"
1244 "2: targets = {T}\n"
1245 "3: targets = {t}, decl\n"},
1246 // Non-type template parameters.
1247 {R"cpp(
1248 template <int I>
1249 void foo() {
1250 int $0^x = $1^I;
1251 }
1252 )cpp",
1253 "0: targets = {x}, decl\n"
1254 "1: targets = {I}\n"},
1255 // Template template parameters.
1256 {R"cpp(
1257 template <class T> struct vector {};
1258
1259 template <template<class> class TT, template<class> class ...TP>
1260 void foo() {
1261 $0^TT<int> $1^x;
1262 $2^foo<$3^TT>();
1263 $4^foo<$5^vector>();
1264 $6^foo<$7^TP...>();
1265 }
1266 )cpp",
1267 "0: targets = {TT}\n"
1268 "1: targets = {x}, decl\n"
1269 "2: targets = {foo}\n"
1270 "3: targets = {TT}\n"
1271 "4: targets = {foo}\n"
1272 "5: targets = {vector}\n"
1273 "6: targets = {foo}\n"
1274 "7: targets = {TP}\n"},
1275 // Non-type template parameters with declarations.
1276 {R"cpp(
1277 int func();
1278 template <int(*)()> struct wrapper {};
1279
1280 template <int(*FuncParam)()>
1281 void foo() {
1282 $0^wrapper<$1^func> $2^w;
1283 $3^FuncParam();
1284 }
1285 )cpp",
1286 "0: targets = {wrapper<&func>}\n"
1287 "1: targets = {func}\n"
1288 "2: targets = {w}, decl\n"
1289 "3: targets = {FuncParam}\n"},
1290 // declaration references.
1291 {R"cpp(
1292 namespace ns {}
1293 class S {};
1294 void foo() {
1295 class $0^Foo { $1^Foo(); ~$2^Foo(); int $3^field; };
1296 int $4^Var;
1297 enum $5^E { $6^ABC };
1298 typedef int $7^INT;
1299 using $8^INT2 = int;
1300 namespace $9^NS = $10^ns;
1301 }
1302 )cpp",
1303 "0: targets = {Foo}, decl\n"
1304 "1: targets = {foo()::Foo::Foo}, decl\n"
1305 "2: targets = {Foo}\n"
1306 "3: targets = {foo()::Foo::field}, decl\n"
1307 "4: targets = {Var}, decl\n"
1308 "5: targets = {E}, decl\n"
1309 "6: targets = {foo()::ABC}, decl\n"
1310 "7: targets = {INT}, decl\n"
1311 "8: targets = {INT2}, decl\n"
1312 "9: targets = {NS}, decl\n"
1313 "10: targets = {ns}\n"},
1314 // User-defined conversion operator.
1315 {R"cpp(
1316 void foo() {
1317 class $0^Bar {};
1318 class $1^Foo {
1319 public:
1320 // FIXME: This should have only one reference to Bar.
1321 $2^operator $3^$4^Bar();
1322 };
1323
1324 $5^Foo $6^f;
1325 $7^f.$8^operator $9^Bar();
1326 }
1327 )cpp",
1328 "0: targets = {Bar}, decl\n"
1329 "1: targets = {Foo}, decl\n"
1330 "2: targets = {foo()::Foo::operator Bar}, decl\n"
1331 "3: targets = {Bar}\n"
1332 "4: targets = {Bar}\n"
1333 "5: targets = {Foo}\n"
1334 "6: targets = {f}, decl\n"
1335 "7: targets = {f}\n"
1336 "8: targets = {foo()::Foo::operator Bar}\n"
1337 "9: targets = {Bar}\n"},
1338 // Destructor.
1339 {R"cpp(
1340 void foo() {
1341 class $0^Foo {
1342 public:
1343 ~$1^Foo() {}
1344
1345 void $2^destructMe() {
1346 this->~$3^Foo();
1347 }
1348 };
1349
1350 $4^Foo $5^f;
1351 $6^f.~ /*...*/ $7^Foo();
1352 }
1353 )cpp",
1354 "0: targets = {Foo}, decl\n"
1355 // FIXME: It's better to target destructor's FunctionDecl instead of
1356 // the type itself (similar to constructor).
1357 "1: targets = {Foo}\n"
1358 "2: targets = {foo()::Foo::destructMe}, decl\n"
1359 "3: targets = {Foo}\n"
1360 "4: targets = {Foo}\n"
1361 "5: targets = {f}, decl\n"
1362 "6: targets = {f}\n"
1363 "7: targets = {Foo}\n"},
1364 // cxx constructor initializer.
1365 {R"cpp(
1366 class Base {};
1367 void foo() {
1368 // member initializer
1369 class $0^X {
1370 int $1^abc;
1371 $2^X(): $3^abc() {}
1372 };
1373 // base initializer
1374 class $4^Derived : public $5^Base {
1375 $6^Base $7^B;
1376 $8^Derived() : $9^Base() {}
1377 };
1378 // delegating initializer
1379 class $10^Foo {
1380 $11^Foo(int);
1381 $12^Foo(): $13^Foo(111) {}
1382 };
1383 }
1384 )cpp",
1385 "0: targets = {X}, decl\n"
1386 "1: targets = {foo()::X::abc}, decl\n"
1387 "2: targets = {foo()::X::X}, decl\n"
1388 "3: targets = {foo()::X::abc}\n"
1389 "4: targets = {Derived}, decl\n"
1390 "5: targets = {Base}\n"
1391 "6: targets = {Base}\n"
1392 "7: targets = {foo()::Derived::B}, decl\n"
1393 "8: targets = {foo()::Derived::Derived}, decl\n"
1394 "9: targets = {Base}\n"
1395 "10: targets = {Foo}, decl\n"
1396 "11: targets = {foo()::Foo::Foo}, decl\n"
1397 "12: targets = {foo()::Foo::Foo}, decl\n"
1398 "13: targets = {Foo}\n"},
1399 // Anonymous entities should not be reported.
1400 {
1401 R"cpp(
1402 void foo() {
1403 class {} $0^x;
1404 int (*$1^fptr)(int $2^a, int) = nullptr;
1405 }
1406 )cpp",
1407 "0: targets = {x}, decl\n"
1408 "1: targets = {fptr}, decl\n"
1409 "2: targets = {a}, decl\n"},
1410 // Namespace aliases should be handled properly.
1411 {
1412 R"cpp(
1413 namespace ns { struct Type {}; }
1414 namespace alias = ns;
1415 namespace rec_alias = alias;
1416
1417 void foo() {
1418 $0^ns::$1^Type $2^a;
1419 $3^alias::$4^Type $5^b;
1420 $6^rec_alias::$7^Type $8^c;
1421 }
1422 )cpp",
1423 "0: targets = {ns}\n"
1424 "1: targets = {ns::Type}, qualifier = 'ns::'\n"
1425 "2: targets = {a}, decl\n"
1426 "3: targets = {alias}\n"
1427 "4: targets = {ns::Type}, qualifier = 'alias::'\n"
1428 "5: targets = {b}, decl\n"
1429 "6: targets = {rec_alias}\n"
1430 "7: targets = {ns::Type}, qualifier = 'rec_alias::'\n"
1431 "8: targets = {c}, decl\n"},
1432 // Handle SizeOfPackExpr.
1433 {
1434 R"cpp(
1435 template <typename... E>
1436 void foo() {
1437 constexpr int $0^size = sizeof...($1^E);
1438 };
1439 )cpp",
1440 "0: targets = {size}, decl\n"
1441 "1: targets = {E}\n"},
1442 // Class template argument deduction
1443 {
1444 R"cpp(
1445 template <typename T>
1446 struct Test {
1447 Test(T);
1448 };
1449 void foo() {
1450 $0^Test $1^a(5);
1451 }
1452 )cpp",
1453 "0: targets = {Test}\n"
1454 "1: targets = {a}, decl\n"},
1455 // Templates
1456 {R"cpp(
1457 namespace foo {
1458 template <typename $0^T>
1459 class $1^Bar {};
1460 }
1461 )cpp",
1462 "0: targets = {foo::Bar::T}, decl\n"
1463 "1: targets = {foo::Bar}, decl\n"},
1464 // Templates
1465 {R"cpp(
1466 namespace foo {
1467 template <typename $0^T>
1468 void $1^func();
1469 }
1470 )cpp",
1471 "0: targets = {T}, decl\n"
1472 "1: targets = {foo::func}, decl\n"},
1473 // Templates
1474 {R"cpp(
1475 namespace foo {
1476 template <typename $0^T>
1477 $1^T $2^x;
1478 }
1479 )cpp",
1480 "0: targets = {foo::T}, decl\n"
1481 "1: targets = {foo::T}\n"
1482 "2: targets = {foo::x}, decl\n"},
1483 // Templates
1484 {R"cpp(
1485 template<typename T> class vector {};
1486 namespace foo {
1487 template <typename $0^T>
1488 using $1^V = $2^vector<$3^T>;
1489 }
1490 )cpp",
1491 "0: targets = {foo::T}, decl\n"
1492 "1: targets = {foo::V}, decl\n"
1493 "2: targets = {vector}\n"
1494 "3: targets = {foo::T}\n"},
1495 // Concept
1496 {
1497 R"cpp(
1498 template <typename T>
1499 concept Drawable = requires (T t) { t.draw(); };
1500
1501 namespace foo {
1502 template <typename $0^T> requires $1^Drawable<$2^T>
1503 void $3^bar($4^T $5^t) {
1504 $6^t.$7^draw();
1505 }
1506 }
1507 )cpp",
1508 "0: targets = {T}, decl\n"
1509 "1: targets = {Drawable}\n"
1510 "2: targets = {T}\n"
1511 "3: targets = {foo::bar}, decl\n"
1512 "4: targets = {T}\n"
1513 "5: targets = {t}, decl\n"
1514 "6: targets = {t}\n"
1515 "7: targets = {}\n"},
1516 // Objective-C: properties
1517 {
1518 R"cpp(
1519 @interface I {}
1520 @property(retain) I* x;
1521 @property(retain) I* y;
1522 @end
1523 I *f;
1524 void foo() {
1525 $0^f.$1^x.$2^y = 0;
1526 }
1527 )cpp",
1528 "0: targets = {f}\n"
1529 "1: targets = {I::x}\n"
1530 "2: targets = {I::y}\n"},
1531 // Objective-C: implicit properties
1532 {
1533 R"cpp(
1534 @interface I {}
1535 -(I*)x;
1536 -(void)setY:(I*)y;
1537 @end
1538 I *f;
1539 void foo() {
1540 $0^f.$1^x.$2^y = 0;
1541 }
1542 )cpp",
1543 "0: targets = {f}\n"
1544 "1: targets = {I::x}\n"
1545 "2: targets = {I::setY:}\n"},
1546 // Designated initializers.
1547 {R"cpp(
1548 void foo() {
1549 struct $0^Foo {
1550 int $1^Bar;
1551 };
1552 $2^Foo $3^f { .$4^Bar = 42 };
1553 }
1554 )cpp",
1555 "0: targets = {Foo}, decl\n"
1556 "1: targets = {foo()::Foo::Bar}, decl\n"
1557 "2: targets = {Foo}\n"
1558 "3: targets = {f}, decl\n"
1559 "4: targets = {foo()::Foo::Bar}\n"},
1560 {R"cpp(
1561 void foo() {
1562 struct $0^Baz {
1563 int $1^Field;
1564 };
1565 struct $2^Bar {
1566 $3^Baz $4^Foo;
1567 };
1568 $5^Bar $6^bar { .$7^Foo.$8^Field = 42 };
1569 }
1570 )cpp",
1571 "0: targets = {Baz}, decl\n"
1572 "1: targets = {foo()::Baz::Field}, decl\n"
1573 "2: targets = {Bar}, decl\n"
1574 "3: targets = {Baz}\n"
1575 "4: targets = {foo()::Bar::Foo}, decl\n"
1576 "5: targets = {Bar}\n"
1577 "6: targets = {bar}, decl\n"
1578 "7: targets = {foo()::Bar::Foo}\n"
1579 "8: targets = {foo()::Baz::Field}\n"},
1580 {R"cpp(
1581 template<typename T>
1582 void crash(T);
1583 template<typename T>
1584 void foo() {
1585 $0^crash({.$1^x = $2^T()});
1586 }
1587 )cpp",
1588 "0: targets = {crash}\n"
1589 "1: targets = {}\n"
1590 "2: targets = {T}\n"},
1591 // unknown template name should not crash.
1592 {R"cpp(
1593 template <template <typename> typename T>
1594 struct Base {};
1595 namespace foo {
1596 template <typename $0^T>
1597 struct $1^Derive : $2^Base<$3^T::template $4^Unknown> {};
1598 }
1599 )cpp",
1600 "0: targets = {foo::Derive::T}, decl\n"
1601 "1: targets = {foo::Derive}, decl\n"
1602 "2: targets = {Base}\n"
1603 "3: targets = {foo::Derive::T}\n"
1604 "4: targets = {}, qualifier = 'T::'\n"},
1605 // deduction guide
1606 {R"cpp(
1607 namespace foo {
1608 template <typename $0^T>
1609 struct $1^Test {
1610 template <typename $2^I>
1611 $3^Test($4^I);
1612 };
1613 template <typename $5^I>
1614 $6^Test($7^I) -> $8^Test<typename $9^I::$10^type>;
1615 }
1616 )cpp",
1617 "0: targets = {T}, decl\n"
1618 "1: targets = {foo::Test}, decl\n"
1619 "2: targets = {I}, decl\n"
1620 "3: targets = {foo::Test::Test<T>}, decl\n"
1621 "4: targets = {I}\n"
1622 "5: targets = {I}, decl\n"
1623 "6: targets = {foo::Test}\n"
1624 "7: targets = {I}\n"
1625 "8: targets = {foo::Test}\n"
1626 "9: targets = {I}\n"
1627 "10: targets = {}, qualifier = 'I::'\n"}};
1628
1629 for (const auto &C : Cases) {
1630 llvm::StringRef ExpectedCode = C.first;
1631 llvm::StringRef ExpectedRefs = C.second;
1632
1633 auto Actual =
1634 annotateReferencesInFoo(llvm::Annotations(ExpectedCode).code());
1635 EXPECT_EQ(ExpectedCode, Actual.AnnotatedCode);
1636 EXPECT_EQ(ExpectedRefs, Actual.DumpedReferences) << ExpectedCode;
1637 }
1638 }
1639
1640 } // namespace
1641 } // namespace clangd
1642 } // namespace clang
1643