From eebf60cae51371393c6136d71c7c715350079fb8 Mon Sep 17 00:00:00 2001 From: Mikhail Glushenkov Date: Sat, 4 Jul 2009 14:23:32 +0000 Subject: [PATCH] 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 --- lib/CompilerDriver/Main.cpp | 1 + lib/CompilerDriver/Tool.cpp | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/lib/CompilerDriver/Main.cpp b/lib/CompilerDriver/Main.cpp index c9c0413028d..7d1a3d8fbc4 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 7953dd24934..5a32fd33c3e 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()) {