Index: webrtc/base/thread_darwin.mm |
diff --git a/webrtc/base/thread_darwin.mm b/webrtc/base/thread_darwin.mm |
new file mode 100644 |
index 0000000000000000000000000000000000000000..5bcc5c8c06b220a67baad5182789c7c1fe983e47 |
--- /dev/null |
+++ b/webrtc/base/thread_darwin.mm |
@@ -0,0 +1,93 @@ |
+/* |
+ * Copyright 2017 The WebRTC Project Authors. All rights reserved. |
+ * |
+ * Use of this source code is governed by a BSD-style license |
+ * that can be found in the LICENSE file in the root of the source |
+ * tree. An additional intellectual property rights grant can be found |
+ * in the file PATENTS. All contributing project authors may |
+ * be found in the AUTHORS file in the root of the source tree. |
+ */ |
+ |
+#include "webrtc/base/thread.h" |
+ |
+#import <Foundation/Foundation.h> |
+ |
+#include "webrtc/base/platform_thread.h" |
+ |
+/* |
+ * This file contains platform-specific implementations for several |
+ * methods in rtc::Thread. |
+ */ |
+ |
+namespace { |
+void InitCocoaMultiThreading() { |
+ if ([NSThread isMultiThreaded] == NO) { |
+ // The sole purpose of this autorelease pool is to avoid a console |
+ // message on Leopard that tells us we're autoreleasing the thread |
+ // with no autorelease pool in place. |
+ @autoreleasepool { |
+ [NSThread detachNewThreadSelector:@selector(class) |
+ toTarget:[NSObject class] |
+ withObject:nil]; |
+ } |
+ } |
+ |
+ RTC_DCHECK([NSThread isMultiThreaded]); |
+} |
+} |
+ |
+namespace rtc { |
+ |
+ThreadManager::ThreadManager() { |
+ pthread_key_create(&key_, nullptr); |
+#ifndef NO_MAIN_THREAD_WRAPPING |
+ WrapCurrentThread(); |
+#endif |
+ // This is necessary to alert the cocoa runtime of the fact that |
+ // we are running in a multithreaded environment. |
+ InitCocoaMultiThreading(); |
+} |
+ |
+ThreadManager::~ThreadManager() { |
+ @autoreleasepool { |
+ UnwrapCurrentThread(); |
+ pthread_key_delete(key_); |
+ } |
+} |
+ |
+// static |
+void* Thread::PreRun(void* pv) { |
+ ThreadInit* init = static_cast<ThreadInit*>(pv); |
+ ThreadManager::Instance()->SetCurrentThread(init->thread); |
+ rtc::SetCurrentThreadName(init->thread->name_.c_str()); |
+ @autoreleasepool { |
+ if (init->runnable) { |
+ init->runnable->Run(init->thread); |
+ } else { |
+ init->thread->Run(); |
+ } |
+ } |
+ delete init; |
+ return nullptr; |
+} |
+ |
+bool Thread::ProcessMessages(int cmsLoop) { |
+ int64_t msEnd = (kForever == cmsLoop) ? 0 : TimeAfter(cmsLoop); |
+ int cmsNext = cmsLoop; |
+ |
+ while (true) { |
+ @autoreleasepool { |
+ Message msg; |
+ if (!Get(&msg, cmsNext)) |
+ return !IsQuitting(); |
+ Dispatch(&msg); |
+ |
+ if (cmsLoop != kForever) { |
+ cmsNext = static_cast<int>(TimeUntil(msEnd)); |
+ if (cmsNext < 0) |
+ return true; |
+ } |
+ } |
+ } |
+} |
+} // namespace rtc |