[PathV2] In llvm::sys::fs::unique_file, make sure it doesn't fall into an infinite...
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>
Thu, 28 Feb 2013 00:38:19 +0000 (00:38 +0000)
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>
Thu, 28 Feb 2013 00:38:19 +0000 (00:38 +0000)
to create the parent path.

This can happen if the path is a relative filename and the current directory was removed.
Thanks to Daniel D. for the hint in fixing it.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@176226 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Support/Unix/PathV2.inc

index 741f44a9db81a7b6ed5e936f88f95daeeea3c041..44b31b3202f7120fff64db3698660409c36d980c 100644 (file)
@@ -417,6 +417,10 @@ retry_random_path:
       RandomPath[i] = "0123456789abcdef"[sys::Process::GetRandomNumber() & 15];
   }
 
+  // Make sure we don't fall into an infinite loop by constantly trying
+  // to create the parent path.
+  bool TriedToCreateParent = false;
+
   // Try to open + create the file.
 rety_open_create:
   int RandomFD = ::open(RandomPath.c_str(), O_RDWR | O_CREAT | O_EXCL, mode);
@@ -427,7 +431,9 @@ rety_open_create:
       goto retry_random_path;
     // If path prefix doesn't exist, try to create it.
     if (SavedErrno == errc::no_such_file_or_directory &&
-        !exists(path::parent_path(RandomPath))) {
+        !exists(path::parent_path(RandomPath)) &&
+        !TriedToCreateParent) {
+      TriedToCreateParent = true;
       StringRef p(RandomPath);
       SmallString<64> dir_to_create;
       for (path::const_iterator i = path::begin(p),