forked from OSchip/llvm-project
[clang-rename] add support for template parameter renaming
Few simple tweaks allow template parameters to be renamed. See TemplateTypenameFindBy{TemplateParam|TypeInside}.cpp Reviewers: alexfh Differential Revision: https://reviews.llvm.org/D22853 llvm-svn: 277437
This commit is contained in:
parent
a0053cc0af
commit
9e0dab9352
|
@ -77,6 +77,10 @@ public:
|
|||
const auto TypeBeginLoc = Loc.getBeginLoc();
|
||||
const auto TypeEndLoc = Lexer::getLocForEndOfToken(
|
||||
TypeBeginLoc, 0, Context.getSourceManager(), Context.getLangOpts());
|
||||
if (const auto *TemplateTypeParm =
|
||||
dyn_cast<TemplateTypeParmType>(Loc.getType())) {
|
||||
return setResult(TemplateTypeParm->getDecl(), TypeBeginLoc, TypeEndLoc);
|
||||
}
|
||||
return setResult(Loc.getType()->getAsCXXRecordDecl(), TypeBeginLoc,
|
||||
TypeEndLoc);
|
||||
}
|
||||
|
|
|
@ -104,6 +104,13 @@ public:
|
|||
USRSet.end()) {
|
||||
checkAndAddLocation(Loc.getBeginLoc());
|
||||
}
|
||||
if (const auto *TemplateTypeParm =
|
||||
dyn_cast<TemplateTypeParmType>(Loc.getType())) {
|
||||
if (USRSet.find(getUSRForDecl(TemplateTypeParm->getDecl())) !=
|
||||
USRSet.end()) {
|
||||
checkAndAddLocation(Loc.getBeginLoc());
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
|
@ -1,11 +1,7 @@
|
|||
// RUN: cat %s > %t.cpp
|
||||
// RUN: clang-rename -offset=270 -new-name=U %t.cpp -i --
|
||||
// RUN: clang-rename -offset=147 -new-name=U %t.cpp -i --
|
||||
// RUN: sed 's,//.*,,' %t.cpp | FileCheck %s
|
||||
|
||||
// Currently unsupported test.
|
||||
// FIXME: clang-rename should be able to rename template parameters correctly.
|
||||
// XFAIL: *
|
||||
|
||||
template <typename T> // CHECK: template <typename U>
|
||||
class Foo {
|
||||
T foo(T arg, T& ref, T* ptr) { // CHECK: U foo(U arg, U& ref, U* ptr) {
|
||||
|
|
|
@ -1,11 +1,7 @@
|
|||
// RUN: cat %s > %t.cpp
|
||||
// RUN: clang-rename -offset=350 -new-name=U %t.cpp -i --
|
||||
// RUN: clang-rename -offset=227 -new-name=U %t.cpp -i --
|
||||
// RUN: sed 's,//.*,,' %t.cpp | FileCheck %s
|
||||
|
||||
// Currently unsupported test.
|
||||
// FIXME: clang-rename should be able to rename template parameters correctly.
|
||||
// XFAIL: *
|
||||
|
||||
template <typename T> // CHECK: template <typename U>
|
||||
class Foo {
|
||||
T foo(T arg, T& ref, T* ptr) { // CHECK: U foo(U arg, U& ref, U* ptr) {
|
||||
|
|
Loading…
Reference in New Issue