aboutsummaryrefslogtreecommitdiff
path: root/lib/System/Win32/Path.cpp
diff options
context:
space:
mode:
authorJeff Cohen <jeffc@jolt-lang.org>2004-12-24 02:38:34 +0000
committerJeff Cohen <jeffc@jolt-lang.org>2004-12-24 02:38:34 +0000
commitcb652550b67807b7b553e0eacc3e5af62cce91c3 (patch)
tree14f610dc378268daf13d5ea920e57ed274bf1fef /lib/System/Win32/Path.cpp
parente32beb78d5780fc05ff4e104f49e05c3d6c41f40 (diff)
Fix VC++ compilation error
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@19124 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/System/Win32/Path.cpp')
-rw-r--r--lib/System/Win32/Path.cpp9
1 files changed, 7 insertions, 2 deletions
diff --git a/lib/System/Win32/Path.cpp b/lib/System/Win32/Path.cpp
index c50877afb1..9377c42645 100644
--- a/lib/System/Win32/Path.cpp
+++ b/lib/System/Win32/Path.cpp
@@ -23,6 +23,9 @@
#include <fstream>
#include <malloc.h>
+// We need to undo a macro defined in Windows.h, otherwise we won't compile:
+#undef CopyFile
+
static void FlipBackSlashes(std::string& s) {
for (size_t i = 0; i < s.size(); i++)
if (s[i] == '\\')
@@ -574,13 +577,15 @@ bool Path::getMagicNumber(std::string& Magic, unsigned len) const {
void
sys::CopyFile(const sys::Path &Dest, const sys::Path &Src) {
- if (!::CopyFile(Src.c_str(), Dest.c_str(), false))
+ // Can't use CopyFile macro defined in Windows.h because it would mess up the
+ // above line. We use the expansion it would have in a non-UNICODE build.
+ if (!::CopyFileA(Src.c_str(), Dest.c_str(), false))
ThrowError("Can't copy '" + Src.toString() +
"' to '" + Dest.toString() + "'");
}
void
-Path::makeUnique( bool reuse_current ) {
+Path::makeUnique(bool reuse_current) {
if (reuse_current && !exists())
return; // File doesn't exist already, just use it!