[llvm-branch-commits] [clang] e08c165 - [clangd] Avoid crash when printing call to string literal operator template
Tobias Hieta via llvm-branch-commits
llvm-branch-commits at lists.llvm.org
Tue Sep 27 23:16:59 PDT 2022
Author: Nathan Ridge
Date: 2022-09-28T08:16:42+02:00
New Revision: e08c165dd67a60635cc131ad7a73dcdb368d5e06
URL: https://github.com/llvm/llvm-project/commit/e08c165dd67a60635cc131ad7a73dcdb368d5e06
DIFF: https://github.com/llvm/llvm-project/commit/e08c165dd67a60635cc131ad7a73dcdb368d5e06.diff
LOG: [clangd] Avoid crash when printing call to string literal operator template
Differential Revision: https://reviews.llvm.org/D132830
(cherry picked from commit 898c421975ed36b99ec2047589384539bd29a40b)
Added:
Modified:
clang/lib/AST/StmtPrinter.cpp
clang/unittests/AST/StmtPrinterTest.cpp
Removed:
################################################################################
diff --git a/clang/lib/AST/StmtPrinter.cpp b/clang/lib/AST/StmtPrinter.cpp
index 8d778500d103..625048c69a86 100644
--- a/clang/lib/AST/StmtPrinter.cpp
+++ b/clang/lib/AST/StmtPrinter.cpp
@@ -1993,7 +1993,7 @@ void StmtPrinter::VisitUserDefinedLiteral(UserDefinedLiteral *Node) {
cast<FunctionDecl>(DRE->getDecl())->getTemplateSpecializationArgs();
assert(Args);
- if (Args->size() != 1) {
+ if (Args->size() != 1 || Args->get(0).getKind() != TemplateArgument::Pack) {
const TemplateParameterList *TPL = nullptr;
if (!DRE->hadMultipleCandidates())
if (const auto *TD = dyn_cast<TemplateDecl>(DRE->getDecl()))
diff --git a/clang/unittests/AST/StmtPrinterTest.cpp b/clang/unittests/AST/StmtPrinterTest.cpp
index f3ea74d65696..b6f340507164 100644
--- a/clang/unittests/AST/StmtPrinterTest.cpp
+++ b/clang/unittests/AST/StmtPrinterTest.cpp
@@ -31,7 +31,7 @@ using namespace tooling;
namespace {
-enum class StdVer { CXX98, CXX11, CXX14, CXX17, CXX2a };
+enum class StdVer { CXX98, CXX11, CXX14, CXX17, CXX20 };
DeclarationMatcher FunctionBodyMatcher(StringRef ContainingFunction) {
return functionDecl(hasName(ContainingFunction),
@@ -67,7 +67,9 @@ PrintedStmtCXXMatches(StdVer Standard, StringRef Code, const T &NodeMatch,
case StdVer::CXX11: StdOpt = "-std=c++11"; break;
case StdVer::CXX14: StdOpt = "-std=c++14"; break;
case StdVer::CXX17: StdOpt = "-std=c++17"; break;
- case StdVer::CXX2a: StdOpt = "-std=c++2a"; break;
+ case StdVer::CXX20:
+ StdOpt = "-std=c++20";
+ break;
}
std::vector<std::string> Args = {
@@ -146,6 +148,35 @@ TEST(StmtPrinter, TestFloatingPointLiteral) {
// Should be: with semicolon
}
+TEST(StmtPrinter, TestStringLiteralOperatorTemplate_Pack) {
+ ASSERT_TRUE(PrintedStmtCXXMatches(StdVer::CXX11,
+ R"cpp(
+ template <char...> constexpr double operator""_c() { return 42; }
+ void A() {
+ constexpr auto waldo = 42_c;
+ }
+)cpp",
+ FunctionBodyMatcher("A"),
+ "constexpr auto waldo = 42_c;\n"));
+}
+
+TEST(StmtPrinter, TestStringLiteralOperatorTemplate_Class) {
+ ASSERT_TRUE(
+ PrintedStmtCXXMatches(StdVer::CXX20,
+ R"cpp(
+ struct C {
+ template <unsigned N> constexpr C(const char (&)[N]) : n(N) {}
+ unsigned n;
+ };
+ template <C c> constexpr auto operator""_c() { return c.n; }
+ void A() {
+ constexpr auto waldo = "abc"_c;
+ }
+)cpp",
+ FunctionBodyMatcher("A"),
+ "constexpr auto waldo = operator\"\"_c<{4}>();\n"));
+}
+
TEST(StmtPrinter, TestCXXConversionDeclImplicit) {
ASSERT_TRUE(PrintedStmtCXXMatches(
StdVer::CXX98,
More information about the llvm-branch-commits
mailing list