From 79d4c3d5dbabbf0715e40ea83f5582201870ea6d Mon Sep 17 00:00:00 2001 From: Reid Spencer Date: Mon, 30 Aug 2004 21:46:55 +0000 Subject: [PATCH] Move the GetTemporaryDirectory function from "generic Unix" to platform specific. llvm-svn: 16119 --- llvm/lib/System/AIX/Path.cpp | 12 ++++++++ llvm/lib/System/Cygwin/Path.cpp | 50 +++++++++++++++++++++++++++++++++ llvm/lib/System/Darwin/Path.cpp | 12 ++++++++ llvm/lib/System/Linux/Path.cpp | 12 ++++++++ llvm/lib/System/SunOS/Path.cpp | 14 +++++++++ llvm/lib/System/Unix/Path.cpp | 12 -------- 6 files changed, 100 insertions(+), 12 deletions(-) create mode 100644 llvm/lib/System/Cygwin/Path.cpp diff --git a/llvm/lib/System/AIX/Path.cpp b/llvm/lib/System/AIX/Path.cpp index 117fbfb81bc2..e49a593bc896 100644 --- a/llvm/lib/System/AIX/Path.cpp +++ b/llvm/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/llvm/lib/System/Cygwin/Path.cpp b/llvm/lib/System/Cygwin/Path.cpp new file mode 100644 index 000000000000..00fc5f229d18 --- /dev/null +++ b/llvm/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/llvm/lib/System/Darwin/Path.cpp b/llvm/lib/System/Darwin/Path.cpp index b3321a47dfb6..165bbc64b5ee 100644 --- a/llvm/lib/System/Darwin/Path.cpp +++ b/llvm/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/llvm/lib/System/Linux/Path.cpp b/llvm/lib/System/Linux/Path.cpp index e7efd2fb955c..8ec35b3c4a4a 100644 --- a/llvm/lib/System/Linux/Path.cpp +++ b/llvm/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/llvm/lib/System/SunOS/Path.cpp b/llvm/lib/System/SunOS/Path.cpp index a180bbfe124f..3499d525874a 100644 --- a/llvm/lib/System/SunOS/Path.cpp +++ b/llvm/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/llvm/lib/System/Unix/Path.cpp b/llvm/lib/System/Unix/Path.cpp index 9d9dd99103fe..9a860a0672f2 100644 --- a/llvm/lib/System/Unix/Path.cpp +++ b/llvm/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/"); -- GitLab