r180669 - Use LLVM's preferred current_path API instead of calling getcwd(3) directly.
Benjamin Kramer
benny.kra at googlemail.com
Sat Apr 27 01:12:30 PDT 2013
Author: d0k
Date: Sat Apr 27 03:12:29 2013
New Revision: 180669
URL: http://llvm.org/viewvc/llvm-project?rev=180669&view=rev
Log:
Use LLVM's preferred current_path API instead of calling getcwd(3) directly.
The existing code also failed to allocate a buffer for it so getcwd corrupted
the stack. sys::fs::current_path takes care of the memory management.
Modified:
cfe/trunk/lib/Driver/Tools.cpp
Modified: cfe/trunk/lib/Driver/Tools.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/Tools.cpp?rev=180669&r1=180668&r2=180669&view=diff
==============================================================================
--- cfe/trunk/lib/Driver/Tools.cpp (original)
+++ cfe/trunk/lib/Driver/Tools.cpp Sat Apr 27 03:12:29 2013
@@ -1775,9 +1775,6 @@ static bool shouldUseLeafFramePointer(co
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) {
@@ -1794,9 +1791,10 @@ static void addDebugCompDirArg(const Arg
CmdArgs.push_back(Args.MakeArgString(pwd));
return;
}
+
// Fall back to using getcwd.
- char *cwd;
- if (pwd && ::getcwd(cwd, MAXPATHLEN)) {
+ SmallString<128> cwd;
+ if (!llvm::sys::fs::current_path(cwd)) {
CmdArgs.push_back("-fdebug-compilation-dir");
CmdArgs.push_back(Args.MakeArgString(cwd));
}
More information about the cfe-commits
mailing list