aboutsummaryrefslogtreecommitdiff
path: root/llvm/unittests/Support/CommandLineTest.cpp
diff options
context:
space:
mode:
authorSean Silva <chisophugis@gmail.com>2014-08-15 23:39:01 +0000
committerSean Silva <chisophugis@gmail.com>2014-08-15 23:39:01 +0000
commitdb7948499872e3ace0efaa793b15d2b4d547fc58 (patch)
tree2ac62059c5463fde5a2cdc09075dee3a959c1b39 /llvm/unittests/Support/CommandLineTest.cpp
parentd539f866ac7ade08504f646f073340170502cdbc (diff)
downloadllvm-db7948499872e3ace0efaa793b15d2b4d547fc58.zip
llvm-db7948499872e3ace0efaa793b15d2b4d547fc58.tar.gz
llvm-db7948499872e3ace0efaa793b15d2b4d547fc58.tar.bz2
Revert "[Support] Promote cl::StringSaver to a separate utility"
This reverts commit r215784 / 3f8a26f6fe16cc76c98ab21db2c600bd7defbbaa. LLD has 3 StringSaver's, one of which takes a lock when saving the string... Need to investigate more closely. llvm-svn: 215790
Diffstat (limited to 'llvm/unittests/Support/CommandLineTest.cpp')
-rw-r--r--llvm/unittests/Support/CommandLineTest.cpp11
1 files changed, 9 insertions, 2 deletions
diff --git a/llvm/unittests/Support/CommandLineTest.cpp b/llvm/unittests/Support/CommandLineTest.cpp
index ffabaca..e4a1b67 100644
--- a/llvm/unittests/Support/CommandLineTest.cpp
+++ b/llvm/unittests/Support/CommandLineTest.cpp
@@ -146,19 +146,26 @@ TEST(CommandLineTest, UseOptionCategory) {
"Category.";
}
-typedef void ParserFunction(StringRef Source, StringSaver &Saver,
+class StrDupSaver : public cl::StringSaver {
+ const char *SaveString(const char *Str) override {
+ return strdup(Str);
+ }
+};
+
+typedef void ParserFunction(StringRef Source, llvm::cl::StringSaver &Saver,
SmallVectorImpl<const char *> &NewArgv);
void testCommandLineTokenizer(ParserFunction *parse, const char *Input,
const char *const Output[], size_t OutputSize) {
SmallVector<const char *, 0> Actual;
- StringSaver Saver;
+ StrDupSaver Saver;
parse(Input, Saver, Actual);
EXPECT_EQ(OutputSize, Actual.size());
for (unsigned I = 0, E = Actual.size(); I != E; ++I) {
if (I < OutputSize)
EXPECT_STREQ(Output[I], Actual[I]);
+ free(const_cast<char *>(Actual[I]));
}
}