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 /lib/System/SunOS/Path.cpp | |
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
Diffstat (limited to 'lib/System/SunOS/Path.cpp')
-rw-r--r-- | lib/System/SunOS/Path.cpp | 14 |
1 files changed, 14 insertions, 0 deletions
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 |