|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 74636 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | - The Compilation is just a helper class, it shouldn't have that amount of
   logic in it.
 - No functionality change.
llvm-svn: 74634 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Not all tools give good error messages, and sometimes the tool can fail w/o
   any error (for example, when signalled).
 - We suppress this message when the failing command is the compiler and it
   failed normally (exit code == 1), under the assumption that it gave a good
   diagnostic.
For example, for a linker failure we now get:
--
ddunbar@lordcrumb:tmp$ clang a.c b.c
ld: duplicate symbol _x in /var/folders/cl/clrOX6SaG+moCeRKEI4PtU+++TI/-Tmp-/cc-bXYITq.o and /var/folders/cl/clrOX6SaG+moCeRKEI4PtU+++TI/-Tmp-/cc-6uK4jD.o
clang: error: linker command failed with exit code 1 (use -v to see invocation)
--
For a compiler crash we get:
--
ddunbar@lordcrumb:tmp$ clang t.i
Assertion failed: (CGT.getTargetData().getTypeAllocSizeInBits(STy) == RL.getSize()), function layoutStructFields, file CodeGenTypes.cpp, line 573.
0   clang-cc          0x0000000100f1f1f1 PrintStackTrace(void*) + 38
... stack trace and virtual stack trace follow ...
clang: error: compiler command failed due to signal 6 (use -v to see invocation)
--
But for a regular compilation failure we get the usual:
--
ddunbar@lordcrumb:tmp$ clang c.c
c.c:1:6: error: invalid token after top level declarator
int x
     ^
1 diagnostic generated.
--
 - No test case, not amenable to non-executable testing. :/
 - <rdar://problem/6945613>
llvm-svn: 74629 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Lift ArgList to a base class for InputArgList and DerivedArgList.
 
 - This is not a great decomposition, but it does embed the
   translation into the type system, and keep things efficient for
   tool chains that don't want to do any translation.
 - No intended functionality change.
Eventually I hope to get rid of tool chain specific translation and
have each tool do the right thing, but for now this is the easiest way
to match gcc precisely (which is good for testing).
llvm-svn: 67676 | 
| | 
| 
| 
| 
| 
| 
| 
| | is specified.
 - No easy way to make a safe test case for this (given where the
   driver is supposed to put temp files).
llvm-svn: 67632 | 
| | 
| 
| 
| 
| 
| 
| | code; and don't return an error code when -### is present, even if
errors occur.
llvm-svn: 67425 | 
| | 
| 
| 
| | llvm-svn: 67296 | 
| | 
| 
| 
| | llvm-svn: 67295 | 
| | 
| 
| 
| | llvm-svn: 67250 | 
| | 
| 
| 
| | llvm-svn: 67248 | 
| | 
| 
| 
| 
| 
| | construct any jobs).
llvm-svn: 67177 | 
| | 
| 
| 
| 
| 
| | shadowing member.
llvm-svn: 67167 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | earlier.
 - This gives us a simple ownership model, and allows clients access
   to more information should they ever want it.
 - We now free Actions correctly.
llvm-svn: 67158 | 
| | 
| 
| 
| 
| 
| 
| 
| | access to most data should go through the current Compilation, not the
Driver (which shouldn't be specialized on variables for a single
compilation).
llvm-svn: 67037 | 
| | 
| 
| 
| 
| 
| | - Add OptTable instance to Driver.
llvm-svn: 66063 | 
|  | llvm-svn: 65867 |