[llvm] r358460 - Revert [Support] Fix recursive response file expansion guard
Shoaib Meenai via llvm-commits
llvm-commits at lists.llvm.org
Mon Apr 15 15:51:53 PDT 2019
Author: smeenai
Date: Mon Apr 15 15:51:53 2019
New Revision: 358460
URL: http://llvm.org/viewvc/llvm-project?rev=358460&view=rev
Log:
Revert [Support] Fix recursive response file expansion guard
This reverts r358452 (git commit c8df4fb9c3865eac52a99602c26bbc070098c3d4)
A dependent commit breaks the Windows buildbots.
Modified:
llvm/trunk/lib/Support/CommandLine.cpp
llvm/trunk/unittests/Support/CommandLineTest.cpp
Modified: llvm/trunk/lib/Support/CommandLine.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Support/CommandLine.cpp?rev=358460&r1=358459&r2=358460&view=diff
==============================================================================
--- llvm/trunk/lib/Support/CommandLine.cpp (original)
+++ llvm/trunk/lib/Support/CommandLine.cpp Mon Apr 15 15:51:53 2019
@@ -1040,7 +1040,7 @@ static bool ExpandResponseFile(StringRef
bool cl::ExpandResponseFiles(StringSaver &Saver, TokenizerCallback Tokenizer,
SmallVectorImpl<const char *> &Argv,
bool MarkEOLs, bool RelativeNames) {
- unsigned ExpandedRspFiles = 0;
+ unsigned RspFiles = 0;
bool AllExpanded = true;
// Don't cache Argv.size() because it can change.
@@ -1058,16 +1058,14 @@ bool cl::ExpandResponseFiles(StringSaver
// If we have too many response files, leave some unexpanded. This avoids
// crashing on self-referential response files.
- if (ExpandedRspFiles > 20)
+ if (RspFiles++ > 20)
return false;
// Replace this response file argument with the tokenization of its
// contents. Nested response files are expanded in subsequent iterations.
SmallVector<const char *, 0> ExpandedArgv;
- if (ExpandResponseFile(Arg + 1, Saver, Tokenizer, ExpandedArgv, MarkEOLs,
- RelativeNames)) {
- ++ExpandedRspFiles;
- } else {
+ if (!ExpandResponseFile(Arg + 1, Saver, Tokenizer, ExpandedArgv,
+ MarkEOLs, RelativeNames)) {
// We couldn't read this file, so we leave it in the argument stream and
// move on.
AllExpanded = false;
Modified: llvm/trunk/unittests/Support/CommandLineTest.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/unittests/Support/CommandLineTest.cpp?rev=358460&r1=358459&r2=358460&view=diff
==============================================================================
--- llvm/trunk/unittests/Support/CommandLineTest.cpp (original)
+++ llvm/trunk/unittests/Support/CommandLineTest.cpp Mon Apr 15 15:51:53 2019
@@ -813,43 +813,6 @@ TEST(CommandLineTest, RecursiveResponseF
EXPECT_STREQ(Argv[i], ResponseFileRef.c_str());
}
-TEST(CommandLineTest, ResponseFilesAtArguments) {
- SmallString<128> TestDir;
- std::error_code EC = sys::fs::createUniqueDirectory("unittest", TestDir);
- EXPECT_TRUE(!EC);
-
- SmallString<128> ResponseFilePath;
- sys::path::append(ResponseFilePath, TestDir, "test.rsp");
-
- std::ofstream ResponseFile(ResponseFilePath.c_str());
- EXPECT_TRUE(ResponseFile.is_open());
- ResponseFile << "-foo" << "\n";
- ResponseFile << "-bar" << "\n";
- ResponseFile.close();
-
- // Ensure we expand rsp files after lots of non-rsp arguments starting with @.
- constexpr size_t NON_RSP_AT_ARGS = 64;
- llvm::SmallVector<const char *, 4> Argv = {"test/test"};
- Argv.append(NON_RSP_AT_ARGS, "@non_rsp_at_arg");
- std::string ResponseFileRef = std::string("@") + ResponseFilePath.c_str();
- Argv.push_back(ResponseFileRef.c_str());
-
- llvm::BumpPtrAllocator A;
- llvm::StringSaver Saver(A);
- bool Res = llvm::cl::ExpandResponseFiles(
- Saver, llvm::cl::TokenizeGNUCommandLine, Argv, false, false);
- EXPECT_FALSE(Res);
-
- // ASSERT instead of EXPECT to prevent potential out-of-bounds access.
- ASSERT_EQ(Argv.size(), 1 + NON_RSP_AT_ARGS + 2);
- size_t i = 0;
- EXPECT_STREQ(Argv[i++], "test/test");
- for (; i < 1 + NON_RSP_AT_ARGS; ++i)
- EXPECT_STREQ(Argv[i], "@non_rsp_at_arg");
- EXPECT_STREQ(Argv[i++], "-foo");
- EXPECT_STREQ(Argv[i++], "-bar");
-}
-
TEST(CommandLineTest, SetDefautValue) {
cl::ResetCommandLineParser();
More information about the llvm-commits
mailing list