From: Chad Rosier Date: Sat, 27 Apr 2013 01:14:43 +0000 (+0000) Subject: [driver] Revert r180652 and 180658 and temporarily #define MAXPATHLEN to X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=7c993747da28138cadb40fd0b34587cf3a9be499;p=clang [driver] Revert r180652 and 180658 and temporarily #define MAXPATHLEN to make the gdb tests and the Windows bots happy. The Path::GetCurrentDirectory API is not equivalent to ::getcwd(), so r180652 causes a gdb tests to fail. On the other hand, isn't defined on Windows systems, so that causes Windows builds to fail. rdar://12237559 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@180661 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Driver/Tools.cpp b/lib/Driver/Tools.cpp index 5d152e5232..40aebd4d10 100644 --- a/lib/Driver/Tools.cpp +++ b/lib/Driver/Tools.cpp @@ -1775,6 +1775,9 @@ static bool shouldUseLeafFramePointer(const ArgList &Args, return true; } +// FIXME: This is a temporary hack until I can find a fix that works for all +// platforms. +#define MAXPATHLEN 4096 /// If the PWD environment variable is set, add a CC1 option to specify the /// debug compilation directory. static void addDebugCompDirArg(const ArgList &Args, ArgStringList &CmdArgs) { @@ -1792,8 +1795,8 @@ static void addDebugCompDirArg(const ArgList &Args, ArgStringList &CmdArgs) { return; } // Fall back to using getcwd. - std::string cwd = llvm::sys::Path::GetCurrentDirectory().str(); - if (pwd && !cwd.empty()) { + char *cwd; + if (pwd && ::getcwd(cwd, MAXPATHLEN)) { CmdArgs.push_back("-fdebug-compilation-dir"); CmdArgs.push_back(Args.MakeArgString(cwd)); }