aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorReid Spencer <rspencer@reidspencer.com>2004-08-30 21:46:55 +0000
committerReid Spencer <rspencer@reidspencer.com>2004-08-30 21:46:55 +0000
commitf634f4635013235a89a39ac0f218ad2e7967bbc5 (patch)
treebd6fbe0f4e165713e084c7c70bca1a1003bd3d39
parentb60bf6171d031ef38948b40ef0f8de5233f9361c (diff)
Move the GetTemporaryDirectory function from "generic Unix" to platform
specific. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@16119 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/System/AIX/Path.cpp12
-rw-r--r--lib/System/Cygwin/Path.cpp50
-rw-r--r--lib/System/Darwin/Path.cpp12
-rw-r--r--lib/System/Linux/Path.cpp12
-rw-r--r--lib/System/SunOS/Path.cpp14
-rw-r--r--lib/System/Unix/Path.cpp12
-rw-r--r--lib/System/Unix/Path.inc12
7 files changed, 100 insertions, 24 deletions
diff --git a/lib/System/AIX/Path.cpp b/lib/System/AIX/Path.cpp
index 117fbfb81b..e49a593bc8 100644
--- a/lib/System/AIX/Path.cpp
+++ b/lib/System/AIX/Path.cpp
@@ -31,6 +31,18 @@ Path::is_valid() const {
return true;
}
+Path
+Path::GetTemporaryDirectory() {
+ char pathname[MAXPATHLEN];
+ strcpy(pathname,"/tmp/llvm_XXXXXX");
+ if (0 == mkdtemp(pathname))
+ ThrowErrno(std::string(pathname) + ": Can't create temporary directory");
+ Path result;
+ result.set_directory(pathname);
+ assert(result.is_valid() && "mkdtemp didn't create a valid pathname!");
+ return result;
+}
+
}
// vim: sw=2 smartindent smarttab tw=80 autoindent expandtab
diff --git a/lib/System/Cygwin/Path.cpp b/lib/System/Cygwin/Path.cpp
new file mode 100644
index 0000000000..00fc5f229d
--- /dev/null
+++ b/lib/System/Cygwin/Path.cpp
@@ -0,0 +1,50 @@
+//===- Cygwin/Path.cpp - Cygwin Path Implementation -------------*- C++ -*-===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file was developed by Reid Spencer and is distributed under the
+// University of Illinois Open Source License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// This file provides the Cygwin specific implementation of the Path class.
+//
+//===----------------------------------------------------------------------===//
+
+//===----------------------------------------------------------------------===//
+//=== WARNING: Implementation here must contain only Cygwin specific code
+//=== and must not be generic UNIX code (see ../Unix/Path.cpp)
+//===----------------------------------------------------------------------===//
+
+// Include the generic Unix implementation
+#include "../Unix/Path.cpp"
+
+namespace llvm {
+using namespace sys;
+
+bool
+Path::is_valid() const {
+ if (path.empty())
+ return false;
+ char pathname[MAXPATHLEN];
+ if (0 == realpath(path.c_str(), pathname))
+ if (errno != EACCES && errno != EIO && errno != ENOENT && errno != ENOTDIR)
+ return false;
+ return true;
+}
+
+Path
+Path::GetTemporaryDirectory() {
+ char pathname[MAXPATHLEN];
+ strcpy(pathname,"/tmp/llvm_XXXXXX");
+ if (0 == mkdtemp(pathname))
+ ThrowErrno(std::string(pathname) + ": Can't create temporary directory");
+ Path result;
+ result.set_directory(pathname);
+ assert(result.is_valid() && "mkdtemp didn't create a valid pathname!");
+ return result;
+}
+
+}
+
+// vim: sw=2 smartindent smarttab tw=80 autoindent expandtab
diff --git a/lib/System/Darwin/Path.cpp b/lib/System/Darwin/Path.cpp
index b3321a47df..165bbc64b5 100644
--- a/lib/System/Darwin/Path.cpp
+++ b/lib/System/Darwin/Path.cpp
@@ -31,6 +31,18 @@ Path::is_valid() const {
return true;
}
+Path
+Path::GetTemporaryDirectory() {
+ char pathname[MAXPATHLEN];
+ strcpy(pathname,"/tmp/llvm_XXXXXX");
+ if (0 == mkdtemp(pathname))
+ ThrowErrno(std::string(pathname) + ": Can't create temporary directory");
+ Path result;
+ result.set_directory(pathname);
+ assert(result.is_valid() && "mkdtemp didn't create a valid pathname!");
+ return result;
+}
+
}
// vim: sw=2 smartindent smarttab tw=80 autoindent expandtab
diff --git a/lib/System/Linux/Path.cpp b/lib/System/Linux/Path.cpp
index e7efd2fb95..8ec35b3c4a 100644
--- a/lib/System/Linux/Path.cpp
+++ b/lib/System/Linux/Path.cpp
@@ -33,6 +33,18 @@ Path::is_valid() const {
return true;
}
+Path
+Path::GetTemporaryDirectory() {
+ char pathname[MAXPATHLEN];
+ strcpy(pathname,"/tmp/llvm_XXXXXX");
+ if (0 == mkdtemp(pathname))
+ ThrowErrno(std::string(pathname) + ": Can't create temporary directory");
+ Path result;
+ result.set_directory(pathname);
+ assert(result.is_valid() && "mkdtemp didn't create a valid pathname!");
+ return result;
+}
+
}
// vim: sw=2 smartindent smarttab tw=80 autoindent expandtab
diff --git a/lib/System/SunOS/Path.cpp b/lib/System/SunOS/Path.cpp
index a180bbfe12..3499d52587 100644
--- a/lib/System/SunOS/Path.cpp
+++ b/lib/System/SunOS/Path.cpp
@@ -33,6 +33,20 @@ Path::is_valid() const {
return true;
}
+Path
+Path::GetTemporaryDirectory() {
+ char* pathname = tempnam(0,"llvm_");
+ if (0 == pathname)
+ ThrowErrno(std::string("Can't create temporary directory name"));
+ Path result;
+ result.set_directory(pathname);
+ free(pathname);
+ assert(result.is_valid() && "tempnam didn't create a valid pathname!");
+ if (0 != mkdir(result.c_str(), S_IRWXU))
+ ThrowErrno(result.get() + ": Can't create temporary directory");
+ return result;
+}
+
}
// vim: sw=2 smartindent smarttab tw=80 autoindent expandtab
diff --git a/lib/System/Unix/Path.cpp b/lib/System/Unix/Path.cpp
index 9d9dd99103..9a860a0672 100644
--- a/lib/System/Unix/Path.cpp
+++ b/lib/System/Unix/Path.cpp
@@ -43,18 +43,6 @@ Path::GetRootDirectory() {
return result;
}
-Path
-Path::GetTemporaryDirectory() {
- char pathname[MAXPATHLEN];
- strcpy(pathname,"/tmp/llvm_XXXXXX");
- if (0 == mkdtemp(pathname))
- ThrowErrno(std::string(pathname) + ": Can't create temporary directory");
- Path result;
- result.set_directory(pathname);
- assert(result.is_valid() && "mkdtemp didn't create a valid pathname!");
- return result;
-}
-
Path
Path::GetSystemLibraryPath1() {
return Path("/lib/");
diff --git a/lib/System/Unix/Path.inc b/lib/System/Unix/Path.inc
index 9d9dd99103..9a860a0672 100644
--- a/lib/System/Unix/Path.inc
+++ b/lib/System/Unix/Path.inc
@@ -43,18 +43,6 @@ Path::GetRootDirectory() {
return result;
}
-Path
-Path::GetTemporaryDirectory() {
- char pathname[MAXPATHLEN];
- strcpy(pathname,"/tmp/llvm_XXXXXX");
- if (0 == mkdtemp(pathname))
- ThrowErrno(std::string(pathname) + ": Can't create temporary directory");
- Path result;
- result.set_directory(pathname);
- assert(result.is_valid() && "mkdtemp didn't create a valid pathname!");
- return result;
-}
-
Path
Path::GetSystemLibraryPath1() {
return Path("/lib/");