r192091 - Driver: Use the canonical command line arguments.

Reid Kleckner rnk at google.com
Mon Oct 7 09:27:42 PDT 2013


Maybe we can do it with a unit test on the LLVM side.  Testing clang
directly is hard because we either have to commit a source file with
Unicode in the filename or create one from the lit test while worrying
about shell portability.


On Mon, Oct 7, 2013 at 10:27 AM, Nico Weber <thakis at chromium.org> wrote:

> Is it possible to write a test for this?
>
>
> On Mon, Oct 7, 2013 at 12:33 AM, David Majnemer <david.majnemer at gmail.com>wrote:
>
>> Author: majnemer
>> Date: Mon Oct  7 02:33:27 2013
>> New Revision: 192091
>>
>> URL: http://llvm.org/viewvc/llvm-project?rev=192091&view=rev
>> Log:
>> Driver: Use the canonical command line arguments.
>>
>> Summary:
>> Use the arguments given to the OS at process creation-time instead of
>> the arguments passed into main() by the C runtime environment.  The ones
>> that main() received may not be suitable (e.g. not Unicode).
>>
>> Depends on D1834
>>
>> CC: cfe-commits
>>
>> Differential Revision: http://llvm-reviews.chandlerc.com/D1835
>>
>> Modified:
>>     cfe/trunk/tools/driver/driver.cpp
>>
>> Modified: cfe/trunk/tools/driver/driver.cpp
>> URL:
>> http://llvm.org/viewvc/llvm-project/cfe/trunk/tools/driver/driver.cpp?rev=192091&r1=192090&r2=192091&view=diff
>>
>> ==============================================================================
>> --- cfe/trunk/tools/driver/driver.cpp (original)
>> +++ cfe/trunk/tools/driver/driver.cpp Mon Oct  7 02:33:27 2013
>> @@ -37,6 +37,7 @@
>>  #include "llvm/Support/MemoryBuffer.h"
>>  #include "llvm/Support/Path.h"
>>  #include "llvm/Support/PrettyStackTrace.h"
>> +#include "llvm/Support/Process.h"
>>  #include "llvm/Support/Program.h"
>>  #include "llvm/Support/Regex.h"
>>  #include "llvm/Support/Signals.h"
>> @@ -292,8 +293,16 @@ int main(int argc_, const char **argv_)
>>    llvm::sys::PrintStackTraceOnErrorSignal();
>>    llvm::PrettyStackTraceProgram X(argc_, argv_);
>>
>> +  SmallVector<const char *, 256> argv;
>> +  llvm::SpecificBumpPtrAllocator<char> ArgAllocator;
>> +  llvm::error_code EC = llvm::sys::Process::GetArgumentVector(
>> +      argv, llvm::ArrayRef<const char *>(argv_, argc_), ArgAllocator);
>> +  if (EC) {
>> +    llvm::errs() << "error: couldn't get arguments: " << EC.message() <<
>> '\n';
>> +    return 1;
>> +  }
>> +
>>    std::set<std::string> SavedStrings;
>> -  SmallVector<const char*, 256> argv(argv_, argv_ + argc_);
>>    StringSetSaver Saver(SavedStrings);
>>    llvm::cl::ExpandResponseFiles(Saver, llvm::cl::TokenizeGNUCommandLine,
>> argv);
>>
>>
>>
>> _______________________________________________
>> cfe-commits mailing list
>> cfe-commits at cs.uiuc.edu
>> http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
>>
>
>
> _______________________________________________
> cfe-commits mailing list
> cfe-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20131007/fec92cad/attachment.html>


More information about the cfe-commits mailing list