#include "llvm/ADT/STLExtras.h"
#include "llvm/Config/config.h"
#include "llvm/Support/CommandLine.h"
+#include "llvm/Support/StringSaver.h"
#include "gtest/gtest.h"
#include <stdlib.h>
#include <string>
#if HAVE_SETENV
// Assume setenv and unsetenv come together.
unsetenv(name);
+#else
+ (void)name; // Suppress -Wunused-private-field.
#endif
}
StackOption(const M0t &M0, const M1t &M1, const M2t &M2, const M3t &M3)
: Base(M0, M1, M2, M3) {}
- ~StackOption() {
- this->removeArgument();
- }
+ ~StackOption() override { this->removeArgument(); }
};
"Failed to modify option's option category.";
Retrieved->setDescription(Description);
- ASSERT_STREQ(Retrieved->HelpStr, Description) <<
- "Changing option description failed.";
+ ASSERT_STREQ(Retrieved->HelpStr.data(), Description)
+ << "Changing option description failed.";
Retrieved->setArgStr(ArgString);
- ASSERT_STREQ(ArgString, Retrieved->ArgStr) <<
- "Failed to modify option's Argument string.";
+ ASSERT_STREQ(ArgString, Retrieved->ArgStr.data())
+ << "Failed to modify option's Argument string.";
Retrieved->setValueStr(ValueString);
- ASSERT_STREQ(Retrieved->ValueStr, ValueString) <<
- "Failed to modify option's Value string.";
+ ASSERT_STREQ(Retrieved->ValueStr.data(), ValueString)
+ << "Failed to modify option's Value string.";
Retrieved->setHiddenFlag(cl::Hidden);
ASSERT_EQ(cl::Hidden, TestOption.getOptionHiddenFlag()) <<
"Category.";
}
-class StrDupSaver : public cl::StringSaver {
- const char *SaveString(const char *Str) override {
- return strdup(Str);
- }
-};
-
-typedef void ParserFunction(StringRef Source, llvm::cl::StringSaver &Saver,
+typedef void ParserFunction(StringRef Source, StringSaver &Saver,
SmallVectorImpl<const char *> &NewArgv,
bool MarkEOLs);
void testCommandLineTokenizer(ParserFunction *parse, const char *Input,
const char *const Output[], size_t OutputSize) {
SmallVector<const char *, 0> Actual;
- StrDupSaver Saver;
+ BumpPtrAllocator A;
+ StringSaver Saver(A);
parse(Input, Saver, Actual, /*MarkEOLs=*/false);
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]));
}
}