Blame 0001-PATCH-std-thread-copy.patch

049fbf7
diff -ru compiler-rt-8.0.0rc1.src.orig/lib/fuzzer/FuzzerDefs.h compiler-rt-8.0.0rc1.src/lib/fuzzer/FuzzerDefs.h
049fbf7
--- compiler-rt-8.0.0rc1.src.orig/lib/fuzzer/FuzzerDefs.h	2019-01-09 21:46:09.000000000 +0000
049fbf7
+++ compiler-rt-8.0.0rc1.src/lib/fuzzer/FuzzerDefs.h	2019-02-12 14:03:32.971147814 +0000
049fbf7
@@ -176,6 +176,12 @@
049fbf7
 
049fbf7
       template<class Other>
049fbf7
       struct rebind { typedef fuzzer_allocator<Other> other;  };
049fbf7
+
049fbf7
+      template< class U, class... Args >
049fbf7
+      void construct( U* p, Args&&... args ) {
049fbf7
+        std::allocator<T>::construct(p, std::forward<Args>(args)...);
049fbf7
+      }
049fbf7
+
049fbf7
   };
049fbf7
 
049fbf7
 template<typename T>
049fbf7
diff -ru compiler-rt-8.0.0rc1.src.orig/lib/fuzzer/FuzzerDriver.cpp compiler-rt-8.0.0rc1.src/lib/fuzzer/FuzzerDriver.cpp
049fbf7
--- compiler-rt-8.0.0rc1.src.orig/lib/fuzzer/FuzzerDriver.cpp	2019-01-15 22:12:51.000000000 +0000
049fbf7
+++ compiler-rt-8.0.0rc1.src/lib/fuzzer/FuzzerDriver.cpp	2019-02-12 13:05:15.965113872 +0000
049fbf7
@@ -252,7 +252,7 @@
049fbf7
   std::thread Pulse(PulseThread);
049fbf7
   Pulse.detach();
049fbf7
   for (unsigned i = 0; i < NumWorkers; i++)
049fbf7
-    V.push_back(std::thread(WorkerThread, std::ref(Cmd), &Counter, NumJobs, &HasErrors));
049fbf7
+    V.emplace_back(WorkerThread, std::ref(Cmd), &Counter, NumJobs, &HasErrors);
049fbf7
   for (auto &T : V)
049fbf7
     T.join();
049fbf7
   return HasErrors ? 1 : 0;