Index: ppapi/proxy/resource_reply_thread_registrar.cc |
diff --git a/ppapi/proxy/resource_reply_thread_registrar.cc b/ppapi/proxy/resource_reply_thread_registrar.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..ada34e1c2c37f35a8f0a8c10dd8778444d2f53e3 |
--- /dev/null |
+++ b/ppapi/proxy/resource_reply_thread_registrar.cc |
@@ -0,0 +1,71 @@ |
+// Copyright (c) 2013 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "ppapi/proxy/resource_reply_thread_registrar.h" |
+ |
+#include "base/logging.h" |
+#include "base/message_loop/message_loop_proxy.h" |
+#include "ppapi/shared_impl/proxy_lock.h" |
+#include "ppapi/shared_impl/tracked_callback.h" |
+ |
+namespace ppapi { |
+namespace proxy { |
+ |
+ResourceReplyThreadRegistrar::ResourceReplyThreadRegistrar( |
+ scoped_refptr<base::MessageLoopProxy> default_thread) |
+ : default_thread_(default_thread) { |
+} |
+ |
+ResourceReplyThreadRegistrar::~ResourceReplyThreadRegistrar() { |
+} |
+ |
+void ResourceReplyThreadRegistrar::Register( |
+ PP_Resource resource, |
+ int32_t sequence_number, |
+ scoped_refptr<TrackedCallback> reply_thread_hint) { |
+ ProxyLock::AssertAcquiredDebugOnly(); |
+ |
+ // Use the default thread if |reply_thread_hint| is NULL or blocking. |
+ if (!reply_thread_hint || reply_thread_hint->is_blocking()) |
+ return; |
+ |
+ DCHECK(reply_thread_hint->target_loop()); |
+ scoped_refptr<base::MessageLoopProxy> reply_thread( |
+ reply_thread_hint->target_loop()->GetMessageLoopProxy()); |
+ { |
+ base::AutoLock auto_lock(lock_); |
+ |
+ if (reply_thread == default_thread_) |
+ return; |
+ |
+ map_[resource][sequence_number] = reply_thread; |
+ } |
+} |
+ |
+void ResourceReplyThreadRegistrar::Unregister(PP_Resource resource) { |
+ base::AutoLock auto_lock(lock_); |
+ map_.erase(resource); |
+} |
+ |
+scoped_refptr<base::MessageLoopProxy> |
+ResourceReplyThreadRegistrar::GetTargetThreadAndUnregister( |
+ PP_Resource resource, |
+ int32_t sequence_number) { |
+ base::AutoLock auto_lock(lock_); |
+ ResourceMap::iterator resource_iter = map_.find(resource); |
+ if (resource_iter == map_.end()) |
+ return default_thread_; |
+ |
+ SequenceNumberMap::iterator sequence_number_iter = |
+ resource_iter->second.find(sequence_number); |
+ if (sequence_number_iter == resource_iter->second.end()) |
+ return default_thread_; |
+ |
+ scoped_refptr<base::MessageLoopProxy> target = sequence_number_iter->second; |
+ resource_iter->second.erase(sequence_number_iter); |
+ return target; |
+} |
+ |
+} // namespace proxy |
+} // namespace ppapi |