//===- unittest/Tooling/LookupTest.cpp ------------------------------------===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #include "TestVisitor.h" #include "clang/Tooling/Core/Lookup.h" using namespace clang; namespace { struct GetDeclsVisitor : TestVisitor { std::function OnCall; SmallVector DeclStack; bool VisitCallExpr(CallExpr *Expr) { OnCall(Expr); return true; } bool TraverseDecl(Decl *D) { DeclStack.push_back(D); bool Ret = TestVisitor::TraverseDecl(D); DeclStack.pop_back(); return Ret; } }; TEST(LookupTest, replaceNestedName) { GetDeclsVisitor Visitor; auto replaceCallExpr = [&](const CallExpr *Expr, StringRef ReplacementString) { const auto *Callee = cast(Expr->getCallee()->IgnoreImplicit()); const ValueDecl *FD = Callee->getDecl(); return tooling::replaceNestedName( Callee->getQualifier(), Visitor.DeclStack.back()->getDeclContext(), FD, ReplacementString); }; Visitor.OnCall = [&](CallExpr *Expr) { EXPECT_EQ("bar", replaceCallExpr(Expr, "::bar")); }; Visitor.runOver("namespace a { void foo(); }\n" "namespace a { void f() { foo(); } }\n"); Visitor.OnCall = [&](CallExpr *Expr) { EXPECT_EQ("bar", replaceCallExpr(Expr, "::a::bar")); }; Visitor.runOver("namespace a { void foo(); }\n" "namespace a { void f() { foo(); } }\n"); Visitor.OnCall = [&](CallExpr *Expr) { EXPECT_EQ("a::bar", replaceCallExpr(Expr, "::a::bar")); }; Visitor.runOver("namespace a { void foo(); }\n" "namespace b { void f() { a::foo(); } }\n"); Visitor.OnCall = [&](CallExpr *Expr) { EXPECT_EQ("a::bar", replaceCallExpr(Expr, "::a::bar")); }; Visitor.runOver("namespace a { void foo(); }\n" "namespace b { namespace a { void foo(); }\n" "void f() { a::foo(); } }\n"); Visitor.OnCall = [&](CallExpr *Expr) { EXPECT_EQ("c::bar", replaceCallExpr(Expr, "::a::c::bar")); }; Visitor.runOver("namespace a { namespace b { void foo(); }\n" "void f() { b::foo(); } }\n"); Visitor.OnCall = [&](CallExpr *Expr) { EXPECT_EQ("bar", replaceCallExpr(Expr, "::a::bar")); }; Visitor.runOver("namespace a { namespace b { void foo(); }\n" "void f() { b::foo(); } }\n"); Visitor.OnCall = [&](CallExpr *Expr) { EXPECT_EQ("bar", replaceCallExpr(Expr, "::bar")); }; Visitor.runOver("void foo(); void f() { foo(); }\n"); Visitor.OnCall = [&](CallExpr *Expr) { EXPECT_EQ("::bar", replaceCallExpr(Expr, "::bar")); }; Visitor.runOver("void foo(); void f() { ::foo(); }\n"); Visitor.OnCall = [&](CallExpr *Expr) { EXPECT_EQ("a::bar", replaceCallExpr(Expr, "::a::bar")); }; Visitor.runOver("namespace a { void foo(); }\nvoid f() { a::foo(); }\n"); Visitor.OnCall = [&](CallExpr *Expr) { EXPECT_EQ("a::bar", replaceCallExpr(Expr, "::a::bar")); }; Visitor.runOver("namespace a { int foo(); }\nauto f = a::foo();\n"); Visitor.OnCall = [&](CallExpr *Expr) { EXPECT_EQ("bar", replaceCallExpr(Expr, "::a::bar")); }; Visitor.runOver( "namespace a { int foo(); }\nusing a::foo;\nauto f = foo();\n"); } } // end anonymous namespace