hokein created this revision. hokein added a reviewer: sammccall. Herald added subscribers: usaxena95, kadircet, arphaman. hokein requested review of this revision. Herald added subscribers: MaskRay, ilya-biryukov. Herald added a project: clang-tools-extra.
Repository: rG LLVM Github Monorepo https://reviews.llvm.org/D117463 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 @@ -82,6 +82,11 @@ ExtraArgs.push_back("-std=c++17"); EXPECT_UNAVAILABLE("template <au^to X> class Y;"); + ExtraArgs.back() = "-std=c++20"; + EXPECT_UNAVAILABLE( + R"cpp(template <typename T> concept C = true; +^C a^uto abc(); + )cpp"); } } // namespace 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,7 +96,7 @@ if (auto *Node = Inputs.ASTSelection.commonAncestor()) { if (auto *TypeNode = Node->ASTNode.get<TypeLoc>()) { if (const AutoTypeLoc Result = TypeNode->getAs<AutoTypeLoc>()) { - if (!isStructuredBindingType(Node) && + if (!isStructuredBindingType(Node) && !Result.isConstrained() && !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 @@ -82,6 +82,11 @@ ExtraArgs.push_back("-std=c++17"); EXPECT_UNAVAILABLE("template <au^to X> class Y;"); + ExtraArgs.back() = "-std=c++20"; + EXPECT_UNAVAILABLE( + R"cpp(template <typename T> concept C = true; +^C a^uto abc(); + )cpp"); } } // namespace 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,7 +96,7 @@ if (auto *Node = Inputs.ASTSelection.commonAncestor()) { if (auto *TypeNode = Node->ASTNode.get<TypeLoc>()) { if (const AutoTypeLoc Result = TypeNode->getAs<AutoTypeLoc>()) { - if (!isStructuredBindingType(Node) && + if (!isStructuredBindingType(Node) && !Result.isConstrained() && !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