Add GetCurrentDirectory back.

It looks like clang-tools-extra/unittests/cpp11-migrate/TransformTest.cpp
depends on the behaviour of the old one on Windows. Maybe a difference
between GetCurrentDirectoryA and GetCurrentDirectoryW?

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@184009 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Rafael Espindola 2013-06-14 21:41:33 +00:00
parent a553bede23
commit 9e89fe77ce
3 changed files with 26 additions and 0 deletions

View File

@ -102,6 +102,11 @@ namespace sys {
/// directory. /// directory.
static Path GetTemporaryDirectory(std::string* ErrMsg = 0); static Path GetTemporaryDirectory(std::string* ErrMsg = 0);
/// Construct a path to the current directory for the current process.
/// @returns The current working directory.
/// @brief Returns the current working directory.
static Path GetCurrentDirectory();
/// Return the suffix commonly used on file names that contain an /// Return the suffix commonly used on file names that contain an
/// executable. /// executable.
/// @returns The executable file suffix for the current platform. /// @returns The executable file suffix for the current platform.

View File

@ -185,6 +185,17 @@ Path::GetTemporaryDirectory(std::string *ErrMsg) {
#endif #endif
} }
Path
Path::GetCurrentDirectory() {
char pathname[MAXPATHLEN];
if (!getcwd(pathname, MAXPATHLEN)) {
assert(false && "Could not query current working directory.");
return Path();
}
return Path(pathname);
}
#if defined(__FreeBSD__) || defined (__NetBSD__) || defined(__Bitrig__) || \ #if defined(__FreeBSD__) || defined (__NetBSD__) || defined(__Bitrig__) || \
defined(__OpenBSD__) || defined(__minix) || defined(__FreeBSD_kernel__) || \ defined(__OpenBSD__) || defined(__minix) || defined(__FreeBSD_kernel__) || \
defined(__linux__) || defined(__CYGWIN__) defined(__linux__) || defined(__CYGWIN__)

View File

@ -20,6 +20,9 @@
#include <cstdio> #include <cstdio>
#include <malloc.h> #include <malloc.h>
// We need to undo a macro defined in Windows.h, otherwise we won't compile:
#undef GetCurrentDirectory
// Windows happily accepts either forward or backward slashes, though any path // Windows happily accepts either forward or backward slashes, though any path
// returned by a Win32 API will have backward slashes. As LLVM code basically // returned by a Win32 API will have backward slashes. As LLVM code basically
// assumes forward slashes are used, backward slashs are converted where they // assumes forward slashes are used, backward slashs are converted where they
@ -196,6 +199,13 @@ Path::GetTemporaryDirectory(std::string* ErrMsg) {
return *TempDirectory; return *TempDirectory;
} }
Path
Path::GetCurrentDirectory() {
char pathname[MAX_PATH];
::GetCurrentDirectoryA(MAX_PATH,pathname);
return Path(pathname);
}
/// GetMainExecutable - Return the path to the main executable, given the /// GetMainExecutable - Return the path to the main executable, given the
/// value of argv[0] from program startup. /// value of argv[0] from program startup.
Path Path::GetMainExecutable(const char *argv0, void *MainAddr) { Path Path::GetMainExecutable(const char *argv0, void *MainAddr) {