diff options
author | Mikhail Glushenkov <foldr@codedgers.com> | 2009-07-04 14:23:32 +0000 |
---|---|---|
committer | Mikhail Glushenkov <foldr@codedgers.com> | 2009-07-04 14:23:32 +0000 |
commit | eebf60cae51371393c6136d71c7c715350079fb8 (patch) | |
tree | 4ceb711f8da04c8aca2ed2449537435c86abacc3 /lib/CompilerDriver | |
parent | d0f27c4ebbb445b1bb976a57dbd24df28318e464 (diff) | |
download | external_llvm-eebf60cae51371393c6136d71c7c715350079fb8.zip external_llvm-eebf60cae51371393c6136d71c7c715350079fb8.tar.gz external_llvm-eebf60cae51371393c6136d71c7c715350079fb8.tar.bz2 |
Make -save-temps=obj play better with -o.
Use only the *dirname* of the pathname given to -o, so that -o can still be used
to name the output executable. This is more like what GCC 4.5 does.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@74790 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CompilerDriver')
-rw-r--r-- | lib/CompilerDriver/Main.cpp | 1 | ||||
-rw-r--r-- | lib/CompilerDriver/Tool.cpp | 2 |
2 files changed, 2 insertions, 1 deletions
diff --git a/lib/CompilerDriver/Main.cpp b/lib/CompilerDriver/Main.cpp index c9c0413..7d1a3d8 100644 --- a/lib/CompilerDriver/Main.cpp +++ b/lib/CompilerDriver/Main.cpp @@ -37,6 +37,7 @@ namespace { } else if (SaveTemps == SaveTempsEnum::Obj && !OutputFilename.empty()) { tempDir = OutputFilename; + tempDir = tempDir.getDirname(); if (!tempDir.exists()) { std::string ErrMsg; diff --git a/lib/CompilerDriver/Tool.cpp b/lib/CompilerDriver/Tool.cpp index 7953dd2..5a32fd3 100644 --- a/lib/CompilerDriver/Tool.cpp +++ b/lib/CompilerDriver/Tool.cpp @@ -56,7 +56,7 @@ sys::Path Tool::OutFilename(const sys::Path& In, sys::Path Out; if (StopCompilation) { - if (!OutputFilename.empty() && SaveTemps != SaveTempsEnum::Obj ) { + if (!OutputFilename.empty()) { Out.set(OutputFilename); } else if (IsJoin()) { |