From: Daniel Dunbar Date: Wed, 1 Apr 2009 19:08:46 +0000 (+0000) Subject: Support CCC_ADD_ARGS in new driver. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e5be6dac24946e9521af78fce8e531e605f563d4;p=clang Support CCC_ADD_ARGS in new driver. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@68231 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/tools/driver/driver.cpp b/tools/driver/driver.cpp index 880a26acf7..074cab9d0a 100644 --- a/tools/driver/driver.cpp +++ b/tools/driver/driver.cpp @@ -82,8 +82,43 @@ int main(int argc, const char **argv) { TheDriver(new Driver(Path.getBasename().c_str(), Path.getDirname().c_str(), llvm::sys::getHostTriple().c_str(), "a.out", Diags)); - - llvm::OwningPtr C(TheDriver->BuildCompilation(argc, argv)); + + llvm::OwningPtr C; + + // Handle CCC_ADD_ARGS, a comma separated list of extra arguments. + if (const char *Cur = ::getenv("CCC_ADD_ARGS")) { + std::set SavedStrings; + std::vector StringPointers; + + // FIXME: Driver shouldn't take extra initial argument. + StringPointers.push_back(argv[0]); + + for (;;) { + const char *Next = strchr(Cur, ','); + + if (Next) { + if (Cur != Next) { + const char *P = + SavedStrings.insert(std::string(Cur, Next)).first->c_str(); + StringPointers.push_back(P); + } + Cur = Next + 1; + } else { + if (*Cur != '\0') { + const char *P = + SavedStrings.insert(std::string(Cur)).first->c_str(); + StringPointers.push_back(P); + } + break; + } + } + + StringPointers.insert(StringPointers.end(), argv + 1, argv + argc); + + C.reset(TheDriver->BuildCompilation(StringPointers.size(), + &StringPointers[0])); + } else + C.reset(TheDriver->BuildCompilation(argc, argv)); int Res = 0; if (C.get())