[PATCH] D85310: [clangd] Disable define out-of-line code action on templates
Kadir Cetinkaya via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Wed Aug 5 09:07:39 PDT 2020
kadircet updated this revision to Diff 283266.
kadircet marked an inline comment as done.
kadircet added a comment.
- Address comments
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D85310/new/
https://reviews.llvm.org/D85310
Files:
clang-tools-extra/clangd/refactor/tweaks/DefineOutline.cpp
clang-tools-extra/clangd/unittests/TweakTests.cpp
Index: clang-tools-extra/clangd/unittests/TweakTests.cpp
===================================================================
--- clang-tools-extra/clangd/unittests/TweakTests.cpp
+++ clang-tools-extra/clangd/unittests/TweakTests.cpp
@@ -2008,6 +2008,13 @@
EXPECT_UNAVAILABLE(R"cpp(
template <typename> struct Foo { void fo^o(){} };
)cpp");
+
+ // Not available on function templates and specializations, as definition must
+ // be visible to all translation units.
+ EXPECT_UNAVAILABLE(R"cpp(
+ template <typename> void fo^o() {};
+ template <> void fo^o<int>() {};
+ )cpp");
}
TEST_F(DefineOutlineTest, FailsWithoutSource) {
@@ -2037,27 +2044,6 @@
"void foo() ;",
"void foo() { return; }",
},
- // Templated function.
- {
- "template <typename T> void fo^o(T, T x) { return; }",
- "template <typename T> void foo(T, T x) ;",
- "template <typename T> void foo(T, T x) { return; }",
- },
- {
- "template <typename> void fo^o() { return; }",
- "template <typename> void foo() ;",
- "template <typename> void foo() { return; }",
- },
- // Template specialization.
- {
- R"cpp(
- template <typename> void foo();
- template <> void fo^o<int>() { return; })cpp",
- R"cpp(
- template <typename> void foo();
- template <> void foo<int>() ;)cpp",
- "template <> void foo<int>() { return; }",
- },
// Default args.
{
"void fo^o(int x, int y = 5, int = 2, int (*foo)(int) = nullptr) {}",
Index: clang-tools-extra/clangd/refactor/tweaks/DefineOutline.cpp
===================================================================
--- clang-tools-extra/clangd/refactor/tweaks/DefineOutline.cpp
+++ clang-tools-extra/clangd/refactor/tweaks/DefineOutline.cpp
@@ -122,9 +122,8 @@
if (!OrigFuncRange)
return llvm::createStringError(llvm::inconvertibleErrorCode(),
"Couldn't get range for function.");
- // Include template parameter list.
- if (auto *FTD = FD->getDescribedFunctionTemplate())
- OrigFuncRange->setBegin(FTD->getBeginLoc());
+ assert(!FD->getDescribedFunctionTemplate() &&
+ "Define out-of-line doesn't apply to function templates.");
// Get new begin and end positions for the qualified function definition.
unsigned FuncBegin = SM.getFileOffset(OrigFuncRange->getBegin());
@@ -387,6 +386,13 @@
Source->isOutOfLine())
return false;
+ // Bail out if this is a function template or specialization, as their
+ // definitions need to be visible in all including translation units.
+ if (auto *PT = Source->getDescribedFunctionTemplate())
+ return false;
+ if (auto *TSI = Source->getTemplateSpecializationInfo())
+ return false;
+
// Bail out in templated classes, as it is hard to spell the class name, i.e
// if the template parameter is unnamed.
if (auto *MD = llvm::dyn_cast<CXXMethodDecl>(Source)) {
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D85310.283266.patch
Type: text/x-patch
Size: 3060 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20200805/2bd9aa9c/attachment-0001.bin>
More information about the cfe-commits
mailing list