mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 04:32:19 +00:00
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:
parent
a553bede23
commit
9e89fe77ce
@ -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.
|
||||||
|
@ -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__)
|
||||||
|
@ -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) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user