This revision was automatically updated to reflect the committed changes. Closed by commit rG37ec65e1d705: [clangd] Enable expand-auto for decltype(auto). (authored by hokein).
Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D116921/new/ https://reviews.llvm.org/D116921 Files: clang-tools-extra/clangd/refactor/tweaks/ExpandAutoType.cpp clang-tools-extra/clangd/unittests/tweaks/ExpandAutoTypeTests.cpp Index: clang-tools-extra/clangd/unittests/tweaks/ExpandAutoTypeTests.cpp =================================================================== --- clang-tools-extra/clangd/unittests/tweaks/ExpandAutoTypeTests.cpp +++ clang-tools-extra/clangd/unittests/tweaks/ExpandAutoTypeTests.cpp @@ -71,7 +71,8 @@ apply("void ns::Func() { au^to x = new ns::Class::Nested{}; }"), "void ns::Func() { ns::Class::Nested * x = new ns::Class::Nested{}; }"); - EXPECT_UNAVAILABLE("dec^ltype(au^to) x = 10;"); + EXPECT_EQ(apply("dec^ltype(auto) x = 10;"), "int x = 10;"); + EXPECT_EQ(apply("decltype(au^to) x = 10;"), "int x = 10;"); // expanding types in structured bindings is syntactically invalid. EXPECT_UNAVAILABLE("const ^auto &[x,y] = (int[]){1,2};"); Index: clang-tools-extra/clangd/refactor/tweaks/ExpandAutoType.cpp =================================================================== --- clang-tools-extra/clangd/refactor/tweaks/ExpandAutoType.cpp +++ clang-tools-extra/clangd/refactor/tweaks/ExpandAutoType.cpp @@ -96,9 +96,7 @@ if (auto *Node = Inputs.ASTSelection.commonAncestor()) { if (auto *TypeNode = Node->ASTNode.get<TypeLoc>()) { if (const AutoTypeLoc Result = TypeNode->getAs<AutoTypeLoc>()) { - // Code in apply() does handle 'decltype(auto)' yet. - if (!Result.getTypePtr()->isDecltypeAuto() && - !isStructuredBindingType(Node) && + if (!isStructuredBindingType(Node) && !isDeducedAsLambda(Node, Result.getBeginLoc()) && !isTemplateParam(Node)) CachedLocation = Result;
Index: clang-tools-extra/clangd/unittests/tweaks/ExpandAutoTypeTests.cpp =================================================================== --- clang-tools-extra/clangd/unittests/tweaks/ExpandAutoTypeTests.cpp +++ clang-tools-extra/clangd/unittests/tweaks/ExpandAutoTypeTests.cpp @@ -71,7 +71,8 @@ apply("void ns::Func() { au^to x = new ns::Class::Nested{}; }"), "void ns::Func() { ns::Class::Nested * x = new ns::Class::Nested{}; }"); - EXPECT_UNAVAILABLE("dec^ltype(au^to) x = 10;"); + EXPECT_EQ(apply("dec^ltype(auto) x = 10;"), "int x = 10;"); + EXPECT_EQ(apply("decltype(au^to) x = 10;"), "int x = 10;"); // expanding types in structured bindings is syntactically invalid. EXPECT_UNAVAILABLE("const ^auto &[x,y] = (int[]){1,2};"); Index: clang-tools-extra/clangd/refactor/tweaks/ExpandAutoType.cpp =================================================================== --- clang-tools-extra/clangd/refactor/tweaks/ExpandAutoType.cpp +++ clang-tools-extra/clangd/refactor/tweaks/ExpandAutoType.cpp @@ -96,9 +96,7 @@ if (auto *Node = Inputs.ASTSelection.commonAncestor()) { if (auto *TypeNode = Node->ASTNode.get<TypeLoc>()) { if (const AutoTypeLoc Result = TypeNode->getAs<AutoTypeLoc>()) { - // Code in apply() does handle 'decltype(auto)' yet. - if (!Result.getTypePtr()->isDecltypeAuto() && - !isStructuredBindingType(Node) && + if (!isStructuredBindingType(Node) && !isDeducedAsLambda(Node, Result.getBeginLoc()) && !isTemplateParam(Node)) CachedLocation = Result;
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits