diff options
author | Benjamin Kramer <benny.kra@googlemail.com> | 2013-04-27 08:12:29 +0000 |
---|---|---|
committer | Benjamin Kramer <benny.kra@googlemail.com> | 2013-04-27 08:12:29 +0000 |
commit | 6089adc7310e5e70ac42b5d942344cddb8a48f55 (patch) | |
tree | 0588d295dcd3e78e0c4817d227b6278bbfffb920 /lib/Driver/Tools.cpp | |
parent | 7c993747da28138cadb40fd0b34587cf3a9be499 (diff) |
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.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@180669 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Driver/Tools.cpp')
-rw-r--r-- | lib/Driver/Tools.cpp | 8 |
1 files changed, 3 insertions, 5 deletions
diff --git a/lib/Driver/Tools.cpp b/lib/Driver/Tools.cpp index 40aebd4d10..7e3ed2461a 100644 --- a/lib/Driver/Tools.cpp +++ b/lib/Driver/Tools.cpp @@ -1775,9 +1775,6 @@ 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) { @@ -1794,9 +1791,10 @@ static void addDebugCompDirArg(const ArgList &Args, ArgStringList &CmdArgs) { 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)); } |