From: Sean Silva Date: Fri, 15 Aug 2014 23:39:12 +0000 (+0000) Subject: Revert "Update for LLVM change (StringSaver)" X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=95c7500454aaa62bcc76503306e78057c8c479a5;p=clang Revert "Update for LLVM change (StringSaver)" This reverts commit r215785 / 170ebf4f19459ae51a9561d0e65c87ee4c9b2c97. LLD has some StringSavers that need to be updated. One of which takes a lock and I need to investigate that more closely. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@215791 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/tools/driver/driver.cpp b/tools/driver/driver.cpp index 02efeb0c28..2533401082 100644 --- a/tools/driver/driver.cpp +++ b/tools/driver/driver.cpp @@ -41,7 +41,6 @@ #include "llvm/Support/Program.h" #include "llvm/Support/Regex.h" #include "llvm/Support/Signals.h" -#include "llvm/Support/StringSaver.h" #include "llvm/Support/TargetRegistry.h" #include "llvm/Support/TargetSelect.h" #include "llvm/Support/Timer.h" @@ -282,6 +281,18 @@ static void ParseProgName(SmallVectorImpl &ArgVector, } } +namespace { + class StringSetSaver : public llvm::cl::StringSaver { + public: + StringSetSaver(std::set &Storage) : Storage(Storage) {} + const char *SaveString(const char *Str) override { + return GetStableCStr(Storage, Str); + } + private: + std::set &Storage; + }; +} + static void SetBackdoorDriverOutputsFromEnvVars(Driver &TheDriver) { // Handle CC_PRINT_OPTIONS and CC_PRINT_OPTIONS_FILE. TheDriver.CCPrintOptions = !!::getenv("CC_PRINT_OPTIONS"); @@ -372,7 +383,7 @@ int main(int argc_, const char **argv_) { } std::set SavedStrings; - llvm::StringSaver Saver; + StringSetSaver Saver(SavedStrings); llvm::cl::ExpandResponseFiles(Saver, llvm::cl::TokenizeGNUCommandLine, argv); // Handle -cc1 integrated tools.