diff --git a/unittests/Lex/LexerTest.cpp b/unittests/Lex/LexerTest.cpp index 4bb355393f70ce1279d9e4492ff4b1b51da761b2..a887c22bd301e6120ff709a1dc3d897c4f6d2127 100644 --- a/unittests/Lex/LexerTest.cpp +++ b/unittests/Lex/LexerTest.cpp @@ -402,7 +402,9 @@ TEST_F(LexerTest, DontOverallocateStringifyArgs) { ArgTokens.push_back(tok); } - MacroArgs *MA = MacroArgs::create(MI, ArgTokens, false, *PP); + auto MacroArgsDeleter = [&PP](MacroArgs *M) { M->destroy(*PP); }; + std::unique_ptr<MacroArgs, decltype(MacroArgsDeleter)> MA( + MacroArgs::create(MI, ArgTokens, false, *PP), MacroArgsDeleter); Token Result = MA->getStringifiedArgument(0, *PP, {}, {}); EXPECT_EQ(tok::string_literal, Result.getKind()); EXPECT_STREQ("\"\\\"StrArg\\\"\"", Result.getLiteralData());