diff options
author | Reid Spencer <rspencer@reidspencer.com> | 2004-08-30 21:46:55 +0000 |
---|---|---|
committer | Reid Spencer <rspencer@reidspencer.com> | 2004-08-30 21:46:55 +0000 |
commit | f634f4635013235a89a39ac0f218ad2e7967bbc5 (patch) | |
tree | bd6fbe0f4e165713e084c7c70bca1a1003bd3d39 | |
parent | b60bf6171d031ef38948b40ef0f8de5233f9361c (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.cpp | 12 | ||||
-rw-r--r-- | lib/System/Cygwin/Path.cpp | 50 | ||||
-rw-r--r-- | lib/System/Darwin/Path.cpp | 12 | ||||
-rw-r--r-- | lib/System/Linux/Path.cpp | 12 | ||||
-rw-r--r-- | lib/System/SunOS/Path.cpp | 14 | ||||
-rw-r--r-- | lib/System/Unix/Path.cpp | 12 | ||||
-rw-r--r-- | lib/System/Unix/Path.inc | 12 |
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/"); |